There are 12 distinct cases regarding the orientation of two intervals; The Segmentation::splitSplice() operation shall insert a new Segment and adjust / truncate / expand / split / delete existing segments such as to retain the *Invariant* (seamless segmentation covering the complete time axis)
80087 lines
4 MiB
80087 lines
4 MiB
<map version="1.0.1">
|
|
<!-- To view this file, download free mind mapping software FreeMind from http://freemind.sourceforge.net -->
|
|
<node BACKGROUND_COLOR="#6666ff" CREATED="1434127882200" ID="ID_1452170048" MODIFIED="1680365898333" STYLE="fork" TEXT="Lumi">
|
|
<font NAME="SansSerif" SIZE="25"/>
|
|
<node CREATED="1434128046296" FOLDED="true" ID="ID_1900827283" MODIFIED="1679363052358" POSITION="right" TEXT="GUI">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1434128054470" HGAP="7" ID="ID_1166611516" MODIFIED="1557498707213" TEXT="Workflow" VSHIFT="-15">
|
|
<node CREATED="1455289597596" ID="ID_970065036" MODIFIED="1557498707213" TEXT="work site"/>
|
|
<node CREATED="1455289466261" ID="ID_273679080" MODIFIED="1557498707213" TEXT="PresentationState">
|
|
<node CREATED="1618494980292" ID="ID_1626014832" MODIFIED="1618494985867" TEXT="Anordnung">
|
|
<node CREATED="1618494998061" ID="ID_1125409607" MODIFIED="1618495002909" TEXT="top-level-Windows"/>
|
|
<node CREATED="1618495003597" ID="ID_1454902343" MODIFIED="1618495009282" TEXT="docking panels"/>
|
|
<node CREATED="1618495027486" ID="ID_1793800259" MODIFIED="1618495032901" TEXT="Layout / Aufteilung"/>
|
|
</node>
|
|
<node CREATED="1618495052150" ID="ID_1652649228" MODIFIED="1618495059502" TEXT="lokale Ausprägung">
|
|
<node CREATED="1618495060622" ID="ID_1081072599" MODIFIED="1618495064592" TEXT="expand / collapse"/>
|
|
<node CREATED="1618495065300" ID="ID_1443213129" MODIFIED="1618495072066" TEXT="Darstellungsmodi"/>
|
|
</node>
|
|
<node CREATED="1618495095336" ID="ID_1765572056" MODIFIED="1618495654883" TEXT="Thema: Interaction-State">
|
|
<arrowlink COLOR="#382ab9" DESTINATION="ID_1679641405" ENDARROW="Default" ENDINCLINATION="-962;-111;" ID="Arrow_ID_1636278357" STARTARROW="None" STARTINCLINATION="-502;101;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487210691163" ID="ID_1259700796" MODIFIED="1557498707214" TEXT="konzeptioneller Rahmen">
|
|
<linktarget COLOR="#34dbd3" DESTINATION="ID_1259700796" ENDARROW="Default" ENDINCLINATION="473;607;" ID="Arrow_ID_114106295" SOURCE="ID_1430752735" STARTARROW="None" STARTINCLINATION="-1346;-1090;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1487210978300" ID="ID_1502972928" MODIFIED="1557498707214" TEXT="Spot == wo wir sind"/>
|
|
<node CREATED="1487211011447" ID="ID_61564732" MODIFIED="1557498707214" TEXT="Work Site == wo wir sein können"/>
|
|
<node CREATED="1487211200966" ID="ID_1565474518" MODIFIED="1557498707214" TEXT="Focus == Realisierung des Spot in einem ControlSystem"/>
|
|
<node CREATED="1487211243656" ID="ID_953924547" MODIFIED="1557498707214" TEXT="ControlSystem == Steuerungs-Paradigma">
|
|
<node CREATED="1487211263461" ID="ID_374086294" MODIFIED="1557498707214" TEXT="Maus / current element"/>
|
|
<node CREATED="1487211266901" ID="ID_306043379" MODIFIED="1557498707214" TEXT="Keyboard / Input Focus"/>
|
|
</node>
|
|
<node CREATED="1487211777687" ID="ID_577769257" MODIFIED="1557498707214" TEXT="Focus Path == kanonische Koordinaten innerhalb von einem UI Frame"/>
|
|
<node CREATED="1487211825857" ID="ID_883246945" MODIFIED="1557498707214" TEXT="UI Frame == top-level-Segment (konkret: WorkspaceWindow)"/>
|
|
<node CREATED="1487212066024" ID="ID_378199749" MODIFIED="1557498707214" TEXT="Spot Locator == das was navigiert wird, wenn sich der Spot bewegt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477784761581" HGAP="72" ID="ID_854334914" MODIFIED="1679362096943" TEXT="Rahmen" VGAP="19" VSHIFT="-21">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1481320580216" ID="ID_1418071897" MODIFIED="1679087560455" TEXT="vorantreiben">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1501776053522" FOLDED="true" ID="ID_664046169" MODIFIED="1557498707214" TEXT="Rückpfad Session -> UI">
|
|
<node CREATED="1501776081782" ID="ID_1369579979" MODIFIED="1557498707214" TEXT="warum wichtig?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1501776102419" ID="ID_1120643044" MODIFIED="1557498707214" TEXT="full circle"/>
|
|
<node CREATED="1501776110026" ID="ID_53068153" MODIFIED="1557498707214" TEXT="asynchron"/>
|
|
<node CREATED="1501776132767" ID="ID_1853082326" MODIFIED="1557498707214" TEXT="treibt Diff-System"/>
|
|
</node>
|
|
<node CREATED="1501776157116" ID="ID_198311058" MODIFIED="1557498707214" TEXT="wie">
|
|
<node CREATED="1501776171290" ID="ID_1964256208" MODIFIED="1557498707214" TEXT="Diffs in Proc erzeugen"/>
|
|
<node CREATED="1501776183817" ID="ID_415789885" MODIFIED="1557498707214" TEXT="an UiNotification schicken">
|
|
<arrowlink COLOR="#9292a1" DESTINATION="ID_1578367045" ENDARROW="Default" ENDINCLINATION="45;-124;" ID="Arrow_ID_1265828105" STARTARROW="None" STARTINCLINATION="389;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501940591109" FOLDED="true" ID="ID_1925240675" MODIFIED="1567875602930" TEXT="#1099 DemoGuiRoundtrip">
|
|
<arrowlink COLOR="#e5e53f" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="-931;34;" ID="Arrow_ID_1440938291" STARTARROW="None" STARTINCLINATION="-7;605;"/>
|
|
<linktarget COLOR="#64bf95" DESTINATION="ID_1925240675" ENDARROW="Default" ENDINCLINATION="-664;1183;" ID="Arrow_ID_1404986843" SOURCE="ID_504220515" STARTARROW="None" STARTINCLINATION="821;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501940627280" ID="ID_1675066241" MODIFIED="1557498707214" TEXT="Dummy-Code im UI"/>
|
|
<node CREATED="1501940632871" ID="ID_189611570" MODIFIED="1557498707214" TEXT="Dummy Proc-Command"/>
|
|
<node CREATED="1501940639479" ID="ID_1314787910" MODIFIED="1557498707214" TEXT="komplettes Ping-Pong"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1481320590214" FOLDED="true" ID="ID_635303062" MODIFIED="1679361254765" TEXT="#1042 DummySessionConnection">
|
|
<arrowlink COLOR="#f9b709" DESTINATION="ID_1343270939" ENDARROW="Default" ENDINCLINATION="-36;-73;" ID="Arrow_ID_1867016690" STARTARROW="None" STARTINCLINATION="-34;70;"/>
|
|
<arrowlink COLOR="#f9b709" DESTINATION="ID_330280074" ENDARROW="Default" ENDINCLINATION="-37;-88;" ID="Arrow_ID_779644313" STARTARROW="None" STARTINCLINATION="-34;70;"/>
|
|
<arrowlink COLOR="#f9b709" DESTINATION="ID_791449946" ENDARROW="Default" ENDINCLINATION="-842;-559;" ID="Arrow_ID_1347689482" STARTARROW="None" STARTINCLINATION="-81;124;"/>
|
|
<arrowlink COLOR="#f9b709" DESTINATION="ID_1478381189" ENDARROW="Default" ENDINCLINATION="-1009;-357;" ID="Arrow_ID_1072548081" STARTARROW="None" STARTINCLINATION="-87;103;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1481320639544" ID="ID_1440497947" MODIFIED="1557498707214" TEXT="Singleton"/>
|
|
<node CREATED="1481320642455" ID="ID_1938045938" MODIFIED="1557498707214" TEXT="hat fake Session content"/>
|
|
<node CREATED="1481320650486" ID="ID_155238526" MODIFIED="1557498707214" TEXT="bietet fake Commands"/>
|
|
<node CREATED="1481320666196" ID="ID_1580591981" MODIFIED="1557498707214" TEXT="plus zugehörige Diagnostik"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531419217662" FOLDED="true" ID="ID_1622732481" MODIFIED="1557498707214" TEXT="#1147 establish UI start-up sequence">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1538839140096" ID="ID_1491571377" MODIFIED="1582486086563" TEXT="#1145 define startup sequence">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538839163477" ID="ID_840651927" MODIFIED="1557498707214" TEXT=""eigentlich" schon erledigt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1538839170700" ID="ID_172497653" MODIFIED="1582486080773" STYLE="fork">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b><font color="#288d6e">TODO</font></b>: Infos zusammentragen und dokumentieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1538839205056" ID="ID_1118716259" LINK="https://lumiera.org/documentation/design/architecture/Subsystems.html" MODIFIED="1582486123173" TEXT="Lumiera Website -- Design-Sektion">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1531419242634" ID="ID_1022049727" MODIFIED="1679086735170" TEXT="Interfaces hochfahren">
|
|
<arrowlink COLOR="#effa97" DESTINATION="ID_687951877" ENDARROW="Default" ENDINCLINATION="-340;-552;" ID="Arrow_ID_1500281313" STARTARROW="None" STARTINCLINATION="-258;28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1531419250684" ID="ID_1850773836" MODIFIED="1679086514847" TEXT="Verbindungsstrukturen installieren">
|
|
<arrowlink COLOR="#fee998" DESTINATION="ID_176564515" ENDARROW="Default" ENDINCLINATION="-1211;-7367;" ID="Arrow_ID_157207334" STARTARROW="None" STARTINCLINATION="-617;103;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1679086518956" ID="ID_1318591888" MODIFIED="1679086523839" TEXT="Grundlagen gelöst"/>
|
|
<node CREATED="1679086524571" ID="ID_579336411" MODIFIED="1679086528462" TEXT="funktioniert bereits"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679086529266" ID="ID_1925113808" MODIFIED="1679086548056" TEXT="einige Problempunkte / Fallen sind zu klären">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1523746656723" ID="ID_1022913151" MODIFIED="1667166830055" TEXT="#1140 UI Integration Testing">
|
|
<arrowlink COLOR="#eff1e5" DESTINATION="ID_435582808" ENDARROW="Default" ENDINCLINATION="-1920;189;" ID="Arrow_ID_1348453991" STARTARROW="None" STARTINCLINATION="498;45;"/>
|
|
<arrowlink COLOR="#eff1e5" DESTINATION="ID_406286329" ENDARROW="Default" ENDINCLINATION="-2304;344;" ID="Arrow_ID_1832343822" STARTARROW="None" STARTINCLINATION="498;45;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538938685096" HGAP="138" ID="ID_511824194" MODIFIED="1679362063142" TEXT="gründen" VSHIFT="42">
|
|
<font NAME="SansSerif" SIZE="17"/>
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1477784793993" FOLDED="true" ID="ID_1868522177" MODIFIED="1679362320127" TEXT="Umbau">
|
|
<linktarget COLOR="#30bc74" DESTINATION="ID_1868522177" ENDARROW="Default" ENDINCLINATION="374;490;" ID="Arrow_ID_600425644" SOURCE="ID_707273464" STARTARROW="None" STARTINCLINATION="2009;200;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1477784813895" ID="ID_1343270939" MODIFIED="1679362316058" TEXT="Model durch UI-Bus ersetzen">
|
|
<linktarget COLOR="#f9b709" DESTINATION="ID_1343270939" ENDARROW="Default" ENDINCLINATION="-36;-73;" ID="Arrow_ID_1867016690" SOURCE="ID_635303062" STARTARROW="None" STARTINCLINATION="-34;70;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1343270939" ENDARROW="Default" ENDINCLINATION="-197;638;" ID="Arrow_ID_1686519160" SOURCE="ID_202253849" STARTARROW="Default" STARTINCLINATION="-83;-1020;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1481320683706" FOLDED="true" ID="ID_1226263415" MODIFIED="1557498707215" TEXT="klären, wo der Bus aufgehängt wird">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481331063782" ID="ID_1606852933" MODIFIED="1557498707215" TEXT="Lifecycle-Frontend UI-Bus"/>
|
|
<node CREATED="1481331150275" ID="ID_814186655" MODIFIED="1557498707215" TEXT="CoreService als PImpl"/>
|
|
<node CREATED="1481333616753" ID="ID_709873899" MODIFIED="1557498707215" TEXT="Nexus ist Teil von CoreService"/>
|
|
<node CREATED="1481335769192" ID="ID_1335469664" MODIFIED="1557498707215" TEXT="Interface-Manager gleichermaßen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481320693912" FOLDED="true" ID="ID_918908848" MODIFIED="1576282358165" TEXT="Lebenszyklus klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481332855167" ID="ID_362694314" MODIFIED="1557498707215">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#cf1445">AUA</font>: Henne oder Ei?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1481332888362" ID="ID_85978592" MODIFIED="1576282358165" TEXT="Nexus braucht CoreService braucht Nexus...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Nexus verwendet CoreService als "upstream", um <i>alle sonstigen Nachriten</i> dorthin zuzustellen
|
|
</li>
|
|
<li>
|
|
CoreService hat Nexus als Upstream, um mit dem restlichen System kommunizieren zu können
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1481332999091" ID="ID_1793743943" MODIFIED="1557498707215" TEXT="Problem ist: ich wollte Nexus nicht speziell konstruieren"/>
|
|
<node CREATED="1481338218216" ID="ID_128336616" MODIFIED="1557498707215" TEXT="Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481338222672" ID="ID_318056010" MODIFIED="1576282358165" TEXT="Bus-Term greift tatsächlich nicht auf Uplink zu">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist: im ctor
|
|
</p>
|
|
<p>
|
|
Es speichert nur die Referenz
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Ganz anders Model::Tangible: dieses registriert sich bei der Konstruktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481338237550" ID="ID_781727426" MODIFIED="1557498707215" TEXT="kann also eine Referenz auf lokalen Speicher reinreichen"/>
|
|
<node CREATED="1481338295614" ID="ID_1811061645" MODIFIED="1576282358164" TEXT="Folglich muß Nexus lokal in CoreServices angesiedelt werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oder anders herum,
|
|
</p>
|
|
<p>
|
|
aber so herum macht es mehr Sinn
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481335696027" ID="ID_785830602" MODIFIED="1557498707215" TEXT="Lebenszyklus generell unsauber">
|
|
<node CREATED="1481335709297" ID="ID_1340554881" MODIFIED="1557498707215" TEXT="Ticket #1048"/>
|
|
<node CREATED="1481335723887" ID="ID_689818706" MODIFIED="1557498707215" TEXT="GtkLumiera ist ein Singleton">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1481335735901" ID="ID_185489405" MODIFIED="1557498707215" TEXT="das lebt so viel zu lange">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1481338348143" ID="ID_713195335" MODIFIED="1557498707215" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1481338354702" ID="ID_1755264056" MODIFIED="1557498707215" TEXT="CoreServices ist das Lebenszyklus-PImpl"/>
|
|
<node CREATED="1481338363965" ID="ID_1656280824" MODIFIED="1557498707215" TEXT="wenn geschlossen, muß das ganze übrige GUI schon tot sein"/>
|
|
<node CREATED="1481338393113" ID="ID_1854005469" MODIFIED="1557498707215" TEXT="Warn-Log hierfür eingebaut">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481338408983" ID="ID_516483369" MODIFIED="1557498707215" TEXT="könnte später sogar eine Exception sein">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1484871442777" ID="ID_492545805" MODIFIED="1576282358164">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
CoreService hat <i>keine volle</i> Bus-Connection
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das hab ich mir jetzt explizit so überlegt und es ist sinnvoll.
|
|
</p>
|
|
<p>
|
|
Nur ein Tangible kann eine volle Bus-Connection haben, und das heißt,
|
|
</p>
|
|
<p>
|
|
es kann downlink-Nachrichten bekommen. Dagegen hat CoreService lediglich ein "freistehendes"
|
|
</p>
|
|
<p>
|
|
BusTerm, das damit Nachrichten an den Nexus schicken kann.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481320699056" FOLDED="true" ID="ID_728332859" MODIFIED="1557498707216" TEXT="wo kommen die CoreServices hin?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481338456152" ID="ID_266095129" MODIFIED="1557498707216" TEXT="sie leben im Objekt Ui-Bus"/>
|
|
<node CREATED="1481338465823" ID="ID_78520725" MODIFIED="1557498707216" TEXT="und zwar als PImpl"/>
|
|
<node CREATED="1481338478069" ID="ID_406101846" MODIFIED="1557498707216" TEXT="und UI-Bus lebt im lokalen scope von GtkLumiera::main()"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481320759472" ID="ID_687951877" MODIFIED="1557498707216" TEXT="Interfaces öffnen">
|
|
<linktarget COLOR="#effa97" DESTINATION="ID_687951877" ENDARROW="Default" ENDINCLINATION="-340;-552;" ID="Arrow_ID_1500281313" SOURCE="ID_1022049727" STARTARROW="None" STARTINCLINATION="-258;28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481320765135" FOLDED="true" ID="ID_379585622" MODIFIED="1576282358163">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
UI: <b>GuiNotification</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#51517b" DESTINATION="ID_379585622" ENDARROW="Default" ENDINCLINATION="-476;439;" ID="Arrow_ID_1616528570" SOURCE="ID_1324099152" STARTARROW="Default" STARTINCLINATION="-541;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1484792679322" HGAP="13" ID="ID_426218722" MODIFIED="1576282358163" TEXT="#1047 preliminary definition of GuiNotification facade" VSHIFT="-3">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
4/18 inzwischen hier alles geklärt.
|
|
</p>
|
|
<p>
|
|
Wartet nur noch auf proof-of-concept (DemoGuiRoundtrip)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1493753178082" ID="ID_152757560" MODIFIED="1576282358163" TEXT="grundsätzliche Architektur geklärt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...hängt am UI-Bus,
|
|
</p>
|
|
<p>
|
|
aber nur via einfacher "uplink"-Verbindung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1493753215852" ID="ID_1971120" MODIFIED="1557498707216" TEXT="geklärt: wie kann man Shutdown implementieren">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1493753249399" ID="ID_575609638" MODIFIED="1557498707216" TEXT="geklärt: #1098 hand-Over in UI-Thread">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501776210069" ID="ID_228920906" MODIFIED="1557498707216" TEXT="geklärt: konkrete Diff-Nachrichten">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#5c1010" CREATED="1501776256263" HGAP="21" ID="ID_1196529588" MODIFIED="1557498707216" TEXT="Bedeutung" VSHIFT="-11">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1501776296394" ID="ID_1578367045" MODIFIED="1557498707216" TEXT="Rückpfad Proc -> UI">
|
|
<linktarget COLOR="#9292a1" DESTINATION="ID_1578367045" ENDARROW="Default" ENDINCLINATION="45;-124;" ID="Arrow_ID_1265828105" SOURCE="ID_415789885" STARTARROW="None" STARTINCLINATION="389;0;"/>
|
|
</node>
|
|
<node CREATED="1501776305305" ID="ID_1193603370" MODIFIED="1557498707216" TEXT="Abstraktion des GUI"/>
|
|
<node CREATED="1501776319543" ID="ID_641656399" MODIFIED="1557498707216">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Sicht <i>"von unten"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538267608198" HGAP="39" ID="ID_181594780" MODIFIED="1561827464527" TEXT="paßt der Name" VSHIFT="21">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1533915343891" ID="ID_1650034681" MODIFIED="1538267897031" TEXT="Überlegungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1533915353434" ID="ID_1231213592" MODIFIED="1533915424732" TEXT="ist mehr als "notification"?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533915365545" ID="ID_892577975" MODIFIED="1538267801552" TEXT="ja -- aber vorerst nicht relevant">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1533915439279" ID="ID_285136109" MODIFIED="1533915452025" TEXT="Notification auf Architektur-Level"/>
|
|
</node>
|
|
<node CREATED="1533915371872" ID="ID_1003239787" MODIFIED="1533915380406" TEXT="GuiFeedback?">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533915407171" ID="ID_728064464" MODIFIED="1533915412457" TEXT="GuiReaction">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538263882239" ID="ID_1273122422" MODIFIED="1538263888584" TEXT="GuiResponse">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533915454893" ID="ID_877610316" MODIFIED="1538267861452" TEXT="GuiNotification ist nicht schlecht">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533915472186" ID="ID_1748932158" MODIFIED="1533915479325" TEXT="GuiFeedback würde auch gehen"/>
|
|
<node CREATED="1533915480649" ID="ID_846895155" MODIFIED="1533915485628" TEXT="aber klingt nicht so schön"/>
|
|
<node CREATED="1533915486336" ID="ID_627537189" MODIFIED="1576282358162" TEXT="und ist doppeldeutig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es könnte auch den Feedback des Users meinen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538267874378" ID="ID_1732454504" MODIFIED="1538267888571" TEXT="Umbenennen in GuiResponse">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484877839299" HGAP="33" ID="ID_957622878" MODIFIED="1557498707216" TEXT="Asynchrones Protokoll">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1484877856640" ID="ID_1256835676" MODIFIED="1557498707216" TEXT="bedenke: alle Aktionen müssen in den Event-Thread"/>
|
|
<node CREATED="1484877868015" ID="ID_1612427727" MODIFIED="1557498707216" TEXT="über die Rolle des GUI-Modells nachdenken!"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481502305995" FOLDED="true" HGAP="33" ID="ID_1943234904" MODIFIED="1557498707216" TEXT="direkt vom UiManager betrieben" VSHIFT="-3">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481502320065" HGAP="-23" ID="ID_1298358905" MODIFIED="1557498707216" TEXT="bisher vom GuiRunner betrieben" VSHIFT="-26">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1481502327528" ID="ID_75293128" MODIFIED="1576282358162" TEXT="das ist ohnehin schlecht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil es dadurch passieren könnte,
|
|
</p>
|
|
<p>
|
|
daß die Konstruktion des GuiRunners schon scheitert, bevor der Rumpf des ctors aufgerufen wird.
|
|
</p>
|
|
<p>
|
|
In einem solchen Fall wird leider auch der Rumpf des dtors nicht aufgerufen, wodurch das
|
|
</p>
|
|
<p>
|
|
Term-Signal nicht ausgesendet würde.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1481502335583" ID="ID_1245191241" MODIFIED="1557498707216" TEXT="Felder im GuiRunner sollten noexcept sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1484793048273" ID="ID_66499328" MODIFIED="1557498707216" TEXT="verschoben">
|
|
<arrowlink COLOR="#4072ad" DESTINATION="ID_1019455888" ENDARROW="Default" ENDINCLINATION="6;-96;" ID="Arrow_ID_693735378" STARTARROW="None" STARTINCLINATION="-105;33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484793113472" ID="ID_221612387" MODIFIED="1557498707216" TEXT="Lebenszyklus nochmal prüfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1484797253856" ID="ID_226245696" MODIFIED="1575131660805" TEXT="GUI start sauber">
|
|
<linktarget COLOR="#77c1c5" DESTINATION="ID_226245696" ENDARROW="Default" ENDINCLINATION="-1683;73;" ID="Arrow_ID_532646791" SOURCE="ID_1843835835" STARTARROW="None" STARTINCLINATION="2799;341;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1484797307376" FOLDED="true" ID="ID_842106541" MODIFIED="1582493802070" TEXT="Abfolge">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1484797311008" ID="ID_424744338" MODIFIED="1557498707216" TEXT="GuiFacade::start"/>
|
|
<node CREATED="1484797337516" ID="ID_750979034" MODIFIED="1557498707216" TEXT="erzeugt unique_ptr<GuiRunner>"/>
|
|
<node CREATED="1484797370352" ID="ID_622906815" MODIFIED="1557498707216" TEXT="dieser hat GuiHandle als member">
|
|
<node CREATED="1484797379239" ID="ID_1948690926" MODIFIED="1557498707216" TEXT="läd Plugin"/>
|
|
<node CREATED="1484797399756" ID="ID_1084903350" MODIFIED="1557498707216" TEXT="ruft im ctor launchUi()"/>
|
|
</node>
|
|
<node CREATED="1484797429160" ID="ID_959278184" MODIFIED="1557498707216" TEXT="gtk-lumiera.cpp">
|
|
<node CREATED="1484797432999" ID="ID_1571358017" MODIFIED="1557498707216" TEXT="implementiert GUI-Plugin"/>
|
|
<node CREATED="1484797442686" ID="ID_83446606" MODIFIED="1557498707216" TEXT="launchUI -> erzeugt GUI-Thread"/>
|
|
</node>
|
|
<node CREATED="1484797483865" ID="ID_159090609" MODIFIED="1557498707216" TEXT="GuiThread (==runGUI())">
|
|
<node CREATED="1484797502462" ID="ID_21819368" MODIFIED="1557498707216" TEXT="erzeugt GtkLumiera"/>
|
|
<node CREATED="1484797512341" ID="ID_57994807" MODIFIED="1557498707216" TEXT="ruft darauf run()">
|
|
<node CREATED="1501854771820" FOLDED="true" ID="ID_1849270384" MODIFIED="1582493797614" TEXT="erzeugt UI-Backbone">
|
|
<arrowlink COLOR="#577ca7" DESTINATION="ID_1734603717" ENDARROW="Default" ENDINCLINATION="-18;-71;" ID="Arrow_ID_1972220174" STARTARROW="None" STARTINCLINATION="-130;2;"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1544238872425" HGAP="71" ID="ID_478753729" MODIFIED="1557498707216" TEXT="hier kann ein ungeschützter Fehler passieren" VSHIFT="-58">
|
|
<linktarget COLOR="#e02825" DESTINATION="ID_478753729" ENDARROW="Default" ENDINCLINATION="-3550;0;" ID="Arrow_ID_840138296" SOURCE="ID_1795051800" STARTARROW="None" STARTINCLINATION="-69;-346;"/>
|
|
<linktarget COLOR="#e02825" DESTINATION="ID_478753729" ENDARROW="Default" ENDINCLINATION="-3550;0;" ID="Arrow_ID_390741072" SOURCE="ID_138383314" STARTARROW="None" STARTINCLINATION="-1804;756;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544240822252" ID="ID_540724043" MODIFIED="1582493672224" TEXT="#1192 Lumiera hangs on failed GUI start">
|
|
<linktarget COLOR="#f12a42" DESTINATION="ID_540724043" ENDARROW="Default" ENDINCLINATION="-942;0;" ID="Arrow_ID_893876754" SOURCE="ID_14952077" STARTARROW="None" STARTINCLINATION="864;64;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1582493512018" ID="ID_1430216839" MODIFIED="1582493518909" TEXT="Problem definitiv noch nicht gelöst"/>
|
|
<node CREATED="1582493520113" ID="ID_598389416" MODIFIED="1582493535283" TEXT="betrifft auch Fehler im ctor vom UI-Bus und UiManager">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582493537671" ID="ID_1292210413" MODIFIED="1582493550078" TEXT="out of Memory!">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484797517052" ID="ID_840628023" MODIFIED="1557498707216" TEXT="löst das sigTerm aus"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484797531482" HGAP="104" ID="ID_1734603717" MODIFIED="1557498707216" TEXT="GtkLumiera::run()" VSHIFT="26">
|
|
<linktarget COLOR="#577ca7" DESTINATION="ID_1734603717" ENDARROW="Default" ENDINCLINATION="-18;-71;" ID="Arrow_ID_1972220174" SOURCE="ID_1849270384" STARTARROW="None" STARTINCLINATION="-130;2;"/>
|
|
<node CREATED="1484797543593" HGAP="-5" ID="ID_143907787" MODIFIED="1557498707216" TEXT="erzeugt UiBus" VSHIFT="-19">
|
|
<arrowlink COLOR="#74869a" DESTINATION="ID_1916035717" ENDARROW="Default" ENDINCLINATION="-84;2;" ID="Arrow_ID_355694260" STARTARROW="None" STARTINCLINATION="0;49;"/>
|
|
</node>
|
|
<node CREATED="1501855022131" ID="ID_1152163957" MODIFIED="1557498707216" TEXT="erzeugt UiManager">
|
|
<node CREATED="1501855161616" ID="ID_1916035717" MODIFIED="1557498707216" TEXT="verdrahtet mit UiBus">
|
|
<linktarget COLOR="#74869a" DESTINATION="ID_1916035717" ENDARROW="Default" ENDINCLINATION="-84;2;" ID="Arrow_ID_355694260" SOURCE="ID_143907787" STARTARROW="None" STARTINCLINATION="0;49;"/>
|
|
</node>
|
|
<node CREATED="1501855107127" FOLDED="true" ID="ID_135398487" MODIFIED="1561827483823" TEXT="erzeugt GlobalCtx">
|
|
<node CREATED="1501855278529" ID="ID_1800772710" MODIFIED="1518487921042" TEXT="UiBus&"/>
|
|
<node CREATED="1501855278529" ID="ID_146051630" MODIFIED="1518487921042" TEXT="UiManager&"/>
|
|
<node CREATED="1501855278529" ID="ID_217835618" MODIFIED="1518487921042" TEXT="WindowLocator"/>
|
|
<node CREATED="1501855278529" ID="ID_1549587580" MODIFIED="1518487921042" TEXT="InteractionDirector"/>
|
|
<node CREATED="1501855278529" ID="ID_1835031486" MODIFIED="1518487921042" TEXT="interact::Wizard"/>
|
|
</node>
|
|
<node CREATED="1501855218496" ID="ID_958941481" MODIFIED="1557498707216" TEXT="bindet Menü-Actions"/>
|
|
</node>
|
|
<node CREATED="1501855040016" ID="ID_1016475327" MODIFIED="1557498707216" TEXT="erstellt Hautpfenster"/>
|
|
<node CREATED="1501855050087" ID="ID_1167747758" MODIFIED="1557498707216" TEXT="startet Event-Loop">
|
|
<node CREATED="1501855083654" ID="ID_207237338" MODIFIED="1557498707216" TEXT="uiManager.performMainLoop()"/>
|
|
<node CREATED="1538264133989" FOLDED="true" ID="ID_310550142" MODIFIED="1561827483824" TEXT="installiert façade-Interfaces">
|
|
<node CREATED="1484797620495" ID="ID_1710248767" MODIFIED="1557498707216" TEXT="NotificationService"/>
|
|
<node CREATED="1538264160993" ID="ID_1729118785" MODIFIED="1557498707216" TEXT="DisplayService"/>
|
|
</node>
|
|
<node CREATED="1484797557383" ID="ID_637078214" MODIFIED="1557498707216" TEXT="Gtk-Kit::run()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484797573701" ID="ID_162958920" MODIFIED="1557498707216" TEXT="UiBus">
|
|
<node CREATED="1484797576972" ID="ID_1159570219" MODIFIED="1557498707216" TEXT="erzeugt CoreService">
|
|
<node CREATED="1484871312594" ID="ID_1351400025" MODIFIED="1557498707216" TEXT="erbt zwar von BusTerm"/>
|
|
<node CREATED="1484871321473" ID="ID_112216780" MODIFIED="1576282358161" TEXT="hat aber keine connection">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist: keine volle bidirektionale Connection,
|
|
</p>
|
|
<p>
|
|
denn CoreService ist kein Tangible. Das macht Sinn so, habe darüber nachgedacht.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Anmerkung: ein "frestehendes" BusTerm ist valide und zugelassen, es hat halt nur eine uplink-Connection.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484871556194" ID="ID_1978811406" MODIFIED="1576282358161" TEXT="macht Sinn so">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur ein Tangible kann downlink-Nachrichten sinnvoll empfangen;
|
|
</p>
|
|
<p>
|
|
es muß dazu auch jede Menge Methoden implementieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484797584483" FOLDED="true" ID="ID_1316050570" MODIFIED="1561827483824" TEXT="dieser hat Member ">
|
|
<node CREATED="1484797623574" ID="ID_1754670675" MODIFIED="1557498707216" TEXT="Nexus"/>
|
|
<node CREATED="1538264091954" ID="ID_1287413267" MODIFIED="1557498707216" TEXT="StateManager"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501857011825" FOLDED="true" ID="ID_1201296805" MODIFIED="1582493803650" TEXT="Synchronisation">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1501857019737" ID="ID_1981037750" MODIFIED="1557498707216" TEXT="GuiSubsysDescriptor">
|
|
<node CREATED="1501857031391" ID="ID_1576806105" MODIFIED="1557498707216" TEXT="start hält Lock">
|
|
<arrowlink COLOR="#31be34" DESTINATION="ID_1470293650" ENDARROW="Default" ENDINCLINATION="14;-46;" ID="Arrow_ID_681325673" STARTARROW="None" STARTINCLINATION="-84;0;"/>
|
|
</node>
|
|
<node CREATED="1501857073041" ID="ID_1936840706" MODIFIED="1557498707216" TEXT="erzeugt GuiRunner"/>
|
|
<node CREATED="1501857054324" ID="ID_907543967" MODIFIED="1557498707216" TEXT="reset facade-Pointer">
|
|
<linktarget COLOR="#4fa071" DESTINATION="ID_907543967" ENDARROW="Default" ENDINCLINATION="191;11;" ID="Arrow_ID_249160033" SOURCE="ID_1335129961" STARTARROW="None" STARTINCLINATION="134;-11;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501857081496" ID="ID_1470293650" MODIFIED="1557498707216" TEXT="GuiRunner-ctor">
|
|
<linktarget COLOR="#31be34" DESTINATION="ID_1470293650" ENDARROW="Default" ENDINCLINATION="14;-46;" ID="Arrow_ID_681325673" SOURCE="ID_1576806105" STARTARROW="None" STARTINCLINATION="-84;0;"/>
|
|
<node CREATED="1501857138848" ID="ID_1487509134" MODIFIED="1557498707216" TEXT="läd Gui-Plugin"/>
|
|
<node CREATED="1501857152263" ID="ID_521610150" MODIFIED="1557498707216" TEXT="triggert auf diesem launchUI"/>
|
|
</node>
|
|
<node CREATED="1501857292596" ID="ID_453282087" MODIFIED="1557498707216" TEXT="Gui-Plugin-launchUI">
|
|
<node CREATED="1501857310890" ID="ID_1249679018" MODIFIED="1557498707216" TEXT="erzeugt UI-Thread"/>
|
|
<node CREATED="1501857327592" ID="ID_1036948610" MODIFIED="1557498707216" TEXT="dieser bindet an runGUI"/>
|
|
</node>
|
|
<node CREATED="1501857358387" ID="ID_807727617" MODIFIED="1557498707216" TEXT="runGUI">
|
|
<node CREATED="1501857365394" ID="ID_509238853" MODIFIED="1557498707217" TEXT="erzeugt GtkLumiera"/>
|
|
<node CREATED="1501857382808" ID="ID_1737939783" MODIFIED="1557498707217" TEXT="ruft darauf run() auf"/>
|
|
<node COLOR="#3f9476" CREATED="1501857391335" ID="ID_1248703286" MODIFIED="1557498707217" TEXT="nicht weiter synchronisiert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1501857518526" ID="ID_837968815" MODIFIED="1557498707217" TEXT="Ende runGUI">
|
|
<node CREATED="1501857542075" ID="ID_767030758" MODIFIED="1557498707217" TEXT="aktiviert Term-Signal"/>
|
|
<node CREATED="1501857548922" ID="ID_1335129961" MODIFIED="1557498707217" TEXT="Lock auf GuiSubsysDescriptor">
|
|
<arrowlink COLOR="#4fa071" DESTINATION="ID_907543967" ENDARROW="Default" ENDINCLINATION="191;11;" ID="Arrow_ID_249160033" STARTARROW="None" STARTINCLINATION="134;-11;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501857640582" ID="ID_1028796039" MODIFIED="1557498707217" TEXT="nach dem Subsys-Start">
|
|
<node CREATED="1501857649532" ID="ID_1041981988" MODIFIED="1557498707217" TEXT="läuft der UI-Thread">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1501857657707" ID="ID_35727639" MODIFIED="1557498707217">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GtkLumiera <i>in Konstruktion</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1501857681920" ID="ID_473453255" MODIFIED="1557498707217">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
NotificationFacade <b>noch nicht offen</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1501857705277" ID="ID_1642619932" MODIFIED="1557498707217" TEXT="zuverlässig">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1501857709325" ID="ID_1889612043" MODIFIED="1557498707217" TEXT="entweder Start geht durch"/>
|
|
<node CREATED="1501857714988" ID="ID_158695659" MODIFIED="1557498707217" TEXT="oder scheitert und aktiviert Term-Signal"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501857864240" ID="ID_1721447002" MODIFIED="1557498707217" TEXT="UI-Bus">
|
|
<node CREATED="1501857867935" ID="ID_1896700254" MODIFIED="1557498707217" TEXT="Nexus vorhanden"/>
|
|
<node CREATED="1501857873711" ID="ID_1994626464" MODIFIED="1557498707217" TEXT="CoreService konstruiert"/>
|
|
<node CREATED="1501857903891" ID="ID_791583661" MODIFIED="1557498707217" TEXT="aber">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1501857907682" ID="ID_881624439" MODIFIED="1557498707217" TEXT="GTK_Loop muß (noch) nicht laufen"/>
|
|
<node CREATED="1501857924928" ID="ID_1224004206" MODIFIED="1557498707217" TEXT="InteractionDirector muß (noch) nicht connected sein"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501858109615" ID="ID_747885327" MODIFIED="1557498707217" TEXT="UI-Facaden">
|
|
<node COLOR="#435e98" CREATED="1501858114023" ID="ID_749414376" MODIFIED="1582487948670">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
müssen <b>eigens</b> aktiviert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5365b7" DESTINATION="ID_749414376" ENDARROW="Default" ENDINCLINATION="-480;-31;" ID="Arrow_ID_1567070366" SOURCE="ID_99706930" STARTARROW="None" STARTINCLINATION="295;-51;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1501859757091" ID="ID_1507399957" MODIFIED="1557498707217" TEXT="eigenen Callback schaffen"/>
|
|
<node CREATED="1501859763155" ID="ID_428809729" MODIFIED="1557498707217" TEXT="generische Komponente schaffen?"/>
|
|
<node CREATED="1538264423814" ID="ID_647239893" MODIFIED="1557498707217" TEXT="gelöst durch Instantiieren des Facade-RAII-Objektes"/>
|
|
</node>
|
|
<node CREATED="1501858134796" ID="ID_1622427478" MODIFIED="1557498707217" TEXT="nachdem die UI-Loop läuft">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1538264444419" ID="ID_1493499325" MODIFIED="1557498707217" TEXT="hier wechselseitige Abhängigkeit">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1538264482902" ID="ID_838939814" MODIFIED="1557498707217" TEXT="Instantiiiere gui::ctrl::Facade im Stack-Frame von UiManager::performMainLoop()"/>
|
|
<node CREATED="1538264545797" ID="ID_1760435858" MODIFIED="1576282358160" TEXT="Synchronisation qua Dispatch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwar sind die Fasaden offen, bevor die Main-Loop läuft,
|
|
</p>
|
|
<p>
|
|
jedoch werden genau durch diese Fasaden alle Aktionen per Dispatch
|
|
</p>
|
|
<p>
|
|
in die GTK-Loop übertragen. Und das kann nur <i>in der Loop selber</i>  passieren.
|
|
</p>
|
|
<p>
|
|
Ein zu früher bzw. zu später Aufruf <i>"fällt einfach hinten runter"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582493579819" ID="ID_387023352" MODIFIED="1582493593279" TEXT="Fazit: noch nicht ganz">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1582493598679" ID="ID_14952077" MODIFIED="1582493672224" TEXT="es gibt einen Race im Start-up (#1192)">
|
|
<arrowlink COLOR="#f12a42" DESTINATION="ID_540724043" ENDARROW="Default" ENDINCLINATION="-942;0;" ID="Arrow_ID_893876754" STARTARROW="None" STARTINCLINATION="864;64;"/>
|
|
</node>
|
|
<node CREATED="1582493675037" ID="ID_974783388" MODIFIED="1582493696790" TEXT="zusätzlich gibt es die Lücke mit der noch nicht geöffneten Facade">
|
|
<arrowlink COLOR="#d68361" DESTINATION="ID_590420902" ENDARROW="Default" ENDINCLINATION="314;0;" ID="Arrow_ID_1471960575" STARTARROW="None" STARTINCLINATION="109;5;"/>
|
|
<node COLOR="#ab7a47" CREATED="1617458903748" HGAP="36" ID="ID_603424020" MODIFIED="1617459170807" TEXT="unwahrscheinlich aber besteht weiterhin" VSHIFT="-1">
|
|
<edge COLOR="#b28c66"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582493784351" ID="ID_548491726" MODIFIED="1582493794113" TEXT="sonst ist die Synchronisation sauber">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582493698042" ID="ID_306435149" MODIFIED="1582493720146" TEXT="trotzdem vertagt; sollte Subsystem-Runner überarbeiten">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582493761032" ID="ID_117656877" LINK="https://issues.lumiera.org/ticket/1177" MODIFIED="1582493774585" TEXT=" #1177 Subsytem-Runner design rework ">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1617459426438" ID="ID_1892682204" MODIFIED="1617459482615">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verbleibende Probleme sind <i>"marginal"</i> und besser im Subsystem-Runner zu addressieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484871163902" ID="ID_274722396" MODIFIED="1557498707217" TEXT="closeGuiModule (PImpl) hat Lock">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484871188635" ID="ID_1922412139" MODIFIED="1557498707217" TEXT="Storage/Lebenzyklus des Term-Funktors (jetzt) OK">
|
|
<arrowlink COLOR="#68b4bb" DESTINATION="ID_375871642" ENDARROW="Default" ENDINCLINATION="-300;-60;" ID="Arrow_ID_896120556" STARTARROW="None" STARTINCLINATION="495;28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484793022924" HGAP="100" ID="ID_1019455888" MODIFIED="1557498707217" TEXT="neuer Facade-Kontext" VSHIFT="2">
|
|
<linktarget COLOR="#4072ad" DESTINATION="ID_1019455888" ENDARROW="Default" ENDINCLINATION="6;-96;" ID="Arrow_ID_693735378" SOURCE="ID_66499328" STARTARROW="None" STARTINCLINATION="-105;33;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1501866627055" ID="ID_1521184600" MODIFIED="1557498707217" TEXT="RAII-Stil"/>
|
|
<node CREATED="1501866591164" ID="ID_751026549" MODIFIED="1557498707217" TEXT="öffnet/schließt die öffentlichen Interfaces"/>
|
|
</node>
|
|
<node COLOR="#7a2f10" CREATED="1481502251450" FOLDED="true" HGAP="96" ID="ID_1125529151" MODIFIED="1557498707217" TEXT="möglicher Race" VSHIFT="14">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1484797174890" ID="ID_986391148" MODIFIED="1557498707217" TEXT="triggerShutdown() kommt bevor GuiNotification offen ist">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1484797210597" ID="ID_1555304752" MODIFIED="1557498707217" TEXT="ist das überhaupt ein Problem">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1484797230051" ID="ID_590420902" MODIFIED="1557498707217" TEXT="ja, weil dann das GUI weiterläuft">
|
|
<linktarget COLOR="#d68361" DESTINATION="ID_590420902" ENDARROW="Default" ENDINCLINATION="314;0;" ID="Arrow_ID_1471960575" SOURCE="ID_974783388" STARTARROW="None" STARTINCLINATION="109;5;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1501867017251" ID="ID_1980251688" MODIFIED="1557498707217" TEXT="...und der shutdown-Prozeß blockt"/>
|
|
</node>
|
|
<node CREATED="1481502257825" HGAP="24" ID="ID_232782099" MODIFIED="1576282358160" TEXT="Gefahr gering, aber gegeben" VSHIFT="11">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil unser Thread-Framework
|
|
</p>
|
|
<p>
|
|
tatsächlich <i>erzwingt,</i> daß der neue Thrad zu laufen beginnt, bevor die
|
|
</p>
|
|
<p>
|
|
startende Funktion zurückkehrt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Daher können wir zumindest annehmen, daß die ganze Initialisierung
|
|
</p>
|
|
<p>
|
|
bereits läuft, wenn die start()-Funktion mit true (Erfolg) zurückkommt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings ist <i>definitiv</i> ein Race gegeben, und wenn
|
|
</p>
|
|
<p>
|
|
direkt beim Starten anderer Subsysteme nach dem GUI etwas schiefläuft,
|
|
</p>
|
|
<p>
|
|
dann kann der Shutdown-Prozeß den Start des GUI überholen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1484797646771" HGAP="38" ID="ID_1605520996" MODIFIED="1557498707217" TEXT="Ausgestaltung" VSHIFT="20">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501859455212" FOLDED="true" ID="ID_751494565" MODIFIED="1557498707217" TEXT="Lebenszyklus">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#435e98" CREATED="1484797663121" FOLDED="true" ID="ID_134980216" MODIFIED="1557498707217" TEXT="braucht Bus-Connection">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1484797863862" ID="ID_464230340" MODIFIED="1561827464529" TEXT="zum Controller machen?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1484797872109" ID="ID_1877007933" MODIFIED="1518487921045" TEXT="Controller ist Tangible"/>
|
|
<node CREATED="1484797878364" ID="ID_93289471" MODIFIED="1518487921045" TEXT="hat damit automatisch BusTerm"/>
|
|
<node CREATED="1484799604429" ID="ID_1141687282" MODIFIED="1518487921045" TEXT="Design-Problem: sinnvolles Diff">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1484799625306" ID="ID_443020211" MODIFIED="1518487921045" TEXT="aus den Fingern saugen">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1484799634233" ID="ID_1600517820" MODIFIED="1518487921045" TEXT="nur implementation-reuse">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1484799675388" HGAP="29" ID="ID_228932182" MODIFIED="1518487921045" TEXT="Idee: Attribute?" VSHIFT="18">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484876010871" ID="ID_175784507" MODIFIED="1576282358159" TEXT="Design-Problem: restliches Tangible-Protokoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wirkt alles mehr oder weniger beliebig...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484875935505" ID="ID_1341415727" MODIFIED="1518487921046" TEXT="nein">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484875946312" ID="ID_271363232" MODIFIED="1561827464529" TEXT="ist ein BusTerm">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1484875959342" ID="ID_1202046492" MODIFIED="1538268186367" TEXT="nur unidirektional zum Bus verbunden">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1484875968557" ID="ID_1406569407" MODIFIED="1518487921046" TEXT="ist hier genau angemessen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484875972588" ID="ID_1887863793" MODIFIED="1518487921046" TEXT="damit kann der Service mit dem UI reden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484799525344" FOLDED="true" ID="ID_640788614" MODIFIED="1561827464533" TEXT="muß sauber vom Nexus disconnecten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#ff0000" CREATED="1484799538686" ID="ID_1136883698" MODIFIED="1518487921046" TEXT="tut es nicht">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1484799551220" ID="ID_496503271" MODIFIED="1576282358158" TEXT="Fehlermeldung + Segfault">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0000000937: ERR: core-service.hpp:111: worker_3: ~CoreService: Some UI components are still connected to the backbone.
|
|
</p>
|
|
<p>
|
|
Speicherzugriffsfehler
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node COLOR="#435e98" CREATED="1584932162467" ID="ID_813910229" MODIFIED="1584932190012" TEXT="inzwischen wohl geklärt">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584932093080" ID="ID_1234616959" MODIFIED="1584932222621" TEXT="es gibt aber noch einen ähnlichen Fehler....">
|
|
<arrowlink COLOR="#b183a2" DESTINATION="ID_535289114" ENDARROW="Default" ENDINCLINATION="-2880;0;" ID="Arrow_ID_1219325605" STARTARROW="None" STARTINCLINATION="1004;61;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484800480472" ID="ID_1441013524" MODIFIED="1576282358158" TEXT="Sanity-Check in CoreService anpassen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...muß diejenigen Bus-Verbindungen abziehen, die von Members dieser Klasse stammen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
CoreService selber
|
|
</li>
|
|
<li>
|
|
der NotificationService
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1484802745625" ID="ID_375871642" MODIFIED="1561827464537" TEXT="Heisenbug">
|
|
<linktarget COLOR="#68b4bb" DESTINATION="ID_375871642" ENDARROW="Default" ENDINCLINATION="-300;-60;" ID="Arrow_ID_896120556" SOURCE="ID_1922412139" STARTARROW="None" STARTINCLINATION="495;28;"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1484802752728" ID="ID_634426848" MODIFIED="1518487921046" TEXT="passiert beim Aufruf des TerminationHandle"/>
|
|
<node CREATED="1484802766966" ID="ID_370736554" MODIFIED="1518487921046">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ich per Value capture, dann gibts schon
|
|
</p>
|
|
<p>
|
|
beim Start des GUI einen SEGFAULT
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und noch schlimmer: im Debugger gibts keinen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#c80e33" CREATED="1484862058589" ID="ID_1640490030" MODIFIED="1533608413516" TEXT="Locking">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1484865203945" ID="ID_1990023724" MODIFIED="1518487921046" TEXT="Locking in der GuiFacade ist korrekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484865231878" ID="ID_1054093321" MODIFIED="1518487921046" TEXT="im Gui-Thread kein Locking notwendig"/>
|
|
<node CREATED="1484865243724" ID="ID_617730067" MODIFIED="1518487921046" TEXT="HA! das Lambda vom Threadstart">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484865278999" ID="ID_1656236909" MODIFIED="1533608413518" TEXT="aufgeklärt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1484865298093" ID="ID_1797078596" MODIFIED="1518487921046">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die <i>Closure</i> eines Lambdas hängt am Kontext
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484865316147" ID="ID_687373412" MODIFIED="1518487921047" TEXT="wenn ich den Thread mit Lambda starte..."/>
|
|
<node CREATED="1484865349366" ID="ID_652410738" MODIFIED="1518487921047" TEXT="betrifft den term-Functor intern"/>
|
|
<node CREATED="1484865513568" ID="ID_696204655" MODIFIED="1576282358157" TEXT="selbst wenn der Funktor selber per Value übergeben wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
konkret:
|
|
</p>
|
|
<p>
|
|
der Kontext ist hier nämlich ein anderes Lambda, das dem Aufruf des GUI-Plugins mitgegeben wurde.
|
|
</p>
|
|
<p>
|
|
Dagegen die alte Lösung erzeugte an dieser Stelle einen Bind-Ausdruck, und das war offenbar genug,
|
|
</p>
|
|
<p>
|
|
um nicht mehr von dem direkten Kontext abhängig zu sein, in dem der Thread gestartet wurde.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Denn dieser Kontext (auf dem Stack) ist natürlich lange schon weg, wenn der Thread
|
|
</p>
|
|
<p>
|
|
terminiert und dann tatsächlich den Fuktor aufrufen möchte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484800741349" ID="ID_1156360682" MODIFIED="1518487921047">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Debug: nur <b>ein</b> Element connected
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1484800781408" ID="ID_183164357" MODIFIED="1518487921047" TEXT="nämlich der NotificationService">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484875214137" ID="ID_977859942" MODIFIED="1518487921047" TEXT="nein: das ist genau OK">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484875222128" ID="ID_1133941591" MODIFIED="1518487921047" TEXT="CoreService ist nicht bidirektional angebunden">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1484876114521" ID="ID_1082250595" MODIFIED="1557498707217" TEXT="Protokoll zur Kommunikation">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#4e0099" CREATED="1484876122960" ID="ID_31825421" MODIFIED="1560688098496" STYLE="fork" TEXT="UI-Bus nur im GUI-Thread">
|
|
<arrowlink COLOR="#6c5f80" DESTINATION="ID_489078622" ENDARROW="Default" ENDINCLINATION="712;-47;" ID="Arrow_ID_485145709" STARTARROW="None" STARTINCLINATION="1538;-37;"/>
|
|
<linktarget COLOR="#b7748e" DESTINATION="ID_31825421" ENDARROW="Default" ENDINCLINATION="560;150;" ID="Arrow_ID_1434676575" SOURCE="ID_935689465" STARTARROW="Default" STARTINCLINATION="587;44;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484876143949" ID="ID_558559630" MODIFIED="1561827464538" TEXT="muß Nachrichten explizit übergeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1531583488816" ID="ID_928145965" MODIFIED="1531583491643" TEXT="Dispatcher"/>
|
|
<node CREATED="1531583492656" ID="ID_1195055295" MODIFIED="1531583502490" TEXT="Queue mit explizitem Mutex-Locking"/>
|
|
<node CREATED="1531583503318" ID="ID_40184396" MODIFIED="1531583517752" TEXT="UI-Thread signalisieren per Gtk::Dispatcher"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484876154492" ID="ID_669377427" MODIFIED="1557498707217" TEXT="an Locking denken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484797900185" ID="ID_1895372084" MODIFIED="1561827464539" TEXT="Protokoll zum Schließen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1484797920846" ID="ID_472054508" MODIFIED="1518487921047" TEXT="sollte Nachricht auf dem Bus sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1484797928661" ID="ID_256413655" MODIFIED="1518487921047" TEXT="sollte in das bestehende Protokoll passen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1501791850068" ID="ID_1334285372" MODIFIED="1518487921047" TEXT="paßt aber nicht wirklich">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1501791881175" ID="ID_361179647" MODIFIED="1518487921047" TEXT="jede Lösung willkürlich"/>
|
|
<node CREATED="1501791876032" ID="ID_381137803" MODIFIED="1576282358157" TEXT="logisch unsinnig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil die Abstraktion "UI-Element" eben grade
|
|
</p>
|
|
<p>
|
|
die UI-internen Framework-Aspekte ausklammert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Die Elemente stellen eine Abbildung der Strukturen aus der <i>Session</i> dar,
|
|
</p>
|
|
<p>
|
|
und ihre <i>"Methoden"</i> sind Commands auf der Session!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501859470962" ID="ID_99706930" MODIFIED="1557498707217">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß eigens <b>aktiviert</b> werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5365b7" DESTINATION="ID_749414376" ENDARROW="Default" ENDINCLINATION="-480;-31;" ID="Arrow_ID_1567070366" STARTARROW="None" STARTINCLINATION="295;-51;"/>
|
|
<node CREATED="1501859557934" ID="ID_764787705" MODIFIED="1557498707217" TEXT="nach Start der UI-Loop"/>
|
|
<node CREATED="1501859566837" ID="ID_984712012" MODIFIED="1557498707217" TEXT="Verbindung zum CoreCtx">
|
|
<arrowlink COLOR="#4f547b" DESTINATION="ID_36527267" ENDARROW="Default" ENDINCLINATION="-424;-2038;" ID="Arrow_ID_134552555" STARTARROW="None" STARTINCLINATION="2547;286;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484797808349" FOLDED="true" HGAP="31" ID="ID_389264738" MODIFIED="1561827464542" TEXT="Notification-Funktionen" VSHIFT="11">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1501854084264" HGAP="-42" ID="ID_1333991907" MODIFIED="1538263469663" TEXT="allgemein...." VSHIFT="-60">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1501854094710" ID="ID_1146157818" MODIFIED="1538263469663" TEXT="Synchronisation">
|
|
<arrowlink COLOR="#a75677" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="-317;-24;" ID="Arrow_ID_274836249" STARTARROW="None" STARTINCLINATION="-647;-66;"/>
|
|
</node>
|
|
<node CREATED="1501854114284" ID="ID_168912186" MODIFIED="1538263469663" TEXT="Lebenszyklus"/>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1502411488645" FOLDED="true" ID="ID_1875294174" MODIFIED="1561827464544" TEXT="Fehler im UI">
|
|
<linktarget COLOR="#84b6b7" DESTINATION="ID_1875294174" ENDARROW="Default" ENDINCLINATION="1297;-64;" ID="Arrow_ID_245240331" SOURCE="ID_1177399909" STARTARROW="None" STARTINCLINATION="285;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1502411559060" ID="ID_1282973269" MODIFIED="1538263469663" TEXT="GTK nicht exception-safe">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1502411571690" ID="ID_878676751" MODIFIED="1538263469663" TEXT="aber was tun wenn....">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1503444108091" ID="ID_725326352" MODIFIED="1538263469663" TEXT="loggen und weitermachen"/>
|
|
<node CREATED="1503444117593" ID="ID_1115027114" MODIFIED="1538263469663" TEXT="loggen, Fehlerlog-Widget, weitermachen">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1503444163706" ID="ID_577766875" MODIFIED="1538263469663" TEXT="UI-Reset"/>
|
|
<node CREATED="1503444173752" ID="ID_65458957" MODIFIED="1538263469663" TEXT="(emergency)-shutdown"/>
|
|
</node>
|
|
<node CREATED="1502411595263" ID="ID_58102462" MODIFIED="1538263469663" TEXT="Fallunterscheidung">
|
|
<node CREATED="1502411604054" ID="ID_1705249614" MODIFIED="1538263469663" TEXT="Fehler im Feedback/Notify harmlos">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1502411612700" ID="ID_1951009863" MODIFIED="1538263469663" TEXT="Diff darf nicht scheitern">
|
|
<node CREATED="1503670572980" ID="ID_599888416" MODIFIED="1538263469663" TEXT="einzige Ausnahme">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1503670585794" FOLDED="true" ID="ID_1806860698" MODIFIED="1561827483824" TEXT="speziellen Handler verwenden">
|
|
<arrowlink COLOR="#6d8097" DESTINATION="ID_376091136" ENDARROW="Default" ENDINCLINATION="129;8;" ID="Arrow_ID_206696117" STARTARROW="None" STARTINCLINATION="147;13;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504203543467" FOLDED="true" ID="ID_285166941" MODIFIED="1561827482903" TEXT="TODO">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1504203570199" ID="ID_577706469" MODIFIED="1518487921048" TEXT="welche Fehler kann Diff-Anwendung werfen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504203562616" ID="ID_1637738213" MODIFIED="1518487921048" TEXT="in generischen Diff-Aufruf einbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1503443968096" ID="ID_986919353" MODIFIED="1538263469663" TEXT="Implementierungs-Muster">
|
|
<node CREATED="1503443979619" ID="ID_1673104600" MODIFIED="1538263469663" TEXT="jedes einzelne Lambda in Fehlerhandler wrappen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1503443999616" ID="ID_601042478" MODIFIED="1538263469663" TEXT="generischer Fehlerhandler im Invocation-Lambda">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1503670528386" ID="ID_376091136" MODIFIED="1538263469663" TEXT="generischer Chain-Fehlerhandler">
|
|
<arrowlink COLOR="#5e6d7f" DESTINATION="ID_1933339677" ENDARROW="Default" ENDINCLINATION="201;-32;" ID="Arrow_ID_1887448672" STARTARROW="None" STARTINCLINATION="-44;52;"/>
|
|
<linktarget COLOR="#6d8097" DESTINATION="ID_376091136" ENDARROW="Default" ENDINCLINATION="129;8;" ID="Arrow_ID_206696117" SOURCE="ID_1806860698" STARTARROW="None" STARTINCLINATION="147;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484797813373" ID="ID_536855363" MODIFIED="1538840099146" TEXT="generische Nachricht">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484797818780" ID="ID_354397333" MODIFIED="1561827464545" TEXT="state mark">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1484877574046" ID="ID_251939815" MODIFIED="1538263469663" TEXT="Error">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484877577550" ID="ID_258243919" MODIFIED="1538263469663" TEXT="Note">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1504203488690" FOLDED="true" ID="ID_149796171" MODIFIED="1561827464547" TEXT="Fehlermeldungen">
|
|
<linktarget COLOR="#c19dc4" DESTINATION="ID_149796171" ENDARROW="Default" ENDINCLINATION="1300;76;" ID="Arrow_ID_451002492" SOURCE="ID_821848615" STARTARROW="None" STARTINCLINATION="1509;156;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1504203497529" ID="ID_1933339677" MODIFIED="1538839626771" TEXT="#1102 brauche Fehlerlog-Widget">
|
|
<linktarget COLOR="#5e6d7f" DESTINATION="ID_1933339677" ENDARROW="Default" ENDINCLINATION="201;-32;" ID="Arrow_ID_1887448672" SOURCE="ID_376091136" STARTARROW="None" STARTINCLINATION="-44;52;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504203643550" ID="ID_764647453" MODIFIED="1538263469663" TEXT="via InteractionDirector ansprechen"/>
|
|
<node CREATED="1504203694423" ID="ID_812129962" MODIFIED="1538263469663">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Fehlerlog-Anzeige <i>vorläufig irgendwo....</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7893b2" DESTINATION="ID_1745777873" ENDARROW="Default" ENDINCLINATION="-499;-464;" ID="Arrow_ID_1590510093" STARTARROW="None" STARTINCLINATION="808;0;"/>
|
|
</node>
|
|
<node CREATED="1533688453675" ID="ID_528918224" MODIFIED="1538263469663" TEXT="längerfristige Lösung">
|
|
<arrowlink COLOR="#9c95b1" DESTINATION="ID_1972484306" ENDARROW="Default" ENDINCLINATION="-3826;-1250;" ID="Arrow_ID_1735504887" STARTARROW="None" STARTINCLINATION="2269;1167;"/>
|
|
<node CREATED="1533688464386" ID="ID_1583348838" MODIFIED="1538263469663" TEXT="Wizard erzeugt NotificationController"/>
|
|
<node CREATED="1533688486631" ID="ID_1186891962" MODIFIED="1538263469664" TEXT="dieser alloziert bei Bedarf ein Anzeige-Widget"/>
|
|
<node CREATED="1533688504805" ID="ID_882148786" MODIFIED="1538263469664" TEXT="welches dann in das Infobox-Panel platziert wird"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1504203511199" ID="ID_1027795869" MODIFIED="1538263469664" TEXT="Nachricht per UI-Bus senden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484797822403" FOLDED="true" HGAP="37" ID="ID_364545191" MODIFIED="1582487884518" TEXT="Diff" VSHIFT="8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1502401930856" FOLDED="true" ID="ID_634125084" MODIFIED="1582487870878" TEXT="#1066 concept how to hand over diff messages">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1502410099141" ID="ID_1388523431" MODIFIED="1538263469664" TEXT="unnötig: zwei Abstraktions-Typen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1502410126058" ID="ID_30550435" MODIFIED="1538263469664" TEXT="MutationMessage"/>
|
|
<node CREATED="1502410130889" ID="ID_1402431306" MODIFIED="1538263469664" TEXT="DiffMessage"/>
|
|
</node>
|
|
<node CREATED="1502410149463" ID="ID_1909971032" MODIFIED="1538263469664" TEXT="Entscheidung für DiffMessage">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1502599977964" ID="ID_249258988" MODIFIED="1538263469664" TEXT="ist das bessere Konzept"/>
|
|
<node CREATED="1502599993338" ID="ID_1306432135" MODIFIED="1538263469664" TEXT="abstrahierter Iterator">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1502600004168" ID="ID_1865027243" MODIFIED="1538263469664" TEXT="aber Name »MutationMessage« beibehalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502410165980" ID="ID_1450795292" MODIFIED="1538263469664" TEXT="MutationMessage entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502410176619" ID="ID_1188430411" MODIFIED="1538263469664" TEXT="AbstractTangible_test umschreiben"/>
|
|
<node CREATED="1502410190737" ID="ID_1036564813" MODIFIED="1576282358156" TEXT="operator string() in DiffMessage übernehmen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist nützlich zur Diagnose,
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
aber läßt sich das überhaupt auf IterSource übertragen?
|
|
</li>
|
|
<li>
|
|
war es überhaupt je gerechtferigt? zu starke Annahme über den Diff-Erzeuger!
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1502410328279" ID="ID_1577461232" MODIFIED="1538263469664" TEXT="Tree-Diff-Aplikator direkt in Nexus verschieben"/>
|
|
<node CREATED="1502410351284" ID="ID_845679527" MODIFIED="1538263469664" TEXT="BusTerm-API ändern"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484799660822" ID="ID_1288003894" MODIFIED="1538263469664" TEXT="TreeMutator binden">
|
|
<node CREATED="1502410730274" ID="ID_1631270974" MODIFIED="1538263469664" TEXT="passiert bisher in MutationMessage"/>
|
|
<node CREATED="1502410738992" ID="ID_1626925051" MODIFIED="1538263469664" TEXT="direkt in den Nexus verschieben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484877585605" ID="ID_101718446" MODIFIED="1538263469664" TEXT="verwende MutationMessage">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1502401956093" ID="ID_322700967" MODIFIED="1538263469664" TEXT="MutationMessage von DiffMessage erzeugen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1502454601603" ID="ID_384770680" MODIFIED="1538263469664" TEXT="nein: MutationMessage wird überflüssig">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1502401987033" ID="ID_1584846573" MODIFIED="1564495786621" TEXT="erfordert Festlegung der Natur der Diff Message">
|
|
<arrowlink COLOR="#bdbad3" DESTINATION="ID_89098030" ENDARROW="Default" ENDINCLINATION="600;-1189;" ID="Arrow_ID_554743885" STARTARROW="None" STARTINCLINATION="1459;870;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1502402004383" ID="ID_1491065212" MODIFIED="1538263469664" TEXT="generisch bleiben?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1502402012558" ID="ID_1846096533" MODIFIED="1538263469664" TEXT="IterSource verwenden">
|
|
<linktarget COLOR="#2579a2" DESTINATION="ID_1846096533" ENDARROW="Default" ENDINCLINATION="-5;149;" ID="Arrow_ID_896931950" SOURCE="ID_636092614" STARTARROW="None" STARTINCLINATION="158;5;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1502402691844" FOLDED="true" ID="ID_286774751" MODIFIED="1561827483824" TEXT="Diskussion">
|
|
<node CREATED="1502402022580" FOLDED="true" ID="ID_1661331763" MODIFIED="1561827482905" TEXT="Pro">
|
|
<node CREATED="1502402025820" ID="ID_1076820802" MODIFIED="1518487921050" TEXT="bestehende Framework"/>
|
|
<node CREATED="1502402031275" ID="ID_104571481" MODIFIED="1518487921050" TEXT="ownership management"/>
|
|
<node CREATED="1502402038690" ID="ID_921191865" MODIFIED="1518487921050" TEXT="schlankes Interface"/>
|
|
<node CREATED="1502402049305" ID="ID_20073652" MODIFIED="1518487921050" TEXT="eigentliche Diff-Erzeugung bleibt offen"/>
|
|
</node>
|
|
<node CREATED="1502402071222" FOLDED="true" ID="ID_905919540" MODIFIED="1561827482906" TEXT="Con">
|
|
<node CREATED="1502402075413" ID="ID_913770531" MODIFIED="1518487921050" TEXT="Komplexität"/>
|
|
<node CREATED="1502402086268" FOLDED="true" ID="ID_380041258" MODIFIED="1561827469144" TEXT="zusätzliche Indirektion">
|
|
<node CREATED="1502402254582" ID="ID_218820320" MODIFIED="1518487921050" TEXT="DiffMutable beim Empfänger"/>
|
|
<node CREATED="1502402499053" ID="ID_587801464" MODIFIED="1518487921050" TEXT="TreeMutator beim Empfänger"/>
|
|
<node CREATED="1502402266284" ID="ID_1573858698" MODIFIED="1518487921050" TEXT="IterSource<DiffStep> beim Generator"/>
|
|
<node CREATED="1502402516275" ID="ID_334129744" MODIFIED="1518487921050">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist schon <i>schlimm </i>genug....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502402213139" FOLDED="true" ID="ID_1233670694" MODIFIED="1561827469144" TEXT="nicht C-kompatibel">
|
|
<node CREATED="1502402286425" ID="ID_683015958" MODIFIED="1518487921051" TEXT="ja mei...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1502402291209" ID="ID_1962599608" MODIFIED="1518487921051" TEXT="aber könnte SWIG-kompatibel sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn eigentlich geht es nur um ein einfaches Producer-Interface,
|
|
</p>
|
|
<p>
|
|
das einen Element-Pointer durchreicht. Das einzige Problem, das ich sehe,
|
|
</p>
|
|
<p>
|
|
ist, daß hier <i>ownership </i>übertragen wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502402370534" ID="ID_1923477219" MODIFIED="1518487921051" TEXT="es geht hier um C++ (Proc) <-> C++ (GUI)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502402701106" FOLDED="true" ID="ID_510901772" MODIFIED="1561827483824" TEXT="Abwägung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1502402718496" ID="ID_1641881714" MODIFIED="1518487921051" TEXT="mir gefällt die Lösung zum ownerhsip management"/>
|
|
<node CREATED="1502402735558" ID="ID_1883129099" MODIFIED="1518487921051" TEXT="halte das für eine gute Implementierungs-Struktur..."/>
|
|
<node CREATED="1502402757163" ID="ID_1525377159" MODIFIED="1518487921051" TEXT="denn der Client ist quasi gezwungen, den Erzeugungs-Kontext herauszuabstrahieren"/>
|
|
<node CREATED="1502402778960" FOLDED="true" ID="ID_577811618" MODIFIED="1561827482906" TEXT="Indirektion/Komplexität">
|
|
<node CREATED="1502402798909" ID="ID_813337624" MODIFIED="1518487921051" TEXT="zählt nicht wirklich, denn.."/>
|
|
<node CREATED="1502402810620" ID="ID_439896117" MODIFIED="1518487921051" TEXT="mit dem Diff-Konzept habe ich das bereits akzeptiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
ein sehr theoretisches und anspruchsvolles Konzept
|
|
</li>
|
|
<li>
|
|
der Zwang, das auf jedem Empfänger umzusetzen
|
|
</li>
|
|
<li>
|
|
die hablseidene Trickserei mit der konkreten Puffergröße
|
|
</li>
|
|
<li>
|
|
den double-dispatch im Diff-Framework selber
|
|
</li>
|
|
<li>
|
|
das Variant-basierte GenNode-Framework
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502402998859" ID="ID_1462873166" MODIFIED="1518487921051">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das wird <i>sowiso</i> ein Desaster
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502402830713" ID="ID_1666981219" MODIFIED="1518487921051" TEXT="was zählt, ist die Entkoppelung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502403145431" ID="ID_636092614" MODIFIED="1538263469664" TEXT="DiffMessage ist selber der Iterator">
|
|
<arrowlink COLOR="#2579a2" DESTINATION="ID_1846096533" ENDARROW="Default" ENDINCLINATION="-5;149;" ID="Arrow_ID_896931950" STARTARROW="None" STARTINCLINATION="158;5;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1484877658891" ID="ID_1855662071" MODIFIED="1538263469664" TEXT="Vorsicht: Storage / GUI-Thread">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1484877696486" ID="ID_476867583" MODIFIED="1538263469664" TEXT="wir müssen jede Aktion in den Event-Thread übergeben"/>
|
|
<node CREATED="1484877711388" ID="ID_407918505" MODIFIED="1538263469664">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, die Diff-<b>Implementierung</b> muß länger leben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484877731337" ID="ID_1859059266" MODIFIED="1538263469664">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
faktisch erfolgt somit ein <b>Callback</b> aus einem anderen Thread
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1484877743992" ID="ID_680582075" MODIFIED="1538263469664">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
um das Diff zu <i>pullen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502459141531" ID="ID_301431029" MODIFIED="1538263469665" TEXT="Refactoring">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502459182214" ID="ID_1601884743" MODIFIED="1538263469665" TEXT="MutationMessage wird überflüssig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1502459190477" ID="ID_102437369" MODIFIED="1538263469665" TEXT="DiffMessage übernimmt deren Rolle">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502459198611" ID="ID_1739527989" MODIFIED="1538263469665" TEXT="aber DiffMessage wird umbenannt in MutationMessage">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1493753249399" HGAP="64" ID="ID_1023343635" MODIFIED="1561827464564" TEXT="#1098 hand-over in UI-Thread" VSHIFT="83">
|
|
<linktarget COLOR="#a75677" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="-317;-24;" ID="Arrow_ID_274836249" SOURCE="ID_1146157818" STARTARROW="None" STARTINCLINATION="-647;-66;"/>
|
|
<linktarget COLOR="#84c6b8" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="21;233;" ID="Arrow_ID_1372135725" SOURCE="ID_995145542" STARTARROW="None" STARTINCLINATION="237;0;"/>
|
|
<linktarget COLOR="#7caaa8" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="2513;3565;" ID="Arrow_ID_1832047032" SOURCE="ID_489078622" STARTARROW="Default" STARTINCLINATION="2914;51;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501804992301" ID="ID_1647263044" MODIFIED="1538263469665" TEXT="schedule event"/>
|
|
<node CREATED="1501804985286" ID="ID_320977714" MODIFIED="1538263469665" TEXT="GTK-Mechanismus">
|
|
<node CREATED="1501850591393" ID="ID_1831316800" MODIFIED="1538263469665" TEXT="Glib::Dispatcher"/>
|
|
<node CREATED="1501850603736" ID="ID_1030340631" MODIFIED="1538263469665" TEXT="im UI-Thread erzeugen und binden"/>
|
|
<node CREATED="1501850614630" ID="ID_196299293" MODIFIED="1538263469665" TEXT="emit() -> event im UI-Thread"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1501850632636" FOLDED="true" ID="ID_431682708" MODIFIED="1561827464567" TEXT="technische Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1501850684373" ID="ID_1688212376" MODIFIED="1576282358156" TEXT="ein Dispatcher pro Call">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
jede Facade-Funktion brauch einen Dispatcher
|
|
</p>
|
|
<p>
|
|
Das wird eine ganze Me
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1501850754827" ID="ID_314216229" MODIFIED="1538263469665" TEXT="jede Facade-Funktion brauch einen Dispatcher">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1501850863525" ID="ID_1439490807" MODIFIED="1538263469665" TEXT="das wird eine Menge"/>
|
|
<node CREATED="1501850867597" ID="ID_141225152" MODIFIED="1538263469665" TEXT="alle Dispatcher haben eine gemeinsame Queue"/>
|
|
<node CREATED="1501850880179" ID="ID_745997733" MODIFIED="1538263469665" TEXT="mögliche contention-Probleme"/>
|
|
</node>
|
|
<node CREATED="1501850690748" ID="ID_1995715844" MODIFIED="1538263469665" TEXT="Erzeugen der Dispatcher">
|
|
<node CREATED="1501850920950" ID="ID_1529426036" MODIFIED="1538263469665" TEXT="muß im UI-Thread erfolgen"/>
|
|
<node CREATED="1501850933596" ID="ID_620574396" MODIFIED="1538263469665">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>bevor</i> die Facade geöffnet wir
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501850677790" ID="ID_1195250454" MODIFIED="1538263469665" TEXT="Argumentübergabe">
|
|
<node CREATED="1501850716049" ID="ID_104637334" MODIFIED="1538263469665" TEXT="emit() ist void(void)"/>
|
|
<node CREATED="1501850734414" ID="ID_994424125" MODIFIED="1538263469665">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und arbeitet <i>asynchron</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1501850967855" ID="ID_859055846" MODIFIED="1538263469665">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Argument-Storage
|
|
</p>
|
|
<p>
|
|
organisieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1501867225983" FOLDED="true" ID="ID_1121867075" MODIFIED="1538263469665">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauche dedizierten <b>Dispatcher</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1501938738836" ID="ID_1257499857" MODIFIED="1561827464568" TEXT="Helper: CallQueue">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501938715247" ID="ID_1286525769" MODIFIED="1538263469666" TEXT="simplistic">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1501938699841" ID="ID_1077640328" MODIFIED="1538263469666" TEXT="std::function"/>
|
|
<node CREATED="1501938690626" ID="ID_353231581" MODIFIED="1538263469666" TEXT="thread safe queue"/>
|
|
<node CREATED="1501938705321" ID="ID_1924064403" MODIFIED="1538263469666" TEXT="lambdas für Argument-binding"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501938776839" ID="ID_1031878628" MODIFIED="1561827464569" TEXT="Convenience-Wrapper">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501939110138" ID="ID_203135379" MODIFIED="1538263469666" TEXT="Lambda konstruieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1501939132431" ID="ID_1400757157" MODIFIED="1538263469666" TEXT="Funktion zum Triggern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1501939149837" ID="ID_1733976265" MODIFIED="1538263469666" TEXT="diese an Glib::Dispatcher binden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1502404797300" ID="ID_1177399909" MODIFIED="1561827464570" TEXT="Exceptions fangen">
|
|
<arrowlink COLOR="#84b6b7" DESTINATION="ID_1875294174" ENDARROW="Default" ENDINCLINATION="1297;-64;" ID="Arrow_ID_245240331" STARTARROW="None" STARTINCLINATION="285;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1522935881957" HGAP="23" ID="ID_564244010" MODIFIED="1576282358155" TEXT="4/2018 was ist hier der Stand?" VSHIFT="16">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann mich so vague erinnern
|
|
</p>
|
|
<p>
|
|
daß hier zwar schon ein catch eingebaut war,
|
|
</p>
|
|
<p>
|
|
aber noch <i>irgend ein Hund</i> begraben liegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1531584775498" ID="ID_1901801971" MODIFIED="1576282358155" TEXT="7/2018 notification-Display fehlt noch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und insofern ist auch die Behandlung einer <b>Folge-Exception</b> noch offen
|
|
</p>
|
|
<p>
|
|
Im Moment loggen wir nur ins textuelle Konsole-Log (NoBug)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#22ed6f" DESTINATION="ID_1901801971" ENDARROW="Default" ENDINCLINATION="287;0;" ID="Arrow_ID_1609281182" SOURCE="ID_1545300987" STARTARROW="None" STARTINCLINATION="83;-25;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538263118645" ID="ID_944384957" MODIFIED="1576282358154" TEXT="9/2018 hinreichend behandelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Habe nochmal alle Aufrufe im Einzelnen durchgeprüft
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wenn schon das Einfügen des Funktors vor dem Dispatch wirft (out of memory),<br />dann bekommt der Aufrufer diese Exception, was typischerweise tödlich ist.<br />
|
|
</li>
|
|
<li>
|
|
aber alles, was <i>innerhalb</i> dieses Funktors passiert, wird abgefangen und geloggt.<br />
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
mehr erscheint mir nicht sinnvoll; <i>behandeln</i> kann man solche Fehler ohnehin nicht.<br /><br />
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501939174506" ID="ID_504999068" MODIFIED="1561827464571" TEXT="in NotificationService integrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502375098210" ID="ID_581509556" MODIFIED="1538263469666" STYLE="fork" TEXT="als PImpl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1502375146395" ID="ID_144811928" MODIFIED="1538263469666" TEXT="CallQueue einrichten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1502375120551" ID="ID_1281399419" MODIFIED="1538263469666" TEXT="Glib::Dispatcher verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1502375134501" ID="ID_1011463592" MODIFIED="1538263469666" STYLE="fork" TEXT="Aufrufe in Lamdas verpacken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502375294344" ID="ID_640199096" MODIFIED="1561827464572" TEXT="Spezialbehandlung für Shutdown">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502375312469" ID="ID_1075926054" MODIFIED="1576282358153" TEXT="ironischerweise...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...könnte das am Ende nicht sinnvoll sein,
|
|
</p>
|
|
<p>
|
|
speziell den UI-Shutdown-Trigger über den neuen Mechanismus laufen zu lassen,
|
|
</p>
|
|
<p>
|
|
obwohl jener doch genau der Anlaß war, diesen neuen Mechanismus zu bauen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502390322659" ID="ID_194166182" MODIFIED="1538263469666" TEXT="den neuen Dispatcher nutzen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1502390340193" FOLDED="true" ID="ID_1491902996" MODIFIED="1561827483824" TEXT="Con">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1502390353887" ID="ID_1015749080" MODIFIED="1518487921054">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn die Queue voll ist
|
|
</p>
|
|
<p>
|
|
wird erst alles Andere abgearbeitet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502390402273" ID="ID_929098721" MODIFIED="1518487921054">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn UI-Thread blockt/verhungert,
|
|
</p>
|
|
<p>
|
|
kommt der rettende Shutdown <i>gar nicht</i> durch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502390334890" FOLDED="true" ID="ID_1454460947" MODIFIED="1561827483824" TEXT="Pro">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502390463664" ID="ID_1786963429" MODIFIED="1518487921054" TEXT="einfach zu implementieren"/>
|
|
<node CREATED="1502390473567" ID="ID_1776620772" MODIFIED="1518487921054" TEXT="alle Glib::Dispatcher nutzen die gleiche Pipe"/>
|
|
<node CREATED="1502390485294" ID="ID_146294589" MODIFIED="1518487921054" TEXT="...d.h. echte Alternative müßte aufwendig zu Fuß programmiert werden"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502390572106" ID="ID_1872668444" MODIFIED="1679362063151" TEXT="zusätzlich noch eine Benachrichtigung">
|
|
<node CREATED="1502390583289" ID="ID_741614829" MODIFIED="1538263469666" TEXT="an die UI-Nachrichtenbox">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1502390886681" ID="ID_985994192" MODIFIED="1538263469666" TEXT="führe Benachrichtiguns-Level ein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502390603674" ID="ID_125356908" MODIFIED="1538839473841" TEXT="#1102 : build a message display box in the UI">
|
|
<arrowlink COLOR="#8c8bae" DESTINATION="ID_1926586811" ENDARROW="Default" ENDINCLINATION="1539;60;" ID="Arrow_ID_1593124756" STARTARROW="None" STARTINCLINATION="-850;779;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501939193031" HGAP="3" ID="ID_1045913810" MODIFIED="1679362063151" TEXT="Test" VSHIFT="20">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1501939204166" ID="ID_383444966" MODIFIED="1679362063151" TEXT="CallQueue_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1501946847700" ID="ID_1917302142" MODIFIED="1538263469666" TEXT="basic">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501946852555" ID="ID_1617455971" MODIFIED="1538263469666" TEXT="mehrere">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501946856587" ID="ID_1780067399" MODIFIED="1538263469666" TEXT="Streß">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1501939212693" ID="ID_1007296291" MODIFIED="1679362063151" TEXT="#1099 DemoGuiRoundtrip">
|
|
<linktarget COLOR="#e5e53f" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="-931;34;" ID="Arrow_ID_1440938291" SOURCE="ID_1925240675" STARTARROW="None" STARTINCLINATION="-7;605;"/>
|
|
<linktarget COLOR="#f0eca5" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="881;2029;" ID="Arrow_ID_1736540527" SOURCE="ID_1456159316" STARTARROW="None" STARTINCLINATION="765;-14;"/>
|
|
<linktarget COLOR="#ebf0a5" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="-3154;1704;" ID="Arrow_ID_1091720734" SOURCE="ID_1098045534" STARTARROW="None" STARTINCLINATION="1220;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1501939235834" FOLDED="true" ID="ID_1160414548" MODIFIED="1561827483824" TEXT="Menü-Eintrag">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533402935579" ID="ID_263665767" MODIFIED="1533402958273" TEXT="erst mal Bang!-Button verwenden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1533402947233" ID="ID_1533593555" MODIFIED="1533402955562" TEXT="alles fest drahten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501939240217" ID="ID_325602880" MODIFIED="1538263469667" TEXT="triggert Proc-Command"/>
|
|
<node CREATED="1501939252991" ID="ID_31140909" MODIFIED="1538263469667" TEXT="dieses sendet Mark zurück"/>
|
|
<node CREATED="1501939263030" FOLDED="true" ID="ID_381890207" MODIFIED="1561827483824" TEXT="ein Widget im UI reagiert">
|
|
<node COLOR="#338800" CREATED="1533402866549" FOLDED="true" ID="ID_899369632" MODIFIED="1561827482906" TEXT="fest verdrahtete ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533688905326" ID="ID_709974587" MODIFIED="1538263469667" TEXT="gehört dem NotificationController"/>
|
|
<node CREATED="1533688913996" ID="ID_33570780" MODIFIED="1538263469667">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>das</i> ist schon die endgültige Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1533688935962" FOLDED="true" ID="ID_1996006263" MODIFIED="1561827469144" TEXT="NotificationController">
|
|
<node CREATED="1533688944816" ID="ID_1273458647" MODIFIED="1538263469667" TEXT="wird vom Wizard gemanagt"/>
|
|
<node CREATED="1533688953399" ID="ID_1850034653" MODIFIED="1538263469667" TEXT="belegt ein Display-widget">
|
|
<arrowlink COLOR="#455086" DESTINATION="ID_396920290" ENDARROW="Default" ENDINCLINATION="-38;-97;" ID="Arrow_ID_729082861" STARTARROW="None" STARTINCLINATION="101;-7;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533771813324" FOLDED="true" ID="ID_930319427" MODIFIED="1561827469144" TEXT="wo ist die ID selber definiert">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1533911116328" ID="ID_1079600246" MODIFIED="1533911128764" TEXT="sie muß insgesamt reprouzierbar sein"/>
|
|
<node CREATED="1533911129424" ID="ID_659618402" MODIFIED="1533911139946" TEXT="zumindest innerhalb einer Program-Ausführung"/>
|
|
<node CREATED="1533911854871" FOLDED="true" HGAP="23" ID="ID_1953310668" MODIFIED="1561827469123" TEXT="Problem dabei" VSHIFT="11">
|
|
<node CREATED="1533911897569" ID="ID_1876551933" MODIFIED="1533911919154" TEXT="ID ist somit Teil des Interface"/>
|
|
<node CREATED="1533911919814" FOLDED="true" ID="ID_558535868" MODIFIED="1561827464588" TEXT="welches Interface?">
|
|
<node CREATED="1533915325903" FOLDED="true" ID="ID_1053391149" MODIFIED="1561827464588" TEXT="GuiNotification">
|
|
<node CREATED="1533915683535" ID="ID_1976057171" MODIFIED="1533915688561" TEXT="wäre möglich"/>
|
|
<node CREATED="1533915689317" ID="ID_689429680" MODIFIED="1533915696616" TEXT="hat aber anderen Scope"/>
|
|
</node>
|
|
<node CREATED="1533915336757" ID="ID_1674509000" MODIFIED="1533915653847" TEXT="NotificationService">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1533915549928" FOLDED="true" ID="ID_1316198257" MODIFIED="1561827464588" TEXT="ErrorLogView">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1533915663705" ID="ID_1407115037" MODIFIED="1533915670027" TEXT="ist Implementation"/>
|
|
</node>
|
|
<node CREATED="1533915555871" FOLDED="true" ID="ID_1144697657" MODIFIED="1561827464588" TEXT="ErrorLog">
|
|
<node CREATED="1533915560942" ID="ID_981931913" MODIFIED="1533915564473" TEXT="würde passen"/>
|
|
<node CREATED="1533915565111" ID="ID_779138620" MODIFIED="1533915568721" TEXT="gibts aber noch nicht"/>
|
|
<node CREATED="1533915569453" ID="ID_208285264" MODIFIED="1533915574145" TEXT="hat sonst keinen Inhalt"/>
|
|
</node>
|
|
<node CREATED="1533915576132" FOLDED="true" ID="ID_1784095931" MODIFIED="1561827464588" TEXT="Wizzard">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1533915588283" ID="ID_909934131" MODIFIED="1533915603577">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Schlußfolgerung: Wizzard <i>wird</i> ein Interface
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533911886268" FOLDED="true" ID="ID_1414379746" MODIFIED="1561827464588" TEXT="ID storage">
|
|
<node CREATED="1534026768353" ID="ID_38337485" MODIFIED="1534026773780" TEXT="statisch extern"/>
|
|
<node CREATED="1534026775080" ID="ID_875112330" MODIFIED="1534026808983">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in proc::asset::meta::<b><font color="#c01a1a">theErrorLog_ID</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534026821186" FOLDED="true" ID="ID_1959407299" MODIFIED="1561827464588" TEXT="dieses Interface fühlt sich irgendwie falsch an">
|
|
<linktarget COLOR="#c23581" DESTINATION="ID_1959407299" ENDARROW="Default" ENDINCLINATION="-34;0;" ID="Arrow_ID_1588328372" SOURCE="ID_1198718862" STARTARROW="Default" STARTINCLINATION="10;-26;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1534026923108" ID="ID_1896057034" MODIFIED="1534026932095" TEXT="Wizzard hat jetzt eine statische Methode"/>
|
|
<node CREATED="1534026932891" ID="ID_1643129041" MODIFIED="1534026942685" TEXT="NotificationService muß die ansprechen"/>
|
|
<node CREATED="1534026943481" ID="ID_445720698" MODIFIED="1534026954859" TEXT="bloß um eine "hinten herum" vereinbarte ID zu bekommen"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533916387142" FOLDED="true" HGAP="-78" ID="ID_1746348489" MODIFIED="1561827469123" TEXT="Festlegung" VSHIFT="-6">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533916393797" ID="ID_1198718862" MODIFIED="1534026961333" TEXT="Wizzard">
|
|
<arrowlink COLOR="#c23581" DESTINATION="ID_1959407299" ENDARROW="Default" ENDINCLINATION="-34;0;" ID="Arrow_ID_1588328372" STARTARROW="Default" STARTINCLINATION="10;-26;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1533916397565" FOLDED="true" ID="ID_1117749960" MODIFIED="1561827464588" TEXT="ErrorLog">
|
|
<arrowlink COLOR="#68788a" DESTINATION="ID_1121251191" ENDARROW="Default" ENDINCLINATION="-1644;0;" ID="Arrow_ID_146013003" STARTARROW="None" STARTINCLINATION="-4766;280;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1533916469971" ID="ID_802623301" MODIFIED="1533916472319" TEXT="in Proc"/>
|
|
<node CREATED="1533916473075" ID="ID_766768160" MODIFIED="1533916479190" TEXT="neu zu schaffen"/>
|
|
<node CREATED="1533916480282" ID="ID_1974491793" MODIFIED="1533916483670" TEXT="Platzhalter"/>
|
|
<node CREATED="1533916484785" ID="ID_537026197" MODIFIED="1533916497105" TEXT="(vorerst)">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504200793444" FOLDED="true" ID="ID_340215113" MODIFIED="1561827482907" TEXT="mißbrauche InfoBox">
|
|
<arrowlink COLOR="#f5dd67" DESTINATION="ID_19179662" ENDARROW="Default" ENDINCLINATION="743;-1563;" ID="Arrow_ID_1195014928" STARTARROW="None" STARTINCLINATION="-452;605;"/>
|
|
<linktarget COLOR="#e0d18d" DESTINATION="ID_340215113" ENDARROW="Default" ENDINCLINATION="-389;5426;" ID="Arrow_ID_1440864098" SOURCE="ID_622217667" STARTARROW="None" STARTINCLINATION="-1637;-8191;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1504200974955" FOLDED="true" ID="ID_1182589184" MODIFIED="1561827469145" TEXT="neues Dock(Panel)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522936169270" FOLDED="true" ID="ID_1991244597" MODIFIED="1561827469123" TEXT="vorläufig eingehängt...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...in den eigentlich kaputten DockManager
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533688853229" ID="ID_396920290" MODIFIED="1534508612332" TEXT="der NotificationHub (Controller) im Wizard erzeugt es">
|
|
<linktarget COLOR="#455086" DESTINATION="ID_396920290" ENDARROW="Default" ENDINCLINATION="-38;-97;" ID="Arrow_ID_729082861" SOURCE="ID_1850034653" STARTARROW="None" STARTINCLINATION="101;-7;"/>
|
|
</node>
|
|
<node CREATED="1533688860812" ID="ID_1631735052" MODIFIED="1533688874622" TEXT="direkt im aktiven WorkspaceWindow -> PanelManager"/>
|
|
<node CREATED="1533688875242" ID="ID_708108999" MODIFIED="1533688887596" TEXT="solange bis Panel-Management umgebaut wird">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1534513356842" FOLDED="true" HGAP="34" ID="ID_1371608668" MODIFIED="1561827469123" TEXT="Begriffe klären...">
|
|
<arrowlink COLOR="#8a9dae" DESTINATION="ID_1031484560" ENDARROW="Default" ENDINCLINATION="1135;-5718;" ID="Arrow_ID_1369217030" STARTARROW="None" STARTINCLINATION="1238;-672;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534513604257" ID="ID_724835920" MODIFIED="1534513612859" TEXT="Dock == DockArea"/>
|
|
<node CREATED="1534513617543" ID="ID_1874506167" MODIFIED="1534513631737" TEXT="DockItem == Panel"/>
|
|
</node>
|
|
<node CREATED="1533607995396" FOLDED="true" ID="ID_806494084" MODIFIED="1561827469123" TEXT="wieder das Problem: wie bekommt man's">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533608171186" ID="ID_1446703192" MODIFIED="1533608449611" TEXT="#1104 how to instruct actions through panels">
|
|
<arrowlink COLOR="#9e99b7" DESTINATION="ID_1943521361" ENDARROW="Default" ENDINCLINATION="-1423;-376;" ID="Arrow_ID_779469840" STARTARROW="None" STARTINCLINATION="920;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1533608459780" ID="ID_1685349188" MODIFIED="1533608467039" TEXT="können wir nicht sofort lösen"/>
|
|
<node CREATED="1533608471274" FOLDED="true" ID="ID_1700599331" MODIFIED="1561827464592" TEXT="aber müssen der Lösung vorgreifen">
|
|
<linktarget COLOR="#c1a9be" DESTINATION="ID_1700599331" ENDARROW="Default" ENDINCLINATION="123;115;" ID="Arrow_ID_399610434" SOURCE="ID_193790781" STARTARROW="None" STARTINCLINATION="282;-120;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533608548408" ID="ID_154643654" MODIFIED="1533608602022" TEXT="man fragt einen Service: gib mir....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist schon bekannt, daß dieser Service der <b>ViewLocator</b> sein wird,
|
|
</p>
|
|
<p>
|
|
und daß man ihn via <b>InteractionDirector</b> erreicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533608609479" FOLDED="true" ID="ID_1375309708" MODIFIED="1561827464592" TEXT="Erzeugung">
|
|
<node CREATED="1533608626061" ID="ID_401916400" MODIFIED="1533608643287" TEXT="entweder aufgrund so einer Anfrage"/>
|
|
<node CREATED="1533608656121" ID="ID_448111831" MODIFIED="1533608669227" TEXT="oder explizit per User/Menü-Aktion"/>
|
|
<node CREATED="1533608670271" ID="ID_216288706" MODIFIED="1533608678066" TEXT="oder generisch-fest-verdrahtet"/>
|
|
</node>
|
|
<node CREATED="1533608721200" FOLDED="true" ID="ID_724576502" MODIFIED="1561827464592" TEXT="Schlußfolgerung">
|
|
<node CREATED="1533608737142" ID="ID_1087400544" MODIFIED="1533608752167" TEXT="der vollziehende Erzeuger braucht Zugang zum UI-Bus"/>
|
|
<node CREATED="1533608822826" ID="ID_1772827095" MODIFIED="1533608834604" TEXT="Schema zur reproduzierbaren ID-Generierung ist notwendig"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534513723209" FOLDED="true" ID="ID_592805858" MODIFIED="1561827464592" TEXT="PanelManger liefert Panel">
|
|
<arrowlink COLOR="#99a7bd" DESTINATION="ID_1360472787" ENDARROW="Default" ENDINCLINATION="772;-6907;" ID="Arrow_ID_1137118362" STARTARROW="None" STARTINCLINATION="698;1616;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534513739655" ID="ID_1688346556" MODIFIED="1534516101304" TEXT="Suche per Typ-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534516106942" ID="ID_1930444963" MODIFIED="1534516117582" TEXT="Referenz auf Panel zurückliefern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1534513747542" ID="ID_313486234" MODIFIED="1534513755681" TEXT="im Moment eine int-ID">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534513723209" FOLDED="true" ID="ID_1131466377" MODIFIED="1561827464592" TEXT="Zugang durch WindowLocator / PanelLocator">
|
|
<arrowlink COLOR="#aab7cb" DESTINATION="ID_1614049284" ENDARROW="Default" ENDINCLINATION="772;-6907;" ID="Arrow_ID_139428133" STARTARROW="None" STARTINCLINATION="676;1738;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534520043319" ID="ID_1510680356" MODIFIED="1534520065894" TEXT="vorläufige Implementierung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1534520050783" ID="ID_193790781" MODIFIED="1534520115340" TEXT="greift vor auf ViewLocator">
|
|
<arrowlink COLOR="#c1a9be" DESTINATION="ID_1700599331" ENDARROW="Default" ENDINCLINATION="123;115;" ID="Arrow_ID_399610434" STARTARROW="None" STARTINCLINATION="282;-120;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504203667130" FOLDED="true" HGAP="50" ID="ID_1745777873" MODIFIED="1561827469145" TEXT="vorläufig Empfänger für Fehler-Log" VSHIFT="2">
|
|
<arrowlink COLOR="#98a2c5" DESTINATION="ID_217810080" ENDARROW="Default" ENDINCLINATION="1891;-1228;" ID="Arrow_ID_1688804340" STARTARROW="None" STARTINCLINATION="-1261;74;"/>
|
|
<linktarget COLOR="#7893b2" DESTINATION="ID_1745777873" ENDARROW="Default" ENDINCLINATION="-499;-464;" ID="Arrow_ID_1590510093" SOURCE="ID_812129962" STARTARROW="None" STARTINCLINATION="808;0;"/>
|
|
<linktarget COLOR="#628195" DESTINATION="ID_1745777873" ENDARROW="Default" ENDINCLINATION="245;349;" ID="Arrow_ID_1743659141" SOURCE="ID_1981930639" STARTARROW="None" STARTINCLINATION="397;197;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1504203746239" ID="ID_697660682" MODIFIED="1538263469667" TEXT="Scroll-Pane">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1504203749815" FOLDED="true" ID="ID_1057483680" MODIFIED="1561827469123" STYLE="fork" TEXT="Textanzeige-Box">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504215911647" ID="ID_1066629131" MODIFIED="1538263469667" TEXT="GtkTextView"/>
|
|
<node CREATED="1504215958961" ID="ID_55797578" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-textview-buffer.html.en#textview-formatting" MODIFIED="1538263469667" TEXT="Formattierung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1504219859389" FOLDED="true" ID="ID_653669269" MODIFIED="1538263469667" TEXT="Scrollen zum zuletzt eingefügten Text">
|
|
<arrowlink COLOR="#9bbabd" DESTINATION="ID_429138159" ENDARROW="Default" ENDINCLINATION="-1413;0;" ID="Arrow_ID_1025095859" STARTARROW="None" STARTINCLINATION="-1151;202;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504220139416" ID="ID_1997485219" MODIFIED="1518487921054" TEXT="scroll_to(iterator) funktioniert nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1504220198880" ID="ID_1877499848" MODIFIED="1518487921054" TEXT="muß Marke verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504216221389" FOLDED="true" ID="ID_355253225" MODIFIED="1561827464612" TEXT="Marks">
|
|
<node CREATED="1504216224349" ID="ID_1372118244" MODIFIED="1538263469667" TEXT="was ist die "insert"-Mark?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1504219835536" ID="ID_1720205947" MODIFIED="1538263469667" TEXT="der Text-Cursor">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504203763606" ID="ID_877984616" MODIFIED="1538263469667" TEXT="in ein Widget verpacken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1504203754175" FOLDED="true" ID="ID_580465154" MODIFIED="1561827469124" TEXT="Fehler-Level erkennen">
|
|
<arrowlink DESTINATION="ID_1459967459" ENDARROW="Default" ENDINCLINATION="-73;-253;" ID="Arrow_ID_424075973" STARTARROW="None" STARTINCLINATION="225;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537754684692" FOLDED="true" HGAP="65" ID="ID_494305022" MODIFIED="1561827464612" TEXT="Rolle im API klären" VSHIFT="-12">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauchen wir diese zwischengeschaltete Methode <b>showMsg()</b>?
|
|
</p>
|
|
<p>
|
|
wäre es nicht sinnvoller, sie direkt auf das API zu heben?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538266114512" ID="ID_1994199296" MODIFIED="1538266139416" TEXT="Enum nur noch im NotificationService"/>
|
|
<node CREATED="1538266140789" ID="ID_965920969" MODIFIED="1538266163157" TEXT="Widget: drei einzelne API-Methoden"/>
|
|
<node CREATED="1538266165305" ID="ID_318361090" MODIFIED="1538266174884" TEXT="Controller: in Protokoll integriert"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725200588" FOLDED="true" ID="ID_871562482" MODIFIED="1561827469124" TEXT="Operationen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534725109137" FOLDED="true" ID="ID_694776463" MODIFIED="1538756305396" TEXT="expand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534725397553" FOLDED="true" ID="ID_1072347956" MODIFIED="1561827464612" TEXT="collapsed-Repräsentation schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535554610295" ID="ID_1050608842" MODIFIED="1538263469668" TEXT="nur vorläufige Lösung">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1535629564615" FOLDED="true" ID="ID_1047933726" MODIFIED="1561827464612" TEXT="Gtk::Expander">
|
|
<arrowlink COLOR="#4561ae" DESTINATION="ID_1889724128" ENDARROW="Default" ENDINCLINATION="-1778;-100;" ID="Arrow_ID_219393455" STARTARROW="None" STARTINCLINATION="-6486;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1535557111546" ID="ID_649935976" MODIFIED="1538263469668" TEXT="Label-Text als ctor param"/>
|
|
<node CREATED="1535557122205" ID="ID_1034248466" MODIFIED="1538263469668" TEXT="resize_toplevel (=true by default)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ob beim Expand/Collapse das umschließende Widget resized werden soll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1535563193014" FOLDED="true" ID="ID_1551506828" MODIFIED="1538277321257" TEXT="Problem: dehnt sich nicht aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1535563256725" ID="ID_327777357" MODIFIED="1535563288805" TEXT="scrolled pane belegt nur minimal notwendigen Platz"/>
|
|
<node CREATED="1535563300695" ID="ID_862867674" MODIFIED="1535563311905" TEXT="egal ob initial zugeklappt (=default) oder aufgeklappt"/>
|
|
<node CREATED="1535563317214" ID="ID_201611533" MODIFIED="1535563330839" TEXT="egal in welcher Reihenfolge man es hinzufügt"/>
|
|
<node CREATED="1535563334050" ID="ID_718726647" MODIFIED="1535563366331" TEXT="dagegen direkt im Frame dehnt sie sich aus"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535629564615" ID="ID_228360739" MODIFIED="1538263469668" TEXT="Lösung: Widget::property_expand()">
|
|
<arrowlink COLOR="#6277b2" DESTINATION="ID_860094095" ENDARROW="Default" ENDINCLINATION="-1778;-100;" ID="Arrow_ID_761942436" STARTARROW="None" STARTINCLINATION="-6486;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1535554640586" FOLDED="true" ID="ID_1376241476" MODIFIED="1561827464613" TEXT="essentiell: passiert im Parent-Widget">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>...wesentliches Struktur-Element:</p>
|
|
<p>der Parent-Container ist für das expand/collapse zuständig</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535634032601" FOLDED="true" ID="ID_964641889" MODIFIED="1561827464613" TEXT="Design-Problem: sich expandieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535634116925" FOLDED="true" ID="ID_1129948550" MODIFIED="1561827464612" TEXT="Voraussetzung: unser Widget-Protokoll">
|
|
<node CREATED="1535634127852" ID="ID_317106359" MODIFIED="1538263469668" TEXT="enthält eine expand()-Methode"/>
|
|
<node CREATED="1535636097808" ID="ID_1540209936" MODIFIED="1538263469668" TEXT="Unterschied Widget / Controller ?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535636169439" FOLDED="true" ID="ID_631287309" MODIFIED="1538263469668" TEXT="zwei Modelle denkbar">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1535636219312" FOLDED="true" ID="ID_1940674226" MODIFIED="1561827464612" TEXT="Widget ist Expander">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1535636281176" ID="ID_232056866" MODIFIED="1535636470569" TEXT="wähle "das Widget" geeignet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535636297102" ID="ID_1966837488" MODIFIED="1535636338854">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
als <i>denjenigen</i> Container...
|
|
</p>
|
|
<p>
|
|
...der das <i>eigentliche</i> Widget expandieren kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535636621140" FOLDED="true" ID="ID_1785708787" MODIFIED="1561827464612" TEXT="pro">
|
|
<node CREATED="1535636644385" ID="ID_976356089" MODIFIED="1535636649884" TEXT="elegantes Design"/>
|
|
<node CREATED="1535636650664" ID="ID_457403473" MODIFIED="1535636661234" TEXT="minimalistisch"/>
|
|
</node>
|
|
<node CREATED="1535636640849" FOLDED="true" ID="ID_1629039815" MODIFIED="1561827464612" TEXT="con">
|
|
<node CREATED="1535636663334" ID="ID_1826518668" MODIFIED="1535636693159" TEXT="ordnet alle anderen Belange diesem Belang unter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ggfs müssen alle anderen Funktionen nach unten delegieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535636755202" ID="ID_507299995" MODIFIED="1535636897708" TEXT="kann grundsätzlich nicht alle Fälle abdecken">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn nämlich das "Expandieren" in einen weiter reichenden Zusammenhang integriert ist,
|
|
</p>
|
|
<p>
|
|
wie z.B. Darstellung in verschiedenen Detailierungs-Graden, oder ein generelles
|
|
</p>
|
|
<p>
|
|
Fokus-/Layout- Management <i>mehrerer</i> Komponenten zusammen
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Standard-Beispiel: Property-Panel
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535636904118" FOLDED="true" ID="ID_489559609" MODIFIED="1561827464612" TEXT="Fazit">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1535636909262" ID="ID_1644409361" MODIFIED="1535636911657" TEXT="abgelehnt"/>
|
|
<node CREATED="1535636912365" ID="ID_298319841" MODIFIED="1535636929783" TEXT="da einfacher als die Essenz"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535636231135" FOLDED="true" ID="ID_913979725" MODIFIED="1561827464613" TEXT="Widget kennt Expander">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1535636486110" ID="ID_285628512" MODIFIED="1535636495891" TEXT="in Form eines Adapters">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535636600599" ID="ID_103556348" MODIFIED="1535636618368" TEXT="der die "expand/collapse"-Funktionalität abstrahiert"/>
|
|
<node CREATED="1535637406019" FOLDED="true" ID="ID_1125726861" MODIFIED="1561827464612" TEXT="ermöglicht generische Impl">
|
|
<node CREATED="1535637416210" ID="ID_1038164215" MODIFIED="1535637424461" TEXT="Gegenwart des Adapters schaltet Feature ein"/>
|
|
<node CREATED="1535637441351" ID="ID_181377485" MODIFIED="1535637498835" TEXT="Standard-Adapter für Gtk::Expander"/>
|
|
<node CREATED="1535637512597" ID="ID_1713615715" MODIFIED="1535637520896" TEXT="Parent-Container kann Adapter selber implementieren"/>
|
|
<node CREATED="1535637534163" ID="ID_1194572504" MODIFIED="1535637548308" TEXT="kann mit "Reveal"-Funktion kombiniert werden"/>
|
|
<node CREATED="1535638307459" ID="ID_1697210606" MODIFIED="1535638391524" TEXT="possibly to discover dynamically">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn wir eine Mix-in -Implementierung wählen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535638228558" FOLDED="true" ID="ID_1027845785" MODIFIED="1561827464613" TEXT="Fazit">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535638234405" ID="ID_1845070371" MODIFIED="1535638250610" TEXT="komplex mit der Gefahr des Over-Engineering">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1535638255138" ID="ID_591635299" MODIFIED="1535638276217" TEXT="erscheint trotzdem als die angemessene Lösung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1535731363267" FOLDED="true" ID="ID_603236457" MODIFIED="1561827464613" TEXT="Lösung">
|
|
<arrowlink COLOR="#5f8cc1" DESTINATION="ID_447101734" ENDARROW="Default" ENDINCLINATION="22;-23;" ID="Arrow_ID_272345450" STARTARROW="None" STARTINCLINATION="-97;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1535731373978" ID="ID_182280315" MODIFIED="1538263469668" TEXT="Widget hält einen Expander-Funktor"/>
|
|
<node CREATED="1535731402126" ID="ID_1177558244" MODIFIED="1538263469668" TEXT="damit ist eine Standard-Impl von Tangible::doExpand() möglich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535638412517" FOLDED="true" ID="ID_447101734" MODIFIED="1561827464613" TEXT="Adapter-Interfaces entwerfen">
|
|
<arrowlink COLOR="#709eaf" DESTINATION="ID_316446199" ENDARROW="Default" ENDINCLINATION="-354;-490;" ID="Arrow_ID_1105268233" STARTARROW="None" STARTINCLINATION="-3385;0;"/>
|
|
<linktarget COLOR="#5f8cc1" DESTINATION="ID_447101734" ENDARROW="Default" ENDINCLINATION="22;-23;" ID="Arrow_ID_272345450" SOURCE="ID_603236457" STARTARROW="None" STARTINCLINATION="-97;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535725900392" ID="ID_489679545" MODIFIED="1538263469668" TEXT="Expander">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535725906647" ID="ID_1380126396" MODIFIED="1538263469668" TEXT="Revealer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535726065753" FOLDED="true" ID="ID_578786610" MODIFIED="1561827464613" TEXT="default-Impl doExpand()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535726077504" ID="ID_1806068721" MODIFIED="1538263469668" TEXT="prüfen: canExpand">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535726086631" ID="ID_1753268128" MODIFIED="1538263469668" TEXT="Expander aufrufen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535743810027" ID="ID_778321095" MODIFIED="1538263469668" TEXT="bestehende default-Impl aus Widget/Controller entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535725923421" FOLDED="true" ID="ID_298871659" MODIFIED="1561827464613" TEXT="Expander geeignet verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1535725940226" ID="ID_162482468" MODIFIED="1538263469668" TEXT="validiert das Design">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535743705113" ID="ID_54369760" MODIFIED="1538263469668" TEXT="auch MockElm anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535737902126" FOLDED="true" ID="ID_1001984094" MODIFIED="1561827464613" TEXT="Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535750033829" ID="ID_1808097547" MODIFIED="1538263469668" TEXT="AbstractTangible_test::markState()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1535750110787" ID="ID_1169665466" MODIFIED="1538263469668" TEXT="tested implizit die neue default-Implementierung mit">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725101578" FOLDED="true" ID="ID_974315967" MODIFIED="1561827464613" TEXT="clearAll">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538277182898" ID="ID_1432000446" MODIFIED="1538277242242" TEXT="Marker-Tabelle leeren"/>
|
|
<node CREATED="1538277192232" ID="ID_94588950" MODIFIED="1538277241203" TEXT="Platzhalter-Zeile">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um den Umstand zu dokumentieren,
|
|
</p>
|
|
<p>
|
|
daß hier ## Zeilen gelöscht wurden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725131214" ID="ID_1479834475" MODIFIED="1538263469668" TEXT="addMsg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725152139" FOLDED="true" ID="ID_887758432" MODIFIED="1538756202003" TEXT="addError">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534725422454" FOLDED="true" ID="ID_1459967459" MODIFIED="1561827464614" TEXT="spezieller Markup">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1459967459" ENDARROW="Default" ENDINCLINATION="-73;-253;" ID="Arrow_ID_424075973" SOURCE="ID_580465154" STARTARROW="None" STARTINCLINATION="225;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537571906634" FOLDED="true" ID="ID_1839759637" MODIFIED="1561827464614" TEXT="Tags anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1537571917625" FOLDED="true" ID="ID_1900926418" MODIFIED="1561827464614" TEXT="kären: CSS?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1535629564615" HGAP="43" ID="ID_1432671260" MODIFIED="1538263469668" TEXT="GTK-Styling, CSS für Custom-Widgets" VSHIFT="-35">
|
|
<arrowlink COLOR="#6277b2" DESTINATION="ID_1174884362" ENDARROW="Default" ENDINCLINATION="-2315;-45;" ID="Arrow_ID_380937946" STARTARROW="None" STARTINCLINATION="-7413;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1537661752104" ID="ID_373027917" MODIFIED="1538263469668" TEXT="wohl nicht so einfach"/>
|
|
<node COLOR="#338800" CREATED="1537661764454" FOLDED="true" ID="ID_1004400727" MODIFIED="1561827464613" TEXT="Untersuchen per Inspector">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1538707192879" ID="ID_253847354" MODIFIED="1538707208726" TEXT="jedes Tag ist einzeln in der Objekt-Hierarchie vorhanden"/>
|
|
<node CREATED="1538707176081" ID="ID_1239285032" MODIFIED="1538707284654">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erscheint <b>definitiv nicht</b> als CSS-Node
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537661787387" FOLDED="true" ID="ID_20967740" MODIFIED="1561827464614" TEXT="vorläufig hart verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537752420235" ID="ID_922959985" MODIFIED="1538263469668" TEXT="Funktion zum Populieren der Tag-Table"/>
|
|
<node CREATED="1537752434280" ID="ID_1053927695" MODIFIED="1538263469669" TEXT="könnte in den StyleManager wandern">
|
|
<arrowlink COLOR="#b3a9c1" DESTINATION="ID_758790930" ENDARROW="Default" ENDINCLINATION="96;-5;" ID="Arrow_ID_1283375190" STARTARROW="None" STARTINCLINATION="-17;39;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537571928143" ID="ID_221069673" MODIFIED="1538263469669" TEXT="Tag für Warnung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537571934143" ID="ID_447258227" MODIFIED="1538263469669" TEXT="Tag für Fehler">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537571949893" ID="ID_328949056" MODIFIED="1538263469669" TEXT="Tags zuweisen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537571956436" ID="ID_1806243350" MODIFIED="1538587722314" TEXT="Tags entfernen">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1806243350" ENDARROW="Default" ENDINCLINATION="294;-15;" ID="Arrow_ID_52974407" SOURCE="ID_383201596" STARTARROW="None" STARTINCLINATION="294;-15;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725501467" FOLDED="true" ID="ID_1420459325" MODIFIED="1538587929492" TEXT="Bookmark speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1537535919147" FOLDED="true" ID="ID_1338221225" MODIFIED="1561827464614" TEXT="Technologie">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1537535925874" FOLDED="true" ID="ID_196796680" MODIFIED="1561827464614" TEXT="Tag / TagTable">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1537535939265" ID="ID_1176049085" MODIFIED="1538263469669" TEXT="geht nicht"/>
|
|
<node CREATED="1537535943840" ID="ID_694044876" MODIFIED="1538263469669" TEXT="man kann nicht nach Tags suchen"/>
|
|
<node CREATED="1537536772568" ID="ID_332685872" MODIFIED="1538263469669" TEXT="(Suchen kann man auf dem Iterator)"/>
|
|
</node>
|
|
<node CREATED="1537536783583" FOLDED="true" ID="ID_883754303" MODIFIED="1561827464614" TEXT="Mark verwenden">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1537536791477" ID="ID_1332288045" MODIFIED="1538263469669" TEXT="muß Index dafür selber pflegen"/>
|
|
<node CREATED="1537536808627" ID="ID_609351839" MODIFIED="1538263469669" TEXT="kann dann direkt zur Mark springen"/>
|
|
<node CREATED="1537536819657" ID="ID_1987418184" MODIFIED="1538263469669" TEXT="wird durch Edits/Insterts nicht gestört">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537571771685" FOLDED="true" ID="ID_1198199438" MODIFIED="1561827464614" TEXT="ErrorIndex">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537571794801" FOLDED="true" ID="ID_1255966338" MODIFIED="1561827464614" TEXT="einfügen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538581675841" ID="ID_914012802" MODIFIED="1538581695036" TEXT="Problem: brauche Anfangs und Endpunkt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538581696238" ID="ID_579972167" MODIFIED="1538581705246" TEXT="speichere ein Paar von Marken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538581570783" FOLDED="true" ID="ID_1599117331" MODIFIED="1561827464614" TEXT="Problem: Ende wandert mit...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das liegt vermutlich daran, daß ich die zweite Marke mit "right gravity" einfüge,
|
|
</p>
|
|
<p>
|
|
aber eben am absoluten Ende des Buffers. Damit wird sie hinter jeder Einfügung bleiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538585387424" ID="ID_151756918" MODIFIED="1538585442447" TEXT="Trick: erst abschließenden Zeilenumbruch">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538585409653" ID="ID_584738161" MODIFIED="1538585447421">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dann Einfügestelle <i>davor</i> platzieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537571882918" FOLDED="true" ID="ID_620353485" MODIFIED="1561827464614" TEXT="reorganisieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538586059134" ID="ID_5616537" MODIFIED="1538586065889" TEXT="besser wegwerfen und neu bauen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537537333987" FOLDED="true" ID="ID_667263409" MODIFIED="1561827464614" TEXT="Übersicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537537339011" FOLDED="true" ID="ID_1759202815" MODIFIED="1561827464614" TEXT="Lösung">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1537537345410" ID="ID_1560200040" MODIFIED="1538263469669" TEXT="Toolbar verwenden?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1537537353105" ID="ID_409330854" MODIFIED="1538263469669" TEXT="ButtonBox verwenden?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1537571223088" ID="ID_1186576760" MODIFIED="1538263469669" TEXT="erst mal gar nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
YAGNI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1537571240500" FOLDED="true" ID="ID_1601115005" MODIFIED="1538756163375" TEXT="nur >> (nächster Fehler)">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1537571669683" ID="ID_196982892" MODIFIED="1538263469669" TEXT="wenn es Fehler gibt"/>
|
|
<node CREATED="1537571681249" ID="ID_1273769655" MODIFIED="1538263469669" TEXT="wenn es mehr Zeilen gibt"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538756156811" ID="ID_27239439" MODIFIED="1538756161793" TEXT="YAGNI">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537572133580" ID="ID_671753441" MODIFIED="1538756131546" TEXT="Button: clear Errors">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537572142139" ID="ID_1644572130" MODIFIED="1538756133431" TEXT="Button: clear all">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531676045" FOLDED="true" ID="ID_548104404" MODIFIED="1561827464615" TEXT="addWarning">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537531682564" ID="ID_1510582702" MODIFIED="1538263469669" TEXT="nur speziell ausgezeichnete Meldung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725142756" FOLDED="true" ID="ID_343395831" MODIFIED="1538756206590" TEXT="clearInfoMsg">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1538581145248" ID="ID_643768128" MODIFIED="1538581206025" TEXT="neuen TextBuffer anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538581157502" ID="ID_1715975641" MODIFIED="1538581204913" TEXT="nur die Fehler-Einträge übertragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538581168092" ID="ID_404563793" MODIFIED="1538581204032" TEXT="dabei auch einen neuen Mark-Index populieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538581183986" ID="ID_147260284" MODIFIED="1538581203099" TEXT="Alten gegen Neuen austauschen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725160618" FOLDED="true" ID="ID_1981616896" MODIFIED="1538756208941" TEXT="turnError_into_InfoMsg">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534725575098" ID="ID_383201596" MODIFIED="1538587760128" TEXT="Markup reduzieren">
|
|
<arrowlink DESTINATION="ID_1806243350" ENDARROW="Default" ENDINCLINATION="294;-15;" ID="Arrow_ID_52974407" STARTARROW="None" STARTINCLINATION="294;-15;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725587112" ID="ID_31905080" MODIFIED="1538587763137" TEXT="Bookmarks entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725180543" FOLDED="true" ID="ID_1442607312" MODIFIED="1538756210290" TEXT="triggerFlash">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534725283337" FOLDED="true" ID="ID_1256364821" MODIFIED="1561827464615" TEXT="farbigen Rahmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534725366734" ID="ID_951505172" MODIFIED="1538618155829" TEXT="verwende zusätzliche Klasse">
|
|
<arrowlink COLOR="#877796" DESTINATION="ID_758790930" ENDARROW="Default" ENDINCLINATION="315;0;" ID="Arrow_ID_564282272" STARTARROW="None" STARTINCLINATION="649;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538707399447" FOLDED="true" ID="ID_1845737933" MODIFIED="1561827464615" TEXT="Rahmen auch auf Kind-Objekte setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538707420444" ID="ID_334911121" MODIFIED="1538707474258" TEXT="denn nur so erscheint er z.B. bei einem TextView">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Widget hat offensichtlich keine eigene graphische Repräsentation.
|
|
</p>
|
|
<p>
|
|
dieser Fall dürfte häufiger auftreten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538618157537" FOLDED="true" ID="ID_1728464265" MODIFIED="1561827464615" TEXT="Problem: kaputtes Stylesheet">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538618179734" ID="ID_1693288014" MODIFIED="1538618198551" TEXT="das Lumiera-eigene Stylesheet funktioniert praktisch gar nicht mehr"/>
|
|
<node CREATED="1538618201035" ID="ID_1034140537" MODIFIED="1538618349191" TEXT="...seitdem die Engine 'Adwaitha' nicht mehr gefunden wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ca 2014 finde ich einige Blog-Einträge, daß jetzt keine Theming-Engine mehr notwendig ist,
|
|
</p>
|
|
<p>
|
|
weil man alles per CSS machen kann. Seit Jessie findet GTK die Engine nicht mehr,
|
|
</p>
|
|
<p>
|
|
obwohl das Standard-Theme-Paket installiert ist.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dummerweise funktioniert nun aber auch das Übersteuern mit unseren Farben nicht mehr
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538707301511" FOLDED="true" ID="ID_265456880" MODIFIED="1561827464615" TEXT="vorläufig gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538707313237" ID="ID_1871755466" MODIFIED="1538707323542" TEXT="Theming-Engine nicht mehr notwendig"/>
|
|
<node CREATED="1538707324276" ID="ID_876477218" MODIFIED="1538707360310" TEXT="alternatives Ergänzungs-Stylesheet angelegt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welches ich zusammen mit meinem
|
|
</p>
|
|
<p>
|
|
normalen 'light' destkop-theme verwenden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534725292080" FOLDED="true" ID="ID_1462887421" MODIFIED="1561827464615" TEXT="timeout setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538590120545" ID="ID_1847571040" MODIFIED="1538590128908" TEXT="Glib::timeout nutzen"/>
|
|
<node CREATED="1538590129616" ID="ID_9828219" MODIFIED="1538590145185" TEXT="analog zum Ctor InteractionDirector">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538590112698" FOLDED="true" ID="ID_360284784" MODIFIED="1561827464616" TEXT="generisch anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538591568439" FOLDED="true" ID="ID_1863162820" MODIFIED="1561827464615" TEXT="Idee: Flasher">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538591875574" ID="ID_701299048" MODIFIED="1538592020697" TEXT="muß von Gtk::Widget erben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1538591734386" FOLDED="true" ID="ID_1790046084" MODIFIED="1561827464615" TEXT="void flash()">
|
|
<node CREATED="1538591895692" ID="ID_954326123" MODIFIED="1538591904679" TEXT="installiert Glib::timeout"/>
|
|
<node CREATED="1538591905458" ID="ID_817752728" MODIFIED="1538591950857" TEXT="fügt CSS-Klasse hinzu"/>
|
|
</node>
|
|
<node CREATED="1538591750359" FOLDED="true" ID="ID_1546318660" MODIFIED="1561827464615" TEXT="void flashback()">
|
|
<node CREATED="1538591954100" ID="ID_248197618" MODIFIED="1538591969766" TEXT="vom Timeout aufgerufen"/>
|
|
<node CREATED="1538591970498" ID="ID_1898943385" MODIFIED="1538591977037" TEXT="entfernt CSS-Klasse"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538592070125" FOLDED="true" ID="ID_30810203" MODIFIED="1561827464615" TEXT="Varianten">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538592125238" FOLDED="true" ID="ID_1673239146" MODIFIED="1561827464615" TEXT="hat WLink auf target-widget">
|
|
<node CREATED="1538592323691" ID="ID_567150569" MODIFIED="1538592333222" TEXT="lebt irgendwo als Member"/>
|
|
<node CREATED="1538592438724" ID="ID_1623451463" MODIFIED="1538592446455" TEXT="muß explizit mit dem Target verbunden werden"/>
|
|
</node>
|
|
<node CREATED="1538592135452" FOLDED="true" ID="ID_526442862" MODIFIED="1561827464615" TEXT="freischwebende selbsterhaltende Heap-Allokation">
|
|
<node CREATED="1538592277209" ID="ID_1333427334" MODIFIED="1538592290619" TEXT="flashback() endet mit Suizid"/>
|
|
<node CREATED="1538592450338" ID="ID_1611670382" MODIFIED="1538592470811" TEXT="Memory-Leak wenn flashback() ausbleibt"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538592473055" FOLDED="true" ID="ID_1323523600" MODIFIED="1561827464615" TEXT="Beschluß: Mixin-Design">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538606819103" ID="ID_404941112" MODIFIED="1538607019739" TEXT="Balance">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn dieses Design gibt die beste Balance zwischen den Belangen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
kein zusätzlicher Speicherbedarf
|
|
</li>
|
|
<li>
|
|
Callback ist automatisch abgesichert (sigc::mem_fun auf Trackable)
|
|
</li>
|
|
<li>
|
|
kann direkt auf das Styling des Parent zugreifen
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Einziger Nachteil ist die etwas verwirrende Schreibweise des dekorierten Typs
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1538607106686" ID="ID_1879979063" MODIFIED="1538607368158" TEXT="z.B: FlashDeco<Gtk::TextView>"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534722011622" FOLDED="true" ID="ID_232472679" MODIFIED="1538756217350" TEXT="revealYourself">
|
|
<linktarget COLOR="#76a4ad" DESTINATION="ID_232472679" ENDARROW="Default" ENDINCLINATION="94;307;" ID="Arrow_ID_634173548" SOURCE="ID_898428560" STARTARROW="None" STARTINCLINATION="859;27;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535726017256" FOLDED="true" ID="ID_899234988" MODIFIED="1561827464616" TEXT="default-Impl doReveal()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535726035309" ID="ID_1034773573" MODIFIED="1538263469670" TEXT="prüfen canReveal">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535726053483" ID="ID_628118697" MODIFIED="1538263469670" TEXT="Revealer aufrufen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535743810027" ID="ID_1786165843" MODIFIED="1538263469670" TEXT="bestehende default-Impl aus Widget/Controller entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534722062911" ID="ID_1134044414" MODIFIED="1538263469670" TEXT="braucht Parent-Link">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1534722073526" ID="ID_1428186731" MODIFIED="1538263469670" TEXT="parent.reveal(this)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535725982021" FOLDED="true" ID="ID_858097581" MODIFIED="1561827464616" TEXT="Revealer geeignet verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535743705113" ID="ID_267884906" MODIFIED="1538263469670" TEXT="auch MockElm anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535743754227" ID="ID_1964115972" MODIFIED="1538263469670" TEXT="doReveal(ID) API entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535737911365" FOLDED="true" ID="ID_79619425" MODIFIED="1561827464616" TEXT="Unit-Test: AbtractTangible_test erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535815055702" ID="ID_493114230" MODIFIED="1538263469670" TEXT="EventLog: Problem mit Backtracking">
|
|
<arrowlink COLOR="#80b3ba" DESTINATION="ID_1041148737" ENDARROW="Default" ENDINCLINATION="-1705;-7489;" ID="Arrow_ID_1257144480" STARTARROW="None" STARTINCLINATION="838;114;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537320168170" ID="ID_1213843922" MODIFIED="1538263469670" TEXT="danach läßt sich die gewünschte Log-Bedingung formulieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535756076321" FOLDED="true" ID="ID_1044092797" MODIFIED="1561827464616" TEXT="konkret was machen, damit man die Funktion sehen kann">
|
|
<linktarget COLOR="#58c39d" DESTINATION="ID_1044092797" ENDARROW="Default" ENDINCLINATION="169;308;" ID="Arrow_ID_1805058492" SOURCE="ID_1726008784" STARTARROW="None" STARTINCLINATION="890;-197;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537461362558" ID="ID_1738911844" MODIFIED="1538263469670" TEXT="Idee: ggfs minimiertes DockItem wiederherstellen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1537499243954" FOLDED="true" ID="ID_971802810" MODIFIED="1561827464616" TEXT="versuche mal Panel::show(true)">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1537499275630" FOLDED="true" ID="ID_1288942046" MODIFIED="1561827464616" TEXT="verdrahtet in den Revealer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537499313305" ID="ID_1086105877" MODIFIED="1538263469670" TEXT="von ErrorLogDisplay"/>
|
|
<node CREATED="1537499333798" ID="ID_57237574" MODIFIED="1538263469670" TEXT="verdrahtet in InfoboxPanel::getLog()"/>
|
|
</node>
|
|
<node CREATED="1537499267335" ID="ID_608745909" MODIFIED="1538574682605" TEXT="keine Ahnung ob das was bewirkt...">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538574348519" FOLDED="true" ID="ID_1605278639" MODIFIED="1538574397921" TEXT="funktioniert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538574378707" ID="ID_1292635888" MODIFIED="1538574394169" TEXT="es erzeugt ein neues freischwebendes Panel">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538574380386" ID="ID_1693045801" MODIFIED="1538574388709" TEXT="sofern das Panel vorher geschlossen wurde"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537661799354" FOLDED="true" ID="ID_758790930" MODIFIED="1561827469124" TEXT="Style-Manager vorsehen">
|
|
<arrowlink COLOR="#8f81b2" DESTINATION="ID_407535546" ENDARROW="Default" ENDINCLINATION="3769;-2728;" ID="Arrow_ID_1203118148" STARTARROW="None" STARTINCLINATION="-1594;0;"/>
|
|
<linktarget COLOR="#b3a9c1" DESTINATION="ID_758790930" ENDARROW="Default" ENDINCLINATION="96;-5;" ID="Arrow_ID_1283375190" SOURCE="ID_1053927695" STARTARROW="None" STARTINCLINATION="-17;39;"/>
|
|
<linktarget COLOR="#877796" DESTINATION="ID_758790930" ENDARROW="Default" ENDINCLINATION="315;0;" ID="Arrow_ID_564282272" SOURCE="ID_951505172" STARTARROW="None" STARTINCLINATION="649;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538588393995" HGAP="214" ID="ID_828368967" MODIFIED="1538589740205" TEXT="#1168 : find a way to manage style of custom extended UI elements" VSHIFT="19">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538588393995" FOLDED="true" HGAP="212" ID="ID_47427991" MODIFIED="1538589740205" TEXT="geeignetes Aufrufmuster schon mal angelegt" VSHIFT="-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538588510003" ID="ID_217668977" MODIFIED="1538588519598" TEXT="anscheinend geht hier nix per CSS"/>
|
|
<node CREATED="1538588520377" ID="ID_178600292" MODIFIED="1538588531044" TEXT="daher: Tags per Name einfügen"/>
|
|
<node CREATED="1538588531824" ID="ID_1287551637" MODIFIED="1538588544522" TEXT="Tags zentral populieren"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538746635373" FOLDED="true" ID="ID_1501747643" MODIFIED="1561827469124" TEXT="Error-Flag (Zustand)">
|
|
<linktarget COLOR="#87a5af" DESTINATION="ID_1501747643" ENDARROW="Default" ENDINCLINATION="54;212;" ID="Arrow_ID_512060720" SOURCE="ID_1074988560" STARTARROW="None" STARTINCLINATION="788;93;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538746644284" ID="ID_1672227402" MODIFIED="1538746653979" TEXT="wenn ein Error-Eintrag im Index steht">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538746666721" ID="ID_9727272" MODIFIED="1538747828042" TEXT="Prädikat zur Erkennung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538746673144" ID="ID_1324190008" MODIFIED="1538747829912" TEXT="Signal welcehs bei Status-Änderung triggert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538746726849" FOLDED="true" ID="ID_1790025982" MODIFIED="1561827464617" TEXT="Buttons im InfoboxPanel steuern (Proof-of-Concept)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538751082832" ID="ID_783222361" MODIFIED="1538756010539" TEXT="muß initialen Zustand schedulen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538756013358" ID="ID_1905873400" MODIFIED="1538756056312" TEXT="denn show_all() stellt Aktionen in die Event-Queue">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689031860" HGAP="97" ID="ID_657232437" MODIFIED="1679362063151" TEXT="Implementierung" VSHIFT="9">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1533689046050" ID="ID_32330448" MODIFIED="1538263469670" TEXT="ErrorLog-Widget">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689055601" FOLDED="true" ID="ID_335901895" MODIFIED="1561827482907" TEXT="InfoboxPanel anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534523190695" FOLDED="true" ID="ID_1941760302" MODIFIED="1561827469145" TEXT="ErrorLog bei Bedarf belegen">
|
|
<arrowlink COLOR="#88a8b3" DESTINATION="ID_1806645586" ENDARROW="Default" ENDINCLINATION="-186;-20;" ID="Arrow_ID_948128706" STARTARROW="None" STARTINCLINATION="4;109;"/>
|
|
<linktarget COLOR="#7ca8bc" DESTINATION="ID_1941760302" ENDARROW="Default" ENDINCLINATION="-1967;5936;" ID="Arrow_ID_192358692" SOURCE="ID_329149746" STARTARROW="None" STARTINCLINATION="670;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534523686836" ID="ID_1130300208" MODIFIED="1534524660559" TEXT="per smart-ptr halten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534523712521" FOLDED="true" ID="ID_1958771642" MODIFIED="1561827469124" TEXT="access-API">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534523785342" ID="ID_1532375846" MODIFIED="1534524656476" TEXT="Löschen nicht vorgesehen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1534523790798" ID="ID_497989103" MODIFIED="1534523799758" TEXT="man kann ja das Panel schließen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534523721263" ID="ID_830255345" MODIFIED="1534523747373" TEXT="zuklappbar">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533689065976" FOLDED="true" ID="ID_1456563113" MODIFIED="1561827482907" TEXT="NotificationController im Wizzard ansiedeln">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1533768795377" FOLDED="true" ID="ID_377710833" MODIFIED="1561827469145" TEXT="wirklich ein eigenständiger Controller??">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1533768892227" ID="ID_1131924142" MODIFIED="1538263469670" TEXT="ja, macht Sinn">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil so sichergestellt ist, daß er stets existiert,
|
|
</p>
|
|
<p>
|
|
und er trotzdem vom konkreten Widget entkoppelt bleibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533768930822" ID="ID_1792377980" MODIFIED="1538263469670">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
besserer Name: <b>NotificationHub</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533769126436" FOLDED="true" ID="ID_1000961938" MODIFIED="1561827469145" TEXT="wohin?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533769130987" ID="ID_220812854" MODIFIED="1538263469671" TEXT="ctrl">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1533769133802" ID="ID_643904873" MODIFIED="1538263469671" TEXT="interact">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1533769137338" ID="ID_918339492" MODIFIED="1538263469671" TEXT="workspace">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533689076590" ID="ID_321096443" MODIFIED="1538263469671" TEXT="mit Bus verdrahten und ID global konstant definieren">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533689098787" FOLDED="true" ID="ID_191346591" MODIFIED="1561827482908" TEXT="Empfangs-Logik im NotificationHub (Controller)">
|
|
<icon BUILTIN="full-3"/>
|
|
<node COLOR="#338800" CREATED="1534119968325" FOLDED="true" ID="ID_1630503080" MODIFIED="1561827469145" TEXT="Einrichtung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534336479160" FOLDED="true" ID="ID_203145360" MODIFIED="1561827469124" TEXT="Link zum Widget herstellen">
|
|
<arrowlink COLOR="#a66b86" DESTINATION="ID_1326202399" ENDARROW="Default" ENDINCLINATION="279;-1333;" ID="Arrow_ID_664593340" STARTARROW="None" STARTINCLINATION="-1296;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534334830126" ID="ID_932140820" MODIFIED="1538263469671" TEXT="als Funktor konfiguriert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534334822288" ID="ID_1305015272" MODIFIED="1538263469671" TEXT="Allozieren">
|
|
<arrowlink COLOR="#726b86" DESTINATION="ID_1806645586" ENDARROW="Default" ENDINCLINATION="232;27;" ID="Arrow_ID_246715972" STARTARROW="None" STARTINCLINATION="180;-21;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689120536" ID="ID_1806645586" MODIFIED="1538708596522" TEXT="View belegen">
|
|
<linktarget COLOR="#88a8b3" DESTINATION="ID_1806645586" ENDARROW="Default" ENDINCLINATION="-186;-20;" ID="Arrow_ID_948128706" SOURCE="ID_1941760302" STARTARROW="None" STARTINCLINATION="4;109;"/>
|
|
<linktarget COLOR="#726b86" DESTINATION="ID_1806645586" ENDARROW="Default" ENDINCLINATION="232;27;" ID="Arrow_ID_246715972" SOURCE="ID_1305015272" STARTARROW="None" STARTINCLINATION="180;-21;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1533689125583" FOLDED="true" ID="ID_1077285383" MODIFIED="1561827469124" TEXT="mit close-signal verdrahten">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1534629989468" FOLDED="true" ID="ID_1497889519" MODIFIED="1561827464626" TEXT="close-Signal gibtsned">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1534630165971" ID="ID_783988097" MODIFIED="1534630171687" TEXT="nur Fenster haben signal_delete_event"/>
|
|
<node CREATED="1534630176586" ID="ID_712401559" MODIFIED="1534630190996" TEXT="wird aber per Default auf hide() gemappt"/>
|
|
<node COLOR="#435e98" CREATED="1534634189347" ID="ID_146943890" MODIFIED="1534635809110">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GTK-Konzepte: "<b>Schließen</b>"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6f7ab9" DESTINATION="ID_1900017952" ENDARROW="Default" ENDINCLINATION="-2264;0;" ID="Arrow_ID_1220603071" STARTARROW="None" STARTINCLINATION="-6278;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534630195728" FOLDED="true" ID="ID_1711320497" MODIFIED="1561827464627" TEXT="was brauche ich?">
|
|
<node CREATED="1534630216909" FOLDED="true" ID="ID_1211516480" MODIFIED="1561827464626">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn Log-Anzeige <i>verworfen</i> wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1534630507190" ID="ID_1710219381" MODIFIED="1534630516168" TEXT="aus dem umschließenden Container entfernt"/>
|
|
<node CREATED="1534630517045" ID="ID_435686246" MODIFIED="1534630526167" TEXT="und dann wirklich zerstört, nicht nur verborgen"/>
|
|
<node CREATED="1534630526995" ID="ID_626097783" MODIFIED="1534630535742" TEXT="zugehöriges Model wird ebenfalls zerstört"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534630538178" FOLDED="true" ID="ID_706923205" MODIFIED="1534726744532" TEXT="wenn Docking-Panel geschlossen wird">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1534630581532" FOLDED="true" ID="ID_333724082" MODIFIED="1561827464627" TEXT="herausfinden ob und was passiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534636016460" ID="ID_16558042" MODIFIED="1534636022815" TEXT="vom Code her nicht klar"/>
|
|
<node CREATED="1534636023499" ID="ID_1133271303" MODIFIED="1534636030757" TEXT="könnte kaputt sein"/>
|
|
<node CREATED="1534636033826" FOLDED="true" ID="ID_1327331647" MODIFIED="1561827464627" TEXT="theoretisch....">
|
|
<node CREATED="1534636038545" ID="ID_20267823" MODIFIED="1534636076288" TEXT="sollte das Panel aus seinem Container genommen werden"/>
|
|
<node CREATED="1534636077660" ID="ID_1153072337" MODIFIED="1534636097661" TEXT="und der Container (=DockItem) sollte daraufhin dieses Kind (=Panel) verbergen"/>
|
|
<node CREATED="1534636098937" ID="ID_684477198" MODIFIED="1534636108035" TEXT="jedenfalls wäre das die normale GTK-Logik"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534636118486" ID="ID_1396783317" MODIFIED="1534636136704" TEXT="TODO: empirisch herausfinden">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534630593946" FOLDED="true" ID="ID_332877746" MODIFIED="1561827464627" TEXT="Einstiegspunkt: PanelManager">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1534630686134" ID="ID_1763470642" MODIFIED="1534630687561" TEXT="PanelManager::removePanel"/>
|
|
<node CREATED="1534630698524" ID="ID_170868004" MODIFIED="1534630699432" TEXT="delete panel;"/>
|
|
<node CREATED="1534630922134" FOLDED="true" ID="ID_1602014175" MODIFIED="1561827464627" TEXT="komisch...">
|
|
<node CREATED="1534630926326" ID="ID_1520511750" MODIFIED="1534630932161" TEXT="Panel erbt von VBox"/>
|
|
<node CREATED="1534630932821" ID="ID_669390115" MODIFIED="1534630940399" TEXT="hält nur eine Referenz auf das DockItem"/>
|
|
<node CREATED="1534631014841" ID="ID_997149684" MODIFIED="1534631085070" TEXT="dieser Code ist gegenwärtig auskommentiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
er ist nämlich auch aufgerufen worden, nachdem die GTK-Loop bereits beendet war.
|
|
</p>
|
|
<p>
|
|
Dieser Code hat früher C-mäßig direkt die GObjects manipuliert (Anfangs hatten wir nur GDL, nicht GDLmm)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1534630941563" ID="ID_701586360" MODIFIED="1534631013681" TEXT="Code im dtor entfernt das Panel aus dem DockItem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Erläuterung: DockItem ist ein 1-elementiger GTK-Container,
|
|
</p>
|
|
<p>
|
|
der sichtbare Inhalt liegt in diesem Container. Bei uns ist das das Panel.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534632167588" FOLDED="true" ID="ID_482488418" MODIFIED="1561827464627" TEXT="gtk_container_remove">
|
|
<node CREATED="1534632172396" ID="ID_1415075917" MODIFIED="1534632183158" TEXT="ändert nichts am Sichtbarkeits-Status"/>
|
|
<node CREATED="1534632183818" ID="ID_1537037393" MODIFIED="1534632194005" TEXT="aber erniedrigt den Refcount"/>
|
|
<node CREATED="1534632290500" ID="ID_1165360257" MODIFIED="1534632304077" TEXT="emittiert das signal_remove auf dem Container"/>
|
|
<node CREATED="1534632195136" ID="ID_1692600031" MODIFIED="1534632241155" TEXT="Intersssanter Kommentar: man sollte direkt zerstören">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Removes @widget from @container. @widget must be inside @container.
|
|
</p>
|
|
<p>
|
|
Note that @container will own a reference to @widget, and that this
|
|
</p>
|
|
<p>
|
|
may be the last reference held; so removing a widget from its     
|
|
</p>
|
|
<p>
|
|
container can destroy that widget. If you want to use @widget     
|
|
</p>
|
|
<p>
|
|
again, you need to add a reference to it before removing it from  
|
|
</p>
|
|
<p>
|
|
a container, using g_object_ref(). If you don’t want to use @widget
|
|
</p>
|
|
<p>
|
|
again it’s usually more efficient to simply destroy it directly   
|
|
</p>
|
|
<p>
|
|
using gtk_widget_destroy() since this will remove it from the     
|
|
</p>
|
|
<p>
|
|
container and help break any circular reference count cycles.     
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534632585779" FOLDED="true" ID="ID_1472646683" MODIFIED="1561827464627" TEXT="gtk_widget_destroy">
|
|
<node CREATED="1534632595042" ID="ID_818220639" MODIFIED="1534632609779" TEXT="macht praktisch nix"/>
|
|
<node CREATED="1534632593098" FOLDED="true" ID="ID_1924038071" MODIFIED="1561827464627" TEXT="g_object_run_dispose">
|
|
<node CREATED="1534632642379" ID="ID_1189983629" MODIFIED="1534632650014" TEXT="macht nur Memory-Management"/>
|
|
</node>
|
|
<node CREATED="1534632859518" ID="ID_738187804" MODIFIED="1534632873272" TEXT="aufgerufen von : gtk_container_destroy">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534636163120" FOLDED="true" ID="ID_1102539072" MODIFIED="1561827464627" TEXT="explizites Destroy-Signal bauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1534636203306" ID="ID_1590219615" MODIFIED="1534636301238" TEXT="wird nicht vom Framework bereitgestellt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist das Fazit meiner Untersuchung.
|
|
</p>
|
|
<p>
|
|
"destroy" ist kein relevantes Konzept für GTK. Es gibt nur show()/hide().
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Also müssen wir <i>explizit</i>
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
eine Destroy-Signal bauen
|
|
</li>
|
|
<li>
|
|
dafür sorgen, daß das Infobox-Panel das auch aufruft
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1534636462287" ID="ID_1581893176" MODIFIED="1534721195248" TEXT="eigenes SigC Signal bereitstellen"/>
|
|
<node CREATED="1534636486123" ID="ID_1855036791" MODIFIED="1535814840374" TEXT="würde vom ErrorLog-dtor aufgerufen"/>
|
|
<node CREATED="1534721236063" ID="ID_1398832202" MODIFIED="1534721247336" TEXT="das wäre eine private Konvention">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721249117" ID="ID_997317939" MODIFIED="1534721572753" TEXT="....dann ist WLink genauso gut">
|
|
<arrowlink COLOR="#69b2a9" DESTINATION="ID_1471234946" ENDARROW="Default" ENDINCLINATION="37;-44;" ID="Arrow_ID_1612034198" STARTARROW="None" STARTINCLINATION="-209;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721400696" FOLDED="true" ID="ID_1935193271" MODIFIED="1561827469124" TEXT="jeder Zugriff prüft WLink">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534721417590" ID="ID_1471234946" MODIFIED="1538263469671" STYLE="fork" TEXT="das erübrigt Verwalten eines eigenen Signales">
|
|
<linktarget COLOR="#69b2a9" DESTINATION="ID_1471234946" ENDARROW="Default" ENDINCLINATION="37;-44;" ID="Arrow_ID_1612034198" SOURCE="ID_997317939" STARTARROW="None" STARTINCLINATION="-209;0;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534729080597" ID="ID_1547931497" MODIFIED="1538263469671" TEXT="Code durchgesehen: alle Zugriffe sauber">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
entweder sie laufen über den Getter,
|
|
</p>
|
|
<p>
|
|
oder sie prüfen den Zustand und machen nichts, wenn das Widget nicht da ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1534721435740" FOLDED="true" ID="ID_1066281960" MODIFIED="1561827464627" TEXT="Konvention: Fehlerlog-Widget zerstören">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und nicht bloß inaktiv schalten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node COLOR="#338800" CREATED="1534721528967" ID="ID_1984401497" MODIFIED="1538778232908" TEXT="verifizieren">
|
|
<arrowlink DESTINATION="ID_1360416196" ENDARROW="Default" ENDINCLINATION="417;34;" ID="Arrow_ID_1337668046" STARTARROW="None" STARTINCLINATION="-454;-9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721523435" ID="ID_679085788" MODIFIED="1538263469671" TEXT="dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1534721512505" ID="ID_1260021418" MODIFIED="1538778245658" TEXT="sofern es im Panel lebt, passiert das automatisch">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689146501" FOLDED="true" ID="ID_1371087868" MODIFIED="1561827469124" TEXT="bei Bedarf anzeigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534636343111" FOLDED="true" ID="ID_1922277957" MODIFIED="1561827464629" TEXT="ebenfalls explizit zu bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534636352398" ID="ID_435790811" MODIFIED="1538263469671" TEXT="ähnliche Lage wie bei Destroy">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GTK bietet nur Anzeigen von top-down:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
show_all() auf Containern zeigt rekursiv alle Kinder
|
|
</li>
|
|
<li>
|
|
show() zeigt nur ein bestimmtes Widget
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1534636369107" ID="ID_898428560" MODIFIED="1538574657332" TEXT="reveal / revealYourself">
|
|
<arrowlink COLOR="#76a4ad" DESTINATION="ID_232472679" ENDARROW="Default" ENDINCLINATION="94;307;" ID="Arrow_ID_634173548" STARTARROW="None" STARTINCLINATION="859;27;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1534636377938" FOLDED="true" ID="ID_64685935" MODIFIED="1561827464629" TEXT="Lumiera-Framework: Revealer">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1537499427673" ID="ID_671371282" MODIFIED="1538263469671" TEXT="#1162 helper abstractions for generic widgets">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534721937152" FOLDED="true" ID="ID_1396835945" MODIFIED="1561827464629" TEXT="macht aber nicht der Controller">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1534721946351" ID="ID_1570295012" MODIFIED="1538263469671" TEXT="typisches OO-Design"/>
|
|
<node CREATED="1534721955070" ID="ID_1390682663" MODIFIED="1538263469671" TEXT="der Controller ruft nur getWidget().reveal() auf">
|
|
<linktarget COLOR="#7691b1" DESTINATION="ID_1390682663" ENDARROW="Default" ENDINCLINATION="-71;33;" ID="Arrow_ID_1469414604" SOURCE="ID_558411855" STARTARROW="None" STARTINCLINATION="109;16;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533689138950" FOLDED="true" ID="ID_580572298" MODIFIED="1561827469125" TEXT="status-Flag">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1534722574441" FOLDED="true" ID="ID_558411855" MODIFIED="1561827464630" TEXT="delegiert an Widget">
|
|
<arrowlink COLOR="#7691b1" DESTINATION="ID_1390682663" ENDARROW="Default" ENDINCLINATION="-71;33;" ID="Arrow_ID_1469414604" STARTARROW="None" STARTINCLINATION="109;16;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node COLOR="#338800" CREATED="1534722791268" ID="ID_1074988560" MODIFIED="1538747845155" TEXT="Error-State">
|
|
<arrowlink COLOR="#87a5af" DESTINATION="ID_1501747643" ENDARROW="Default" ENDINCLINATION="54;212;" ID="Arrow_ID_512060720" STARTARROW="None" STARTINCLINATION="788;93;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534722566362" FOLDED="true" HGAP="29" ID="ID_202753412" MODIFIED="1561827464630" TEXT="sichtbar" VSHIFT="-18">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538756263572" ID="ID_1046625699" MODIFIED="1538756268712" TEXT="durch Button-Aktivierung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534119979555" FOLDED="true" ID="ID_1159164748" MODIFIED="1561827469146" TEXT="Controller-Interface">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534120150458" FOLDED="true" ID="ID_1083026482" MODIFIED="1561827469125" TEXT="Expander">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150459" ID="ID_1182032725" MODIFIED="1538263469672" TEXT=""Allocate Widget if necessary, expand widget"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535752333217" ID="ID_332486075" MODIFIED="1538263469672" TEXT="geeignet verdrahten für Delegation">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535752347574" ID="ID_883461261" MODIFIED="1538263469672" TEXT="Expander im ErrorLog widget verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150459" FOLDED="true" ID="ID_1466610963" MODIFIED="1561827469125" TEXT="doRevealYourself()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150460" ID="ID_1726008784" MODIFIED="1538574623534">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b><font color="#3d51ac">Lösung</font></b>: delegiere über zwei Stufen...
|
|
</p>
|
|
<p>
|
|
Neue <b>Revealer</b>-Komponente bindet einen Funktor
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#58c39d" DESTINATION="ID_1044092797" ENDARROW="Default" ENDINCLINATION="169;308;" ID="Arrow_ID_1805058492" STARTARROW="None" STARTINCLINATION="890;-197;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150457" FOLDED="true" ID="ID_1499287865" MODIFIED="1561827469125" TEXT="doReset()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150458" ID="ID_1390376483" MODIFIED="1538277278304" TEXT=""Clear log contents, collapse widget, clear error state"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150462" FOLDED="true" ID="ID_1528884346" MODIFIED="1561827469125" TEXT="doMsg(text)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150462" ID="ID_1226643824" MODIFIED="1538263469672" TEXT=""Possibly allocate Widget, place text into its buffer. No need to expand"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150463" FOLDED="true" ID="ID_183847307" MODIFIED="1561827469125" TEXT="doClearMsg()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150463" ID="ID_1378278687" MODIFIED="1538263469672" TEXT=""remove all mere information messages"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150463" FOLDED="true" ID="ID_1967851591" MODIFIED="1561827469125" TEXT="doErr(text)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150463" ID="ID_764543121" MODIFIED="1538263469672">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Set error state.
|
|
</li>
|
|
<li>
|
|
Allocate Widget if necessary
|
|
</li>
|
|
<li>
|
|
expand widget
|
|
</li>
|
|
<li>
|
|
place error message into its buffer"
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150464" FOLDED="true" ID="ID_1675673289" MODIFIED="1561827469125" TEXT="doClearErr()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150465" ID="ID_1858186015" MODIFIED="1538263469673" TEXT=""clear error state. If widget exists, turn all error entries into mere information entries"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531617621" FOLDED="true" ID="ID_447071799" MODIFIED="1561827469125" TEXT="doMark()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537531624828" ID="ID_52936917" MODIFIED="1538587791541" TEXT="Spezialbehandlung + Chain, um die Warnungs State-marks abzugreifen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534120150465" FOLDED="true" ID="ID_1862649971" MODIFIED="1561827469125" TEXT="doFlash()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534120150465" ID="ID_222097969" MODIFIED="1538263469673">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"If widget exists: expand it, trigger its flash function (paint with timeout).
|
|
</p>
|
|
<p>
|
|
<b><font color="#951c1c">TODO</font></b> also doRevealYourself."
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534334029619" ID="ID_1981930639" MODIFIED="1538756282446" TEXT="ErrorLogView vorläufig...">
|
|
<arrowlink COLOR="#628195" DESTINATION="ID_1745777873" ENDARROW="Default" ENDINCLINATION="245;349;" ID="Arrow_ID_1743659141" STARTARROW="None" STARTINCLINATION="397;197;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533689164394" ID="ID_405297881" MODIFIED="1538708568344" TEXT="in NotificationService integrieren">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533689225658" ID="ID_662017160" MODIFIED="1679362063151" TEXT="Pling! -Button">
|
|
<icon BUILTIN="full-5"/>
|
|
<node COLOR="#338800" CREATED="1533689235200" FOLDED="true" ID="ID_1760873318" MODIFIED="1567875759269" TEXT="non-modal TestControl">
|
|
<linktarget COLOR="#57b762" DESTINATION="ID_1760873318" ENDARROW="Default" ENDINCLINATION="-989;0;" ID="Arrow_ID_782679142" SOURCE="ID_994953692" STARTARROW="None" STARTINCLINATION="-756;-143;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537836495530" FOLDED="true" ID="ID_182389429" MODIFIED="1561827469125" TEXT="per Menüeintrag öffnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537841662854" ID="ID_451055929" MODIFIED="1538263469673" TEXT="Menüeintrag im Hilfe-Menü">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537841672261" ID="ID_1740266874" MODIFIED="1538263469673" TEXT="wird gemanaged vom Wizard">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537836597844" FOLDED="true" ID="ID_1217826524" MODIFIED="1561827469125" TEXT="Konstrukt wie im Tutorial">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537836612210" ID="ID_225351262" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-about-dialog.html.en#aboutdialog-example" MODIFIED="1538263469673" TEXT="non-modal about dialog">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1537838250303" FOLDED="true" ID="ID_1190002074" MODIFIED="1538263469673" TEXT="ist ein sub-window besser">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1537838265916" FOLDED="true" ID="ID_920100816" MODIFIED="1561827464644" TEXT="wie?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1537838337960" ID="ID_1900235846" MODIFIED="1537838337960" TEXT="set_transient_for (Window& parent)"/>
|
|
<node CREATED="1537838432423" FOLDED="true" ID="ID_1065922306" MODIFIED="1561827464644" TEXT="set_type_hint (Gdk::WindowTypeHint hint)">
|
|
<node CREATED="1537838435238" ID="ID_1301145489" MODIFIED="1537838439809" TEXT="nicht klar ob relevant"/>
|
|
</node>
|
|
<node CREATED="1537838544449" ID="ID_1666779438" LINK="https://developer.gnome.org/gtkmm/3.22/classGtk_1_1Window.html#a1f70b3c35e8c477ab3c1f9503a37a6a1" MODIFIED="1537838555867" TEXT="set_modal (bool modal=true)"/>
|
|
<node CREATED="1537838781593" MODIFIED="1537838781593" TEXT="property_destroy_with_parent ()"/>
|
|
</node>
|
|
<node CREATED="1537841505883" ID="ID_1112461783" MODIFIED="1537841514485" TEXT="geht wohl, ist aber etwas umständlich"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1537841516945" FOLDED="true" ID="ID_1578548739" MODIFIED="1561827464644" TEXT="Dialog-Basisklasse non-modal">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1537841531352" ID="ID_1190471518" MODIFIED="1538263469674" TEXT="hat eigene Konstruktoren, die den Dialog non-modal machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537841543886" ID="ID_59238198" MODIFIED="1538263469674" TEXT="regelt schon automatisch das Verhältnis zum Vaterfenster">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1537846114160" FOLDED="true" ID="ID_1907327221" MODIFIED="1561827464644" TEXT="Vorbild: Joel's PreferencesDialog">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1537848007082" ID="ID_1014258603" MODIFIED="1538263469674" TEXT="Notebook">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537848010330" ID="ID_1307971717" MODIFIED="1538263469674" TEXT="Seite einfügen für #1099">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537846129846" FOLDED="true" ID="ID_984655666" MODIFIED="1561827464644" TEXT="muß nur noch non-modal sein...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537847939155" ID="ID_1465508298" MODIFIED="1538263469674" TEXT="einfach per Gtk::DialogFlags">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1537847979886" ID="ID_1956886110" MODIFIED="1538263469674" TEXT="DIALOG_DESTROY_WITH_PARENT"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537836550411" FOLDED="true" ID="ID_899229612" MODIFIED="1561827469126" TEXT="hängt (passiv) am UI-Bus">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537848045781" ID="ID_766784189" MODIFIED="1538263469674" TEXT="analog zum NotificationService">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1537848056915" ID="ID_64593877" MODIFIED="1538263469674" TEXT="globals.uiBus_.getAccessPoint()">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537961550200" FOLDED="true" ID="ID_226231657" MODIFIED="1561827469126" TEXT="setup für Notebook-Widget">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1537961568746" ID="ID_1553519505" MODIFIED="1538263469674" TEXT="Prototyp für generischen Helper">
|
|
<arrowlink COLOR="#6ea8be" DESTINATION="ID_591860371" ENDARROW="Default" ENDINCLINATION="1162;51;" ID="Arrow_ID_1534615646" STARTARROW="None" STARTINCLINATION="-185;836;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537836522950" ID="ID_87203159" MODIFIED="1538263469674" TEXT="Radiobuttons">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537834955977" ID="ID_556296967" MODIFIED="1538263469674" TEXT="Argument-Textbox">
|
|
<arrowlink COLOR="#19f524" DESTINATION="ID_1072038781" ENDARROW="Default" ENDINCLINATION="-7;-200;" ID="Arrow_ID_746117643" STARTARROW="None" STARTINCLINATION="94;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537836579647" FOLDED="true" ID="ID_951515368" MODIFIED="1561827469126" TEXT="Pling!">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537972817468" FOLDED="true" ID="ID_443954725" MODIFIED="1538263469674" TEXT="direkt den UI-Bus ansprechen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1537973078631" ID="ID_476903403" MODIFIED="1537973140285" TEXT="*** first tangible action sent via UI-Bus ***">
|
|
<font NAME="SansSerif" SIZE="28"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537848127378" ID="ID_1206004" MODIFIED="1538263469674" TEXT="Argument-Werte abgreifen">
|
|
<arrowlink COLOR="#47ebbb" DESTINATION="ID_1745090225" ENDARROW="Default" ENDINCLINATION="119;0;" ID="Arrow_ID_372783230" STARTARROW="None" STARTINCLINATION="-10;35;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689243871" FOLDED="true" ID="ID_1745090225" MODIFIED="1561827469146" TEXT="triggert Dummy-Command">
|
|
<linktarget COLOR="#47ebbb" DESTINATION="ID_1745090225" ENDARROW="Default" ENDINCLINATION="119;0;" ID="Arrow_ID_372783230" SOURCE="ID_1206004" STARTARROW="None" STARTINCLINATION="-10;35;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1538220904703" FOLDED="true" HGAP="46" ID="ID_1997338106" MODIFIED="1561827469126" TEXT="definieren..." VSHIFT="31">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1538220944278" ID="ID_1508594379" MODIFIED="1538263469674" TEXT="test_meta_displayInfo">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538220949651" ID="ID_1282771011" MODIFIED="1538263469674" TEXT="test_meta_markError">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538220955266" ID="ID_1011451863" MODIFIED="1538263469674" TEXT="test_meta_markNote">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538220961641" ID="ID_1936475731" MODIFIED="1538263469674" TEXT="test_meta_markAction">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533689255174" FOLDED="true" ID="ID_821013695" MODIFIED="1561827469146" TEXT="Aufruf via Notification_Facade">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537835197558" FOLDED="true" ID="ID_1477928890" MODIFIED="1561827469126" TEXT="displayInfo">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537977715375" ID="ID_26283848" MODIFIED="1538263469675" TEXT="INFO">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537977721054" ID="ID_1182006449" MODIFIED="1538263469675" TEXT="WARN">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537977723454" ID="ID_484673349" MODIFIED="1538263469675" TEXT="ERROR">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835015601" FOLDED="true" ID="ID_1684094906" MODIFIED="1561827469126" TEXT="direkte Bus-Aufrufe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537835220978" ID="ID_1439086949" MODIFIED="1538263469675" TEXT="markError">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835228018" ID="ID_1420898810" MODIFIED="1538263469675" TEXT="markNote">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835741000" FOLDED="true" ID="ID_1072038781" MODIFIED="1561827464648" TEXT="mark">
|
|
<linktarget COLOR="#19f524" DESTINATION="ID_1072038781" ENDARROW="Default" ENDINCLINATION="-7;-200;" ID="Arrow_ID_746117643" SOURCE="ID_556296967" STARTARROW="None" STARTINCLINATION="94;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537835767228" ID="ID_400466516" MODIFIED="1538263469675" TEXT="FLASH">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835848674" ID="ID_1915433481" MODIFIED="1538263469675" TEXT="REVEAL">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538239665856" FOLDED="true" ID="ID_518505874" MODIFIED="1538574272012" TEXT="EXPAND">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1538281532767" ID="ID_1335570495" MODIFIED="1538365732115" TEXT="Fehler: muß eigens separate GenNode bauen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil der Payload-Typ für diesen Aufruf bool ist,
|
|
</p>
|
|
<p>
|
|
und nicht string wie für alle anderen state marks
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538281608933" FOLDED="true" ID="ID_584897977" MODIFIED="1561827464648" TEXT="muß bool parsen...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538281635897" FOLDED="true" ID="ID_562945035" MODIFIED="1561827464647" TEXT="lexical_cast geht nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
k
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538281655774" ID="ID_1847834965" MODIFIED="1538281662977" TEXT="kann nur 1 und 0"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1538281664349" FOLDED="true" ID="ID_1454517361" MODIFIED="1538441787807" TEXT="interessanter Folgefehler">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1538281691097" FOLDED="true" ID="ID_1911272932" MODIFIED="1561827464645" TEXT="exception killt ProcDispatcher (das ist OK)">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1538316932460" FOLDED="true" ID="ID_532178252" MODIFIED="1561827464645" TEXT="warum läuft das über HandlingPattern?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538316947954" ID="ID_299870867" MODIFIED="1538316961132" TEXT="dachte, wir rufen Dummy-Commands direkt auf"/>
|
|
<node CREATED="1538317636429" ID="ID_555373711" MODIFIED="1538317640326" TEXT="tun wir auch">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1538317641621" ID="ID_1808679252" MODIFIED="1538317662923" TEXT="aber proc::Command verwendet Default-Pattern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538316971295" FOLDED="true" ID="ID_1865988337" MODIFIED="1561827464645" TEXT="Abgreifen der Fehler-Info">
|
|
<node CREATED="1538316982046" ID="ID_252583984" MODIFIED="1538317000205" STYLE="fork" TEXT="im std::exception-Handler">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1538317002019" FOLDED="true" ID="ID_957898086" MODIFIED="1561827464645" TEXT="lumiera::Error">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1538356729852" FOLDED="true" ID="ID_435503551" MODIFIED="1538356803291" TEXT="wird die cause korrekt übernommen?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538356756336" ID="ID_342508440" MODIFIED="1538356782737" TEXT="ja... works as designed">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1538356761143" ID="ID_1729059066" MODIFIED="1538356797681">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konzept ist <i>nicht</i>, sie gleich in die description zu übernehmen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538317075985" FOLDED="true" ID="ID_712272839" MODIFIED="1538365661558" TEXT="Problem: lumiera Error-Flag übernimmt nur lokale description">
|
|
<linktarget COLOR="#c4588d" DESTINATION="ID_712272839" ENDARROW="Default" ENDINCLINATION="577;63;" ID="Arrow_ID_428347507" SOURCE="ID_313278942" STARTARROW="None" STARTINCLINATION="341;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538317102405" ID="ID_1770156379" MODIFIED="1538317106320" TEXT="und die ist hier leer"/>
|
|
<node CREATED="1538317107765" ID="ID_1730697631" MODIFIED="1538317122431" TEXT="sollte unsere what()-Methode nutzen"/>
|
|
<node CREATED="1538317157966" FOLDED="true" ID="ID_600719509" MODIFIED="1561827464645" TEXT="Problem: Storage">
|
|
<node CREATED="1538317171852" FOLDED="true" ID="ID_1284960080" MODIFIED="1561827464645" TEXT="verwende Symbol">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538317176347" ID="ID_1919150970" MODIFIED="1538317201070" TEXT="wat soll der jeiz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das System ist ohnehin schon angetötet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538317544954" ID="ID_1154202054" MODIFIED="1538317573410">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
keines! Impl verwendet <b>strdup</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538318187819" FOLDED="true" ID="ID_870746075" MODIFIED="1538365651376" TEXT="Problem: ExecResult nicht ausgewertet">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538318216016" ID="ID_1444888451" MODIFIED="1538318226226" TEXT="Exception wird nicht ausgeworfen"/>
|
|
<node CREATED="1538318227150" ID="ID_956176289" MODIFIED="1538318230994" TEXT="Loop läuft weiter"/>
|
|
<node CREATED="1538318231726" FOLDED="true" ID="ID_373021764" MODIFIED="1561827464645" TEXT="aber Error-State ist gesetzt">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538319081491" FOLDED="true" ID="ID_599527376" MODIFIED="1561827464645" TEXT="das ist ein Logik-Fehler">
|
|
<linktarget COLOR="#e54f84" DESTINATION="ID_599527376" ENDARROW="Default" ENDINCLINATION="-9;283;" ID="Arrow_ID_1159234155" SOURCE="ID_1536519871" STARTARROW="None" STARTINCLINATION="411;-47;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538319099993" ID="ID_1362819933" MODIFIED="1538319118146" TEXT="da Exception in einem ExecResult gespeicher ist"/>
|
|
<node CREATED="1538319119398" ID="ID_1062993543" MODIFIED="1538319129753" TEXT="...gilt sie nicht mehr als "schwebend""/>
|
|
<node CREATED="1538319130725" ID="ID_1118929704" MODIFIED="1538319141433" TEXT="der Aufrufer hat volle Freiheit, sie zu ignorieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538318997502" ID="ID_1664562023" MODIFIED="1538319007145" TEXT="wacht nach max-timeout (für Builder auf)"/>
|
|
<node CREATED="1538319008117" FOLDED="true" ID="ID_73040538" MODIFIED="1561827464645" TEXT="unser Object-Monitor prüft beim Aufwachen den Error-state">
|
|
<node CREATED="1538319150290" ID="ID_313278942" MODIFIED="1538319185279" TEXT="und wirft hier nur noch die verkürzte Description aus">
|
|
<arrowlink COLOR="#c4588d" DESTINATION="ID_712272839" ENDARROW="Default" ENDINCLINATION="577;63;" ID="Arrow_ID_428347507" STARTARROW="None" STARTINCLINATION="341;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538319193716" ID="ID_1785359217" MODIFIED="1538319206846" TEXT="...das erklärt, warum wir die Ursache nicht sehen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538319456089" FOLDED="true" ID="ID_342927310" MODIFIED="1538365654527" TEXT="Problem: Handler im ProcDispatcher behandelt nur LumieraException speziell">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538319495420" ID="ID_39746243" MODIFIED="1538319501623" TEXT="das stellt zwar hier kein Problem dar"/>
|
|
<node CREATED="1538319502331" ID="ID_1092806315" MODIFIED="1538319511413" TEXT="und es ist noch der unspezifische Handler da"/>
|
|
<node CREATED="1538319512146" ID="ID_672632423" MODIFIED="1538319533231" TEXT="aber: problem.what() geht verloren bei std::exception">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538319535006" ID="ID_403817336" MODIFIED="1538365635663" TEXT="Fix: Handler kann genausogut auf std::exception abstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir verwenden das Lumiera-Exception-API gar nicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538281708919" FOLDED="true" ID="ID_1611370738" MODIFIED="1561827464646" TEXT="error state ist gesetzt">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1538319670284" ID="ID_1536519871" MODIFIED="1538319694106" TEXT="geklärt warum">
|
|
<arrowlink COLOR="#e54f84" DESTINATION="ID_599527376" ENDARROW="Default" ENDINCLINATION="-9;283;" ID="Arrow_ID_1159234155" STARTARROW="None" STARTINCLINATION="411;-47;"/>
|
|
</node>
|
|
<node CREATED="1538319701680" ID="ID_1856422179" MODIFIED="1538319729311" TEXT="...und beim Trigger ist er schon nicht mehr gesetzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Handler im ProcDispatcher sorgt dafür
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538281715646" FOLDED="true" ID="ID_1541383645" MODIFIED="1561827464646" TEXT="emergency shutdown">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1538320876787" FOLDED="true" ID="ID_1528655784" MODIFIED="1561827464646" TEXT="Subsystem-Shutdown">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538320884769" FOLDED="true" ID="ID_707965628" MODIFIED="1538365685651" TEXT="Problem: re-entrance Bug">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1538320904127" FOLDED="true" ID="ID_1958182633" MODIFIED="1561827464646" TEXT="shutdownAll() ruft indirekt/rekursiv sigTerm()">
|
|
<node COLOR="#435e98" CREATED="1538321043388" ID="ID_1860084270" MODIFIED="1538348459443" TEXT="fragt sich, warum">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1538321059074" FOLDED="true" ID="ID_1754741024" MODIFIED="1561827464646" TEXT="Vermutung: degeneriertes Subsystem">
|
|
<node CREATED="1538321102148" ID="ID_862751524" MODIFIED="1538321102148">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welches keinen separaten Thread aufruft....?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1538321104964" ID="ID_990799680" MODIFIED="1538321198833" TEXT="...und daher das Lock auf dem Subsystem-Runner bekommt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538348464066" ID="ID_1973011292" MODIFIED="1538348489286" TEXT="genau so isses (...und ich hatte vor Jahren schon ein Ticket aufgemacht)">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538348427367" ID="ID_1696230148" MODIFIED="1538348438054" TEXT="#814 subsystem-runner: re-entrance in triggerShutdown">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1538320933291" ID="ID_573672353" MODIFIED="1538320975419" TEXT="removeall auf Collection, die grade iteriert wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich im shutdownAll() weiter oben im Stack
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1538320996027" FOLDED="true" ID="ID_1914116148" MODIFIED="1561827464646" TEXT="STL verhält sich hier anscheinend gutmütig">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538348518843" ID="ID_613222856" MODIFIED="1538348551658" TEXT="zwar wird einer Iteration ggfs das aktuelle Element "unter den Füßen" weggezogen..."/>
|
|
<node CREATED="1538348553006" ID="ID_1259043030" MODIFIED="1538348566936" TEXT="so daß dann die nächste Iteration das übernächste Element bearbeitet"/>
|
|
<node CREATED="1538348577763" ID="ID_830173416" MODIFIED="1538348597359">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber <i>genau der andere Thread,</i> der das gemacht hat...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1538348598352" ID="ID_1090786435" MODIFIED="1538348613234" TEXT="iteriert als nächstes ebenfalls über alle Subsysteme"/>
|
|
<node CREATED="1538348625836" ID="ID_507678251" MODIFIED="1538348638230" TEXT="Fazit: Killen bis zur erschöpfung"/>
|
|
<node CREATED="1538348639034" ID="ID_1799262325" MODIFIED="1538348644065" TEXT="läuft">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538322674991" FOLDED="true" ID="ID_371763142" MODIFIED="1538365689019" TEXT="Problem: triggerShutdown nicht wasserdicht">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538322708227" FOLDED="true" ID="ID_1994833744" MODIFIED="1561827464646" TEXT="kann sterben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1538322737871" ID="ID_513027050" MODIFIED="1538322769742" TEXT="wenn Exceptions auftreten">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538322751893" ID="ID_812762539" MODIFIED="1538322767299" TEXT="z.B. wenn Gui-Facade schon zu ist">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538322721289" ID="ID_156783463" MODIFIED="1538322775541" TEXT="dann läuft das aufrufende sigTerm nicht zuende">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1538359359513" FOLDED="true" ID="ID_874296398" MODIFIED="1561827464646" TEXT="Nein kein Problem">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1538359370815" ID="ID_104358783" MODIFIED="1538359518690" TEXT="das Subsystem-Protokoll verlangt noexcept">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538359382397" ID="ID_1054464710" MODIFIED="1538359515533" TEXT="alle bekannten triggerShutdown sind so gekennzeichnet">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1538359397915" ID="ID_446614054" MODIFIED="1538359507892" TEXT="und wenn trotzdem eine Exception fliegt...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dann sind wir sofort tot und das wird billigend in Kauf genommen.
|
|
</p>
|
|
<p>
|
|
So ist das tatsächlich implementiert im Falle vom OutputDirector.
|
|
</p>
|
|
<p>
|
|
Der startet nämlich einen Thread erst als Supervisor für den Shutdown.
|
|
</p>
|
|
<p>
|
|
Wenn das nun <i>wirklich</i> fehlschlägt, bleibt uns sinnvollerweise nur noch die Selbstmord-Option
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538357436900" FOLDED="true" ID="ID_1015844071" MODIFIED="1561827464646" TEXT="der ganze Subsystem-Runner sollte überarbeitet werden">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538357457297" ID="ID_1518496949" MODIFIED="1538357462577" TEXT="#1177 Subsytem-Runner design rework">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538281733340" ID="ID_1326729675" MODIFIED="1538281765434" TEXT="fährt das GUI runter">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node CREATED="1538281741419" FOLDED="true" ID="ID_1964821489" MODIFIED="1561827464647">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein <b>ZombieCheck</b> spricht an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-5"/>
|
|
<node COLOR="#435e98" CREATED="1538281782245" FOLDED="true" ID="ID_888818129" MODIFIED="1561827464646" TEXT="welcher...">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1538326229581" ID="ID_687910017" MODIFIED="1538326243254" TEXT="mit dem Debugger nicht zu fassen...."/>
|
|
<node COLOR="#338800" CREATED="1538326244075" ID="ID_362650638" MODIFIED="1538365389966" TEXT="Aufgabe: Zobmie-ID statisch speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538365422252" FOLDED="true" ID="ID_1782663880" MODIFIED="1561827464646" TEXT="Offender = ClassLock<gui::interact::LocationQuery>">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0000001180: INFO: subsystem-runner.hpp:208: worker_3: sigTerm: Subsystem 'Lumiera GTK GUI' terminated.
|
|
</p>
|
|
<p>
|
|
0000001181: NOTICE: appstate.cpp:170: thread_1: maybeWait: Shutting down Lumiera...
|
|
</p>
|
|
<p>
|
|
0000001182: ALERT: appstate.cpp:174: thread_1: maybeWait: Triggering emergency exit...
|
|
</p>
|
|
<p>
|
|
0000001243: WARNING: interfaceregistry.c:199: thread_1: lumiera_interfaceregistry_bulkremove_interfaces: ENTRY NOT FOUND in interfaceregistry at clean-up of interface lumieraorg_Gui, instance lumieraorg_GuiStarterPlugin
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:9719): Gtk-CRITICAL **: gtk_widget_is_drawable: assertion 'GTK_IS_WIDGET (widget)' failed
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:9719): Pango-CRITICAL **: pango_layout_get_cursor_pos: assertion 'index >= 0 && index <= layout->length' failed
|
|
</p>
|
|
<p>
|
|
0000001293: ERR: error-exception.cpp:185: worker_3: lumiera_unexpectedException: ### Lumiera halted due to an unexpected Error ###
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
### Lumiera halted due to an unexpected Error ###
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
+++ Caught Exception LUMIERA_ERROR_LIFECYCLE:Lifecycle assumptions violated
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
0000001298: ERR: error-exception.cpp:196: worker_3: lumiera_unexpectedException: +++ caught error::LumieraError<error::LUMIERA_ERROR_FATAL, error::LumieraError<error::LUMIERA_ERROR_LOGIC, Error> >
|
|
</p>
|
|
<p>
|
|
0000001298! ERR: error-exception.cpp:196: worker_3: lumiera_unexpectedException: +++ messg: Sorry, Lumiera encountered an internal error.
|
|
</p>
|
|
<p>
|
|
0000001298! ERR: error-exception.cpp:196: worker_3: lumiera_unexpectedException: +++ descr: LUMIERA_ERROR_LIFECYCLE:Lifecycle assumptions violated (Already deceased object called out of order during Application shutdown. Lumiera Policy violated: Dependencies must not be used from destructors. Offender = ClassLock<gui::interact::LocationQuery, s).
|
|
</p>
|
|
<p>
|
|
0000001299: ERR: error-exception.cpp:212: worker_3: lumiera_unexpectedException: last registered error was....
|
|
</p>
|
|
<p>
|
|
0000001299! ERR: error-exception.cpp:212: worker_3: lumiera_unexpectedException: LUMIERA_ERROR_LIFECYCLE:Lifecycle assumptions violated
|
|
</p>
|
|
<p>
|
|
Abgebrochen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538365543884" ID="ID_534885692" MODIFIED="1538365573259" TEXT="man beachte auch die zwei GTK-Assertions nach dem GUI-Shutdown">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1538365584159" ID="ID_998255150" MODIFIED="1538365599464" TEXT="wieso läuft da noch GUI-code??"/>
|
|
<node CREATED="1538437336885" ID="ID_1889101831" MODIFIED="1538437644906" TEXT="Beobachtung: worker_3 == GUI-Thread gewesen">
|
|
<arrowlink COLOR="#d21052" DESTINATION="ID_1886197899" ENDARROW="Default" ENDINCLINATION="38;-127;" ID="Arrow_ID_274941451" STARTARROW="None" STARTINCLINATION="-156;4;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538281788117" FOLDED="true" ID="ID_1747014683" MODIFIED="1561827464647" TEXT="wie konnte das passieren....">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538436917958" ID="ID_1974415924" MODIFIED="1538436933975" TEXT="sehr wahrscheinlich ein lib::Depend<LocationQuery>"/>
|
|
<node CREATED="1538436940187" FOLDED="true" ID="ID_691937310" MODIFIED="1561827464646" TEXT="in Frage kommen....">
|
|
<node CREATED="1538436955585" ID="ID_508170245" MODIFIED="1538436971250" TEXT="ViewLocator::locResolver_"/>
|
|
<node CREATED="1538437006170" ID="ID_282885180" MODIFIED="1538437018876" TEXT="UILocationSolver::getLocationQuery"/>
|
|
<node CREATED="1538437047572" FOLDED="true" ID="ID_230833452" MODIFIED="1561827464646" TEXT="LocationQuery::service">
|
|
<node CREATED="1538437082776" ID="ID_184252441" MODIFIED="1538437093282" TEXT="lebt in ui-coord-resolver.cpp"/>
|
|
</node>
|
|
<node CREATED="1538437140312" FOLDED="true" ID="ID_1998433336" MODIFIED="1561827464646" TEXT="InteractionDirector::navigator_">
|
|
<node CREATED="1538437158909" ID="ID_1706438738" MODIFIED="1538437159929" TEXT="= lib::DependInject<LocationQuery>::ServiceInstance<Navigator>"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538437605225" FOLDED="true" ID="ID_1886197899" MODIFIED="1561827464647" TEXT="Verdacht: dtor-Race">
|
|
<arrowlink COLOR="#e24165" DESTINATION="ID_1236741743" ENDARROW="Default" ENDINCLINATION="-145;6;" ID="Arrow_ID_1521104972" STARTARROW="None" STARTINCLINATION="-19;77;"/>
|
|
<linktarget COLOR="#d21052" DESTINATION="ID_1886197899" ENDARROW="Default" ENDINCLINATION="38;-127;" ID="Arrow_ID_274941451" SOURCE="ID_1889101831" STARTARROW="None" STARTINCLINATION="-156;4;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538437664345" FOLDED="true" ID="ID_1713946380" MODIFIED="1561827464647" TEXT="Szenario">
|
|
<node CREATED="1538437672401" ID="ID_1788050505" MODIFIED="1538437844014" TEXT="Gui: sigTerm aufgerufen">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1538437682015" ID="ID_1413705214" MODIFIED="1538437846332" TEXT="letztes Subsys -> räumt alle Subsysteme weg">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1538437706876" ID="ID_1187411887" MODIFIED="1538437848750" TEXT="main-Thread wacht auf">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1538437715874" ID="ID_691753107" MODIFIED="1538437851846" TEXT="verläßt main() und entläd das Plug-In">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node CREATED="1538437741751" ID="ID_510852039" MODIFIED="1538437854073" TEXT="das zerstört die statische Factory">
|
|
<icon BUILTIN="full-5"/>
|
|
</node>
|
|
<node CREATED="1538437749950" ID="ID_1236741743" MODIFIED="1538440181061" TEXT="Gui-Thread kehr aus sigTerm zurück und ruft ~UiManager()">
|
|
<linktarget COLOR="#e24165" DESTINATION="ID_1236741743" ENDARROW="Default" ENDINCLINATION="-145;6;" ID="Arrow_ID_1521104972" SOURCE="ID_1886197899" STARTARROW="None" STARTINCLINATION="-19;77;"/>
|
|
<icon BUILTIN="full-6"/>
|
|
</node>
|
|
<node CREATED="1538437785489" ID="ID_1853884803" MODIFIED="1538437858984" TEXT="indirekt deregistriert InteractionDirector den Service">
|
|
<icon BUILTIN="full-7"/>
|
|
</node>
|
|
<node CREATED="1538437812598" FOLDED="true" ID="ID_407685604" MODIFIED="1561827464647" TEXT="DependInject::Service::shutdown() greift sich das Lock">
|
|
<icon BUILTIN="full-8"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1538437831603" ID="ID_822519118" MODIFIED="1538437839823" TEXT="BOOM">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538440214523" FOLDED="true" HGAP="1" ID="ID_390044012" MODIFIED="1561827464647" TEXT="Umbau daraufhin" VSHIFT="21">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1538440224730" ID="ID_973914173" MODIFIED="1538440241131" TEXT="sigTerm-Aufruf aus der run()-Methode herausziehen"/>
|
|
<node CREATED="1538440242999" ID="ID_815144668" MODIFIED="1538440276578">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
..damit ~GtkLumiera() garantiert <i>vorher</i> aufgerufen wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538440332187" FOLDED="true" HGAP="-48" ID="ID_393079011" MODIFIED="1561827464647" TEXT="Treffer, versenkt" VSHIFT="27">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1538440346730" ID="ID_1456330609" MODIFIED="1538440482615" TEXT="Fehler ist verschwunden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0000001028: INFO: proc-dispatcher.cpp:301: worker_2: processCommands: +++ dispatch Command("test_meta_markAction") {exec}
|
|
</p>
|
|
<p>
|
|
0000001029: INFO: proc-dispatcher.cpp:306: worker_2: processCommands: +++ -------->>> bang!
|
|
</p>
|
|
<p>
|
|
0000001031: WARNING: handling-pattern.cpp:90: worker_2: invoke: Invocation of Command("test_meta_markAction") {exec} failed: bad lexical cast: source type value could not be interpreted as target
|
|
</p>
|
|
<p>
|
|
0000001052: INFO: proc-dispatcher.cpp:159: worker_2: ~DispatcherLoop: Proc-Dispatcher stopped.
|
|
</p>
|
|
<p>
|
|
0000001053: INFO: subsystem-runner.hpp:208: worker_2: sigTerm: Subsystem 'Session' terminated.
|
|
</p>
|
|
<p>
|
|
0000001054: WARNING: subsystem-runner.hpp:209: worker_2: sigTerm: Irregular shutdown caused by: LUMIERA_ERROR_LOGIC:internal logic broken (Command execution failed: LUMIERA_ERROR_EXTERNAL:failure in external service -- caused by: bad lexical cast: source type value could not be interpreted as target).
|
|
</p>
|
|
<p>
|
|
0000001090: TODO: output-director.cpp:136: worker_4: bringDown: actually bring down the output generation
|
|
</p>
|
|
<p>
|
|
0000001091: INFO: subsystem-runner.hpp:208: worker_2: sigTerm: Subsystem 'Dummy-Player' terminated.
|
|
</p>
|
|
<p>
|
|
0000001092: NOTICE: notification-service.cpp:158: worker_2: triggerGuiShutdown: @GUI: shutdown triggered with explanation 'Application shutdown'....
|
|
</p>
|
|
<p>
|
|
0000001111: NOTICE: notification-service.cpp:158: worker_2: triggerGuiShutdown: @GUI: shutdown triggered with explanation 'Application shutdown'....
|
|
</p>
|
|
<p>
|
|
0000001119: INFO: subsystem-runner.hpp:208: worker_4: sigTerm: Subsystem 'PlayOut' terminated.
|
|
</p>
|
|
<p>
|
|
0000001120: NOTICE: notification-service.cpp:158: worker_4: triggerGuiShutdown: @GUI: shutdown triggered with explanation 'Application shutdown'....
|
|
</p>
|
|
<p>
|
|
0000001128: INFO: display-service.hpp:147: worker_3: ~DisplayService: Display service dying...
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Gtk-CRITICAL **: gtk_widget_is_drawable: assertion 'GTK_IS_WIDGET (widget)' failed
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Pango-CRITICAL **: pango_layout_get_cursor_pos: assertion 'index >= 0 && index <= layout->length' failed
|
|
</p>
|
|
<p>
|
|
0000001160: INFO: workspace-window.cpp:53: worker_3: ~WorkspaceWindow: Closing workspace window...
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Gdl-CRITICAL **: gdl_dock_master_get_controller: assertion 'master != NULL' failed
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Gdl-CRITICAL **: gdl_dock_master_get_controller: assertion 'master != NULL' failed
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Gdl-CRITICAL **: gdl_dock_master_get_controller: assertion 'master != NULL' failed
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
(lumiera:12160): Gdl-CRITICAL **: gdl_dock_master_get_controller: assertion 'master != NULL' failed
|
|
</p>
|
|
<p>
|
|
0000001167: INFO: subsystem-runner.hpp:208: worker_3: sigTerm: Subsystem 'Lumiera GTK GUI' terminated.
|
|
</p>
|
|
<p>
|
|
0000001175: NOTICE: appstate.cpp:170: thread_1: maybeWait: Shutting down Lumiera...
|
|
</p>
|
|
<p>
|
|
0000001176: ALERT: appstate.cpp:174: thread_1: maybeWait: Triggering emergency exit...
|
|
</p>
|
|
<p>
|
|
0000001237: WARNING: interfaceregistry.c:199: thread_1: lumiera_interfaceregistry_bulkremove_interfaces: ENTRY NOT FOUND in interfaceregistry at clean-up of interface lumieraorg_Gui, instance lumieraorg_GuiStarterPlugin
|
|
</p>
|
|
<p>
|
|
(hiv)~/devel/lumi-$
|
|
</p>
|
|
<p>
|
|
(hiv)~/devel/lumi-$
|
|
</p>
|
|
<p>
|
|
(hiv)~/devel/lumi-$ echo $?
|
|
</p>
|
|
<p>
|
|
2
|
|
</p>
|
|
<p>
|
|
(hiv)~/devel/lumi-$
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538440505597" ID="ID_1015433202" MODIFIED="1538440524651" TEXT="#1178 Zombie race in GUI Subsystem shutdown">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538441813086" ID="ID_431066008" MODIFIED="1538533883011" TEXT="neue Hilfsfunktion in util.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538533891029" ID="ID_1886289594" MODIFIED="1538533896858" TEXT="Test hierfür">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835859576" ID="ID_968868056" MODIFIED="1538263469675" TEXT="CLEAR_ERR">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835874382" ID="ID_252957072" MODIFIED="1538263469675" TEXT="CLEAR_MSG">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835880405" ID="ID_992909467" MODIFIED="1538263469675" TEXT="RESET">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537835889996" ID="ID_5762574" MODIFIED="1538263469675" TEXT="GenNode">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538230509179" FOLDED="true" HGAP="22" ID="ID_657255465" MODIFIED="1538263469675" TEXT="Problem ID-Übergabe" VSHIFT="14">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1538230525641" ID="ID_1999133642" MODIFIED="1538230536846" TEXT="wieder mal das Scheiß Interface-System">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1538230675997" ID="ID_1672501842" MODIFIED="1538232718759" TEXT="bräuchte eine C-Repräsentation für BareEntryID"/>
|
|
<node CREATED="1538232816534" ID="ID_712541347" MODIFIED="1538232905703" TEXT="habe den Anspruch aber bereits aufgegeben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar an dem Punkt, an dem ich eine DiffMessage in das GUI schicke.
|
|
</p>
|
|
<p>
|
|
DiffMessage repräsentiert einen für den User verdeckten Callback
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538234760471" ID="ID_1256781554" MODIFIED="1538234766447" TEXT="#1175 consider EntryID as external entity ID">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721737507" FOLDED="true" ID="ID_1467431829" MODIFIED="1561827482908" TEXT="verifizieren">
|
|
<icon BUILTIN="full-6"/>
|
|
<node COLOR="#338800" CREATED="1538234826126" ID="ID_1989018475" MODIFIED="1538263469675" TEXT="Round-Trip über Thrad-Grenzen hinweg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538234843916" ID="ID_1672079020" MODIFIED="1538263469675" TEXT="Argument-Übergabe per Kopie">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721764680" ID="ID_237796687" MODIFIED="1538777025274" TEXT="Belegen der View">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538747863296" ID="ID_1171544173" MODIFIED="1538777026741" TEXT="Reaktion auf Error-state">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721772238" ID="ID_130695962" MODIFIED="1538777041184" TEXT="Verbinden mit bestehendem InfoboxPanel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721811969" ID="ID_1320259895" MODIFIED="1538777615902" TEXT="auch in einerm anderen Fenster">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721785596" ID="ID_1517054985" MODIFIED="1538777054390" TEXT="Erzeugen eines neuen InfoboxPanels">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534721819264" ID="ID_1360416196" MODIFIED="1538778252025" TEXT="Panel durch Ersetzung zerstören">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1360416196" ENDARROW="Default" ENDINCLINATION="417;34;" ID="Arrow_ID_1337668046" SOURCE="ID_1984401497" STARTARROW="None" STARTINCLINATION="-454;-9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531073966" FOLDED="true" ID="ID_973305985" MODIFIED="1561827469146" TEXT="Funktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537531078757" ID="ID_605735534" MODIFIED="1538708629270" TEXT="Reset">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531084396" ID="ID_648584085" MODIFIED="1538708616965" TEXT="Meldung ausgeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531543495" ID="ID_1813117782" MODIFIED="1538708618921" TEXT="Warnung anzeigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531109361" ID="ID_1483169066" MODIFIED="1538708620397" TEXT="Fehler ausgeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531089012" ID="ID_1427238207" MODIFIED="1538708630612" TEXT="alle Meldungen entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531153739" ID="ID_538123549" MODIFIED="1538708632010" TEXT="Fehler in Meldungen verwandeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537531160298" ID="ID_1717013245" MODIFIED="1538708633930" TEXT="Flash">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537532006073" FOLDED="true" HGAP="-92" ID="ID_135756255" MODIFIED="1561827483825" TEXT="Neben-Nutzen" VSHIFT="15">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537532035141" ID="ID_188521578" MODIFIED="1538263469676" TEXT="NotificationService">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537532041420" ID="ID_1545300987" MODIFIED="1538263469676" TEXT="Implementierung komplettieren">
|
|
<arrowlink COLOR="#22ed6f" DESTINATION="ID_1901801971" ENDARROW="Default" ENDINCLINATION="287;0;" ID="Arrow_ID_1609281182" STARTARROW="None" STARTINCLINATION="83;-25;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537532447549" ID="ID_821848615" MODIFIED="1538263469676" TEXT="Fehleranzeige-Funktion">
|
|
<arrowlink COLOR="#c19dc4" DESTINATION="ID_149796171" ENDARROW="Default" ENDINCLINATION="1300;76;" ID="Arrow_ID_451002492" STARTARROW="None" STARTINCLINATION="1509;156;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537532456004" ID="ID_1700828304" MODIFIED="1538839492410" TEXT="dokumentieren und Ticket #1047 schließen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538836931857" ID="ID_438461567" MODIFIED="1538839523006" TEXT="#1174 kann auch geschlossen werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
#1174 UI self diagnostics window
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1484797684438" FOLDED="true" HGAP="21" ID="ID_932852399" MODIFIED="1576282358153" TEXT="GUI-Shutdown implementieren" VSHIFT="13">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bisher können wir das GUI nur <i>aktiv intern</i> schließen,
|
|
</p>
|
|
<p>
|
|
indem wir ein GTK-Signal erzeugen, das das Hauptfenster schließt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485116867963" ID="ID_1146024699" MODIFIED="1518487921054" TEXT="bisher kann man nur das Fenster schließen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1485116884925" ID="ID_296160451" MODIFIED="1518487921055" TEXT="wie funktioniert das?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1485116901507" ID="ID_1272809751" MODIFIED="1518487921055" TEXT="WindowManager">
|
|
<node COLOR="#338800" CREATED="1485126609878" ID="ID_649614174" MODIFIED="1518487921055" TEXT="#1064 investigate WindowManager lifecycle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485116921072" ID="ID_1191743111" MODIFIED="1518487921055" TEXT="close Action"/>
|
|
</node>
|
|
<node CREATED="1484797749237" ID="ID_1654016697" MODIFIED="1518487921055" TEXT="wie kann man GTK-UI explizit schließen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1501777017858" ID="ID_842367237" MODIFIED="1518487921055" TEXT="wer macht das in unserem GUI?">
|
|
<arrowlink DESTINATION="ID_599315721" ENDARROW="Default" ENDINCLINATION="-137;-12;" ID="Arrow_ID_1743989671" STARTARROW="None" STARTINCLINATION="-18;215;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#763434" CREATED="1484797766035" ID="ID_1740926324" MODIFIED="1561827464658" TEXT="wie signalisieren wir das">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1501781461059" ID="ID_1041497316" MODIFIED="1518487921055" TEXT="wie den UiManager erreichen?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1501781776041" ID="ID_1345710498" MODIFIED="1518487921055" TEXT="magische Nachricht?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1501782361331" ID="ID_1281813611" MODIFIED="1518487921055" TEXT="an wen addressieren?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1501782381185" ID="ID_427836826" MODIFIED="1518487921055" TEXT="muß sinnvoll sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1501782399454" ID="ID_1238852873" MODIFIED="1518487921055" TEXT="InteractionDirector"/>
|
|
<node CREATED="1501784310336" ID="ID_455705917" MODIFIED="1533608413540" TEXT="was für eine Nachricht?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1501784324670" ID="ID_202531654" MODIFIED="1567875686498" TEXT="muß in das Protokoll passen"/>
|
|
<node CREATED="1501784333946" ID="ID_238263434" MODIFIED="1518487921055" TEXT="sollte nicht willkürlich sein"/>
|
|
<node CREATED="1501804506790" ID="ID_985808643" MODIFIED="1518487921055" TEXT="gibts nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501781769834" ID="ID_1836544616" MODIFIED="1518487921055" TEXT="direktes Wiring?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1501866473852" ID="ID_1346430403" MODIFIED="1518487921055" TEXT="direkt den UiManager aufrufen"/>
|
|
<node CREATED="1501866480963" ID="ID_361033579" MODIFIED="1518487921055" TEXT="dazu die NotificationFacade verschoben"/>
|
|
<node CREATED="1501866494441" ID="ID_540781053" MODIFIED="1518487921055" TEXT="wird jetzt vom UiManager gemanaged"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501792024717" ID="ID_1914400893" MODIFIED="1518487921055" TEXT="wer ist "wir"?">
|
|
<node CREATED="1501792033763" ID="ID_1293774586" MODIFIED="1518487921055" TEXT="der Subsystem-Lebenszyklus"/>
|
|
<node CREATED="1501792041586" ID="ID_1326580750" MODIFIED="1518487921055" TEXT="sonst geht das Niemanden was an!">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1501792062904" ID="ID_181717876" MODIFIED="1518487921055" TEXT="Subsysteme sind autark"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1501792086244" ID="ID_233471026" MODIFIED="1576282358152" TEXT="wir wollen keine globale Ebene">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das war genau der Kern der "Plugin-Debatte".
|
|
</p>
|
|
<p>
|
|
Eine solche globale, flache, dynamisch gebundene Ebene
|
|
</p>
|
|
<p>
|
|
klingt nach <i>wahnsinnigen Möglichkeiten</i>, aber nur solange, bis man sich
|
|
</p>
|
|
<p>
|
|
eine einzige Funktion konkret durchdenkt: es läuft auf Spaghetti-Code hinaus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501804804734" HGAP="52" ID="ID_1925973923" MODIFIED="1561827464660" TEXT="Mechanismus zum Schließen" VSHIFT="6">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1484797911392" ID="ID_286857196" MODIFIED="1531585120208" TEXT="geeigneten Mechanisums definieren">
|
|
<linktarget COLOR="#872666" DESTINATION="ID_286857196" ENDARROW="Default" ENDINCLINATION="-684;0;" ID="Arrow_ID_1606936924" SOURCE="ID_405470138" STARTARROW="Default" STARTINCLINATION="1461;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1502410904331" ID="ID_995145542" MODIFIED="1531584054722" TEXT="brauche Dispatch in UI event-Thread">
|
|
<arrowlink COLOR="#84c6b8" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="21;233;" ID="Arrow_ID_1372135725" STARTARROW="None" STARTINCLINATION="237;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501804850624" ID="ID_1451522246" MODIFIED="1518487921055" TEXT="Zugang zum UiManager">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502375214162" ID="ID_267170664" MODIFIED="1518487921055" TEXT="durch direkte Verdrahtung">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1502375221129" ID="ID_368784036" MODIFIED="1576282358152" TEXT="dies möglich machen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...indem der NotificatonService nun vom UI-Manager gemanaged wird :)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1488419591265" HGAP="65" ID="ID_471609909" MODIFIED="1538840175237" VSHIFT="70">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zieht komplett-Umbau
|
|
</p>
|
|
<p>
|
|
des Gui-top-Level nach sich
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#851358" DESTINATION="ID_548720270" ENDARROW="Default" ENDINCLINATION="-663;-614;" ID="Arrow_ID_325703166" STARTARROW="None" STARTINCLINATION="1110;608;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1485118623744" FOLDED="true" HGAP="23" ID="ID_392996871" MODIFIED="1561827464668" TEXT="#1032 use gtk::Application instead of gtk::Main" VSHIFT="11">
|
|
<arrowlink COLOR="#ae1856" DESTINATION="ID_206480879" ENDARROW="Default" ENDINCLINATION="715;0;" ID="Arrow_ID_926482654" STARTARROW="Default" STARTINCLINATION="134;383;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485118668802" ID="ID_575152579" MODIFIED="1518487921055" TEXT="WindowManager verwendet gtk::Main"/>
|
|
<node CREATED="1485118677425" ID="ID_1952311126" MODIFIED="1518487921055" TEXT="genau, um die Applikation runterzufahren"/>
|
|
<node CREATED="1485124031945" ID="ID_329247026" MODIFIED="1518487921055" TEXT="Gtk::Application">
|
|
<node CREATED="1485124038768" ID="ID_764043255" MODIFIED="1518487921055" TEXT="ist kein Singleton"/>
|
|
<node CREATED="1485124046775" ID="ID_505212945" MODIFIED="1518487921055" TEXT="hat keinen public ctor"/>
|
|
<node CREATED="1485124052149" ID="ID_799710500" MODIFIED="1518487921055" TEXT="mit create erstellt -> smart ptr"/>
|
|
<node CREATED="1485124063732" ID="ID_1584553859" MODIFIED="1532795708774" TEXT="erbt von Gio::Application">
|
|
<node CREATED="1485124070131" ID="ID_1720443251" MODIFIED="1518487921055" TEXT="wrappt g_application"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485124084465" ID="ID_660066920" MODIFIED="1518487921055" TEXT="how-to">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1485124094936" ID="ID_1446212765" MODIFIED="1533608413545" TEXT="offiziell">
|
|
<node CREATED="1485124098920" ID="ID_1783958965" MODIFIED="1518487921055" TEXT="auto app = Application::create"/>
|
|
<node CREATED="1485124111806" ID="ID_231977368" MODIFIED="1518487921055" TEXT="app->run"/>
|
|
</node>
|
|
<node CREATED="1485124120220" ID="ID_1639025787" MODIFIED="1533608413546" TEXT="von Application erben">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1485124129436" ID="ID_1540860407" MODIFIED="1518487921055" TEXT="laut Quellcode spricht nichts dagegen"/>
|
|
<node CREATED="1485124142178" ID="ID_1048261084" MODIFIED="1576282358151" TEXT="man sollte aber keine Methoden überschreiben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nur eine <i>heuristische </i>Vermutung von mir
|
|
</p>
|
|
<p>
|
|
stützt sich auf folgenden Quellcode
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Application::Application(const Glib::ustring& application_id, Gio::ApplicationFlags flags)
|
|
</p>
|
|
<p>
|
|
:
|
|
</p>
|
|
<p>
|
|
  // Mark this class as non-derived to allow C++ vfuncs to be skipped.
|
|
</p>
|
|
<p>
|
|
  //Note that GApplication complains about "" but allows NULL (0), so we avoid passing "".
|
|
</p>
|
|
<p>
|
|
  Glib::ObjectBase(0),
|
|
</p>
|
|
<p>
|
|
  Gio::Application(Glib::ConstructParams(custom_class_init(), "application_id", (application_id.empty() ? 0 : application_id.c_str()), "flags", GApplicationFlags(flags), static_cast<char*>(0))),
|
|
</p>
|
|
<p>
|
|
  m_argc(0),
|
|
</p>
|
|
<p>
|
|
  m_argv(0)
|
|
</p>
|
|
<p>
|
|
{
|
|
</p>
|
|
<p>
|
|
  gtk_init(0, 0);
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485124284856" ID="ID_473768869" MODIFIED="1518487921055" TEXT="Windows selber managen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1485124296582" ID="ID_628648705" MODIFIED="1518487921055" TEXT="gtk::Application verwaltet Fensterliste"/>
|
|
<node CREATED="1485124305157" ID="ID_1632068669" MODIFIED="1518487921055" TEXT="schließt sich automatisch, wenn das letzte Fenster zu ist"/>
|
|
<node CREATED="1485124315795" ID="ID_178656069" MODIFIED="1518487921055" TEXT="unser WindowManager macht das Gleiche"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533303793015" ID="ID_1636078216" MODIFIED="1533306062548" TEXT="Infos zu Gtk::Main, Gtk::Application und Gio::Application">
|
|
<arrowlink COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-981;-106;" ID="Arrow_ID_1912776282" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1493754789137" FOLDED="true" ID="ID_1903744710" MODIFIED="1582487817557" TEXT="kommt mir komisch vor">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1493754799439" ID="ID_288205807" MODIFIED="1518487921055" TEXT="das "riecht" nach Framework"/>
|
|
<node CREATED="1493754808373" ID="ID_998804989" MODIFIED="1533608413546" TEXT=""wir machen bequem alles für Sie"">
|
|
<node CREATED="1493759500422" ID="ID_378870766" MODIFIED="1518487921055" TEXT="macht mir Angst">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1493759504742" FOLDED="true" ID="ID_1800184805" MODIFIED="1561827483825" TEXT="Kontrollverlust">
|
|
<node CREATED="1493759564302" ID="ID_409429771" MODIFIED="1518487921055" TEXT="undurchsichtig"/>
|
|
<node CREATED="1493759572261" ID="ID_1741586689" MODIFIED="1518487921055" TEXT="mehrere Ebenen von Frameworks übereinander"/>
|
|
<node CREATED="1493759581123" ID="ID_1296466414" MODIFIED="1518487921055" TEXT="ich traue den Gnome-Leuten nicht über den Weg"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1493754820476" ID="ID_608560419" MODIFIED="1533608413548" TEXT="brauche ich überhaupt eine Gtk::Application">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1493756483852" ID="ID_1428028027" MODIFIED="1518487921055" TEXT="naja, man kann GTK zu Fuß verwenden"/>
|
|
<node CREATED="1493756499745" ID="ID_633405815" MODIFIED="1518487921055" TEXT="aber gtk::Application zeigt, wie"/>
|
|
<node CREATED="1493759629357" FOLDED="true" ID="ID_1297670007" MODIFIED="1561827483825" TEXT="gtk::Application">
|
|
<node CREATED="1493759644755" ID="ID_224674022" MODIFIED="1518487921056" TEXT="ist eine Window-Liste"/>
|
|
<node CREATED="1493759717704" ID="ID_697856504" MODIFIED="1518487921056" TEXT="initialisiert GTK, GLib, GIO"/>
|
|
<node CREATED="1493759649754" ID="ID_898599245" MODIFIED="1518487921056" TEXT="schließt, wenn letztes Fenster zu"/>
|
|
<node CREATED="1493759699387" ID="ID_1249589577" MODIFIED="1518487921056" TEXT="single application Instance"/>
|
|
<node CREATED="1493759656913" ID="ID_658938675" MODIFIED="1518487921056" TEXT="Desktop-Integration"/>
|
|
</node>
|
|
<node CREATED="1493759747148" ID="ID_1721295375" MODIFIED="1518487921056" TEXT="das kann ich doch zu Fuß auch machen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495215099003" ID="ID_1971256545" MODIFIED="1533608413550" TEXT="brauche ich überhaupt eine Gio::Application">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1495215111775" ID="ID_1003964020" MODIFIED="1518487921056" TEXT="initialisiert das Framework"/>
|
|
<node CREATED="1495215119685" ID="ID_1761204495" MODIFIED="1518487921056" TEXT="stellt eine dBus-Verbindung her"/>
|
|
<node CREATED="1495215129564" FOLDED="true" ID="ID_973272722" MODIFIED="1561827483825" TEXT="ist eine gio::ActionGroup">
|
|
<node CREATED="1495215149281" ID="ID_1774523135" MODIFIED="1518487921056" TEXT="man kann Aktionen hinzufügen"/>
|
|
<node CREATED="1495215164279" ID="ID_1315941470" MODIFIED="1518487921056" TEXT="diese Arbeitet mit einem ApplicationWindow zusammen"/>
|
|
<node CREATED="1495215177478" ID="ID_250116811" MODIFIED="1518487921056" TEXT="beachte: nicht GtkWindow, sondern ApplicationWindow (Subclass)"/>
|
|
</node>
|
|
<node CREATED="1495215193500" FOLDED="true" ID="ID_503299515" MODIFIED="1561827483825" TEXT="Zweck (Vermutung)">
|
|
<node CREATED="1495215209066" ID="ID_1153171656" MODIFIED="1518487921056" TEXT="Desktop-Integration"/>
|
|
<node CREATED="1495215214824" ID="ID_1385031644" MODIFIED="1518487921056" TEXT="Grenzen der Applikation aufweichen"/>
|
|
<node CREATED="1495215221624" ID="ID_297065945" MODIFIED="1518487921056" TEXT="Aktionen direkt in den Desktiop integrieren"/>
|
|
</node>
|
|
<node CREATED="1495215237213" ID="ID_745229887" MODIFIED="1518487921056" TEXT="nichts von dem ist für uns relevant, manches davon stört">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1495218672747" HGAP="-13" ID="ID_1786316132" MODIFIED="1518487921056" TEXT="Beschluß" VSHIFT="15">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#2f1d56" CREATED="1495218684994" ID="ID_101574501" MODIFIED="1518487921056" TEXT="vorerst defensiv vorgehen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533325503372" ID="ID_1815764983" MODIFIED="1533325787563" TEXT="nochmal gründlich überprüft und dokumentiert">
|
|
<arrowlink COLOR="#70dcb9" DESTINATION="ID_889790361" ENDARROW="Default" ENDINCLINATION="1185;0;" ID="Arrow_ID_1988524020" STARTARROW="Default" STARTINCLINATION="-2084;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1495218699712" ID="ID_1332523704" MODIFIED="1533325519569" TEXT="den Code aus Gtk::Main in unsere Codebasis übernehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1495218714230" ID="ID_1371091843" MODIFIED="1533608413552" TEXT="Vorsicht mit Action / ActionGroup">
|
|
<node CREATED="1495218731435" ID="ID_1744881610" MODIFIED="1518487921056" TEXT="noch nicht deprecated"/>
|
|
<node CREATED="1495218744961" ID="ID_97034293" MODIFIED="1518487921056" TEXT="aber Ablösung durch Gio::SimpleAction geplant"/>
|
|
<node CREATED="1495218770694" ID="ID_644528853" MODIFIED="1518487921056" TEXT="Warnung: mit dem neuen Gtk::ApplicationWindow verkoppelt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485130302095" FOLDED="true" HGAP="28" ID="ID_506541774" MODIFIED="1561827464676" TEXT="neuer UiManager" VSHIFT="14">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485452508180" ID="ID_549617075" MODIFIED="1518487921056" TEXT="ist front-end dafür">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1485130321924" ID="ID_46787934" MODIFIED="1518487921056" TEXT="Funktion umziehen"/>
|
|
<node CREATED="1485130328324" ID="ID_874057448" MODIFIED="1518487921056" TEXT="umschreiben auf gtk::Application"/>
|
|
<node CREATED="1485130336235" ID="ID_125642886" MODIFIED="1518487921056" TEXT="Application-Objekt durchgeben"/>
|
|
<node CREATED="1485130355377" ID="ID_175334188" MODIFIED="1518487921056" TEXT="Zugriff für NotificationFacade ermöglichen"/>
|
|
</node>
|
|
<node CREATED="1485452536138" ID="ID_599315721" MODIFIED="1518487921056" TEXT="wird dafür zuständig">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_599315721" ENDARROW="Default" ENDINCLINATION="-137;-12;" ID="Arrow_ID_1743989671" SOURCE="ID_842367237" STARTARROW="None" STARTINCLINATION="-18;215;"/>
|
|
<linktarget COLOR="#667e90" DESTINATION="ID_599315721" ENDARROW="None" ENDINCLINATION="41;328;" ID="Arrow_ID_1963473410" SOURCE="ID_1478388503" STARTARROW="Default" STARTINCLINATION="943;-58;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1493762472175" ID="ID_964179569" MODIFIED="1518487921056" TEXT="verwendet Fenster-Liste"/>
|
|
<node COLOR="#435e98" CREATED="1493762490205" ID="ID_869056268" MODIFIED="1538778695808" TEXT="alle noch offenen Fenster verbergen">
|
|
<arrowlink COLOR="#543c6f" DESTINATION="ID_159568066" ENDARROW="Default" ENDINCLINATION="489;-554;" ID="Arrow_ID_373486067" STARTARROW="None" STARTINCLINATION="-762;-46;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1493762498476" ID="ID_1290148687" MODIFIED="1518487921056" TEXT="direkt gtk_main_quit aufrufen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1493762556755" HGAP="34" ID="ID_651403872" MODIFIED="1533608413552" TEXT="siehe" VSHIFT="16">
|
|
<node CREATED="1493762559339" ID="ID_742529116" MODIFIED="1518487921056" TEXT="altes Gtk::Main::quit"/>
|
|
<node CREATED="1493762568266" ID="ID_902609710" MODIFIED="1518487921056" TEXT="Gio::Application::quit"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1493762951293" HGAP="69" ID="ID_1772990353" MODIFIED="1518487921056" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1493762968018" ID="ID_1056007574" MODIFIED="1518487921056" TEXT="brauchen wir ein Application GObject?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1493762987751" ID="ID_236361713" MODIFIED="1533304173000" TEXT="Gtk::Main funktioniert ohne">
|
|
<arrowlink COLOR="#469fa6" DESTINATION="ID_1120787097" ENDARROW="Default" ENDINCLINATION="1725;-6805;" ID="Arrow_ID_433910583" STARTARROW="None" STARTINCLINATION="821;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1493763356907" ID="ID_981398529" MODIFIED="1533608413553" TEXT="aber">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1493763398798" ID="ID_760049978" MODIFIED="1518487921056" TEXT="Gtk::Main ist deprecated"/>
|
|
<node CREATED="1493763393720" ID="ID_112295077" MODIFIED="1518487921056" TEXT="wohin entwickelt sich GTK?"/>
|
|
</node>
|
|
<node CREATED="1493768460811" ID="ID_1862271811" MODIFIED="1533608413553" TEXT="Alternativen">
|
|
<node CREATED="1493768465482" ID="ID_1159523698" MODIFIED="1518487921056" TEXT="gtk_main aufrufen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1493768484007" ID="ID_384827553" MODIFIED="1582487797600" TEXT="von einem Gio::Application ableiten">
|
|
<arrowlink COLOR="#6d7495" DESTINATION="ID_1476863246" ENDARROW="Default" ENDINCLINATION="1126;-247;" ID="Arrow_ID_1941890495" STARTARROW="None" STARTINCLINATION="-373;28;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1493770418552" HGAP="68" ID="ID_346412093" MODIFIED="1518487921056" TEXT="Schritte" VSHIFT="37">
|
|
<linktarget COLOR="#8091a3" DESTINATION="ID_346412093" ENDARROW="Default" ENDINCLINATION="-205;193;" ID="Arrow_ID_824195065" SOURCE="ID_1810145809" STARTARROW="None" STARTINCLINATION="430;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1493770423008" ID="ID_124348052" MODIFIED="1518487921056" TEXT="erst mal Gtk::Main hierher schieben">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1495215269657" ID="ID_850682198" MODIFIED="1518487921056" TEXT="Implementierung aus Gtk::Main übernemen">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1493770431607" ID="ID_117937910" MODIFIED="1518487921056" TEXT="(bei Bedarf) später dann durch Gio::Application ersetzen">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481320772830" FOLDED="true" HGAP="21" ID="ID_1607125695" MODIFIED="1561827464681" VSHIFT="11">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Proc: <b>SessionCommand</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1481320843596" ID="ID_7225903" MODIFIED="1518487921056" TEXT="definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481767553542" ID="ID_1936508244" MODIFIED="1518487921056" TEXT="Eigenschaften">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1481768183970" ID="ID_1887870402" MODIFIED="1518487921056" TEXT="ist offizielle Session-Schnittstelle"/>
|
|
<node CREATED="1481768211951" ID="ID_287828489" MODIFIED="1576282358151">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
setzt <i>aktivierten</i> Dispatcher <font color="#6e080d">zwingend</font> voraus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es genügt definitiv nicht, nur die Dispatcher-Komponente(Schnittstelle) erreichen zu können.
|
|
</p>
|
|
<p>
|
|
Jede Operation, die über dieses externe Interface bereitsteht, benötigt zur Implementierung
|
|
</p>
|
|
<p>
|
|
eine aktiv laufende Dispatcher-Queue.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Daher macht es Sinn, den Interface-Lebenszyklus ganz starr an den Disspatcher zu binden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481768341149" ID="ID_1200042703" MODIFIED="1576282358150" TEXT="implizite Bindung an eine Session-Instanz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar wirklich sehr implizit,
|
|
</p>
|
|
<p>
|
|
nämlich über die Identität (IDs) der Command-Parameter.
|
|
</p>
|
|
<p>
|
|
Das heißt, ein eingehendes Command paßt nur zu einer bestimmten Session-Instanz,
|
|
</p>
|
|
<p>
|
|
was zwar jederzeit (via statisches/internes Session-API) verifizierbar ist, jedoch nicht offensichtlich
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481768566167" ID="ID_702026185" MODIFIED="1576282358149" TEXT="kann jederzeit asynchron geschlossen werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das folgt einfach aus den logischen Eigenschaften der beteiligten Komponenten,
|
|
</p>
|
|
<p>
|
|
welche eben autonom sind.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das heißt im Klartext, alle Clients müssen darauf vorbereitet sein, daß diese Schnittstelle
|
|
</p>
|
|
<p>
|
|
<i>jederzeit</i> wegbrechen kann, was dann heißt, daß irgend ein Aufruf eine Exception wirft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481320847724" FOLDED="true" HGAP="42" ID="ID_545146501" MODIFIED="1582487700785" TEXT="wo ansiedeln" VSHIFT="-6">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1481509901926" ID="ID_1612540786" MODIFIED="1518487921056" TEXT="in proc::control"/>
|
|
<node CREATED="1481767522123" ID="ID_789146708" MODIFIED="1518487921056">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wer besitzt die
|
|
</p>
|
|
<p>
|
|
Implementierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1481767563781" ID="ID_1894117297" MODIFIED="1518487921056" TEXT="Subsystem">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1481767649426" ID="ID_1806364059" MODIFIED="1518487921056" TEXT="pro">
|
|
<node CREATED="1481767653785" ID="ID_65381960" MODIFIED="1518487921056" TEXT="offensichtlich"/>
|
|
<node CREATED="1481767700299" ID="ID_1163247183" MODIFIED="1518487921056" TEXT="logisch"/>
|
|
</node>
|
|
<node CREATED="1481767665231" ID="ID_141423591" MODIFIED="1518487921056" TEXT="con">
|
|
<node CREATED="1481767681797" ID="ID_1133339398" MODIFIED="1576282358149" TEXT="fragiler Lebenszyklus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
meint: zwei gekoppelte Statusvariable
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481767706906" ID="ID_815807707" MODIFIED="1518487921057" TEXT="bekomme dort Zustand"/>
|
|
<node CREATED="1481767720576" ID="ID_714877064" MODIFIED="1518487921057" TEXT="muß dort Locking verwenden"/>
|
|
<node CREATED="1481767711033" ID="ID_232055384" MODIFIED="1518487921057" TEXT="bekomme dort Fehlerbehandlung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481767579130" ID="ID_191292506" MODIFIED="1518487921057" TEXT="Dispatcher">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1481767748180" ID="ID_549036367" MODIFIED="1518487921057" TEXT="pro">
|
|
<node CREATED="1481767761027" ID="ID_949448369" MODIFIED="1518487921057" TEXT="ist die offizielle Schnittstelle"/>
|
|
<node CREATED="1481767864069" ID="ID_47595319" MODIFIED="1518487921057" TEXT="kann Service-Impl direkt verdrahten"/>
|
|
</node>
|
|
<node CREATED="1481767758347" ID="ID_1773256683" MODIFIED="1518487921057" TEXT="con">
|
|
<node CREATED="1481767797062" ID="ID_1542908203" MODIFIED="1518487921057">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß alle Operationen durchschleifen
|
|
</p>
|
|
<p>
|
|
oder muß PImpl als Interface exponieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481767831105" ID="ID_1351930491" MODIFIED="1576282358148" TEXT="fragiler Lebenszyklus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
meint: zwei gekoppelte Statusvariable
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481767581619" ID="ID_1364443356" MODIFIED="1518487921057" TEXT="DispatcherLoop">
|
|
<linktarget COLOR="#4aff51" DESTINATION="ID_1364443356" ENDARROW="Default" ENDINCLINATION="10;30;" ID="Arrow_ID_870320696" SOURCE="ID_1152351588" STARTARROW="Default" STARTINCLINATION="-221;-88;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481767877379" ID="ID_1139131626" MODIFIED="1518487921057" TEXT="pro">
|
|
<node CREATED="1481767893969" ID="ID_1688865092" MODIFIED="1518487921057" TEXT="kann dort dediziertes Interface nutzen"/>
|
|
<node CREATED="1481767924909" ID="ID_438801896" MODIFIED="1518487921057" TEXT="alle Operationen passieren dort"/>
|
|
<node CREATED="1481767961616" ID="ID_1097715033" MODIFIED="1518487921057" TEXT="Lebenszyklus == RAII">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1481769041800" ID="ID_1026761428" MODIFIED="1518487921057" TEXT="ausschlaggebend">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1481769052246" ID="ID_628010771" MODIFIED="1518487921057" TEXT="gutes Design"/>
|
|
</node>
|
|
<node CREATED="1481768131609" ID="ID_600248646" MODIFIED="1518487921057" TEXT="Locking schon da"/>
|
|
</node>
|
|
<node CREATED="1481768014089" ID="ID_1260583976" MODIFIED="1518487921057" TEXT="con">
|
|
<node CREATED="1481768019848" ID="ID_1155187340" MODIFIED="1518487921057">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Shutdown <i>tricky</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481768075481" ID="ID_795971368" MODIFIED="1518487921057" TEXT="in der Implementierung versteckt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481320850779" FOLDED="true" HGAP="45" ID="ID_1632600003" MODIFIED="1582487705118" TEXT="hochfahren" VSHIFT="-3">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481509921211" FOLDED="true" ID="ID_1515469097" MODIFIED="1582487687161">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Session-Subsystem implementieren <font color="#c60814">(#318)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1481599413419" HGAP="34" ID="ID_673133356" MODIFIED="1576282358148" TEXT="Ticket #318" VSHIFT="-7">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....das ist schon mehr ein Meta-Ticket,
|
|
</p>
|
|
<p>
|
|
und es hängt wohl zu viel darunter, um es gleich ganz abschließen zu können.
|
|
</p>
|
|
<p>
|
|
Aber ich <i>akzeptiere</i> es und verwende es jetzt als Treiber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1483473104426" ID="ID_1606817357" MODIFIED="1483747983243" TEXT="#701 Session interface Support facility">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483473212107" ID="ID_600424316" MODIFIED="1512926191669" TEXT="#699 entrance to session subsystem">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483748003185" ID="ID_1342405777" MODIFIED="1483748021355" TEXT="sollte das auch tatsächlich mal in Betrieb setzen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1483748023934" ID="ID_535793074" MODIFIED="1483753100683" TEXT="Session ab jetzt in main() hochfahren...">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483473153851" ID="ID_868700871" MODIFIED="1512926191670" TEXT="#1049 draft SessionLoop component">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483642220941" ID="ID_517844262" MODIFIED="1483645251383" TEXT="integrate API functions for enqueuing commands">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483642220941" ID="ID_775655275" MODIFIED="1483645257684" TEXT="integrate actual command queue">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483642220941" ID="ID_704571897" MODIFIED="1483648766529" TEXT="care for waking (notification) from sleep state">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483642220940" ID="ID_1519554797" MODIFIED="1483654058917" TEXT="care for syncing the disabled state">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483642220941" ID="ID_377776032" MODIFIED="1483746849507" TEXT="deadlock safeguard">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482464327133" HGAP="51" ID="ID_996095134" MODIFIED="1512926191671" TEXT="was es ist" VSHIFT="-2">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1482464377831" ID="ID_1028012453" MODIFIED="1482464390602">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>ist nicht</i> "die Session
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1482464332981" ID="ID_1523357281" MODIFIED="1482464350688" TEXT="Session Subsystem == Session Dispatcher Loop Thread">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482464414721" ID="ID_490065319" MODIFIED="1482464436563" TEXT="verwaltet Command-Queue"/>
|
|
<node CREATED="1482464436919" ID="ID_64274402" MODIFIED="1482464442042" TEXT="führt Commands aus"/>
|
|
<node CREATED="1482464442438" ID="ID_1339868449" MODIFIED="1482464449049" TEXT="startet den Builder"/>
|
|
</node>
|
|
<node CREATED="1481599421021" FOLDED="true" ID="ID_461768132" MODIFIED="1582487678249" TEXT="Locking klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481684383530" ID="ID_236117" MODIFIED="1512926191672" TEXT="zwei unabhängige Locks">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1481684391921" ID="ID_138369898" MODIFIED="1576282358147" TEXT="Front-End">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Lock sorgt hier für konsistenten Zustand und Sichtbarkeit (memory barrier)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481684394544" ID="ID_1314197501" MODIFIED="1576282358147" TEXT="Back-End">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lock ist hier das Dispatcher-Lock
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481599468712" ID="ID_1273965744" MODIFIED="1512926191672" TEXT="Vorsicht beim Anhalten (Deadlock-Gefahr)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1483477519974" ID="ID_1731425552" MODIFIED="1483477535864" TEXT="Term-Signal könnte blocken">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483484052785" ID="ID_667055412" MODIFIED="1483581561638" TEXT="Race beim runningLoop_.reset()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483490459499" ID="ID_1006586365" MODIFIED="1483581568462" TEXT="Thread will sich selbst reapen ==> Deadlock">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483581573147" ID="ID_989149672" MODIFIED="1512926191673" TEXT="durch Umbau gelöst">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1483490316758" ID="ID_1734989824" MODIFIED="1483581603244" TEXT="nur das Term-Signal kann DispatcherLoop deleten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1483581605968" ID="ID_227347532" MODIFIED="1483581655738" TEXT="muß das äußere Lock auf ProcDispatcher verwenden"/>
|
|
<node CREATED="1483581657849" ID="ID_1078225675" MODIFIED="1483581670643" TEXT="damit sind konkurrierende Zugriffe auf die Loop geblockt"/>
|
|
<node CREATED="1483581671183" ID="ID_186079754" MODIFIED="1483581680474" TEXT="und danach ist der PImpl bereits auf NULL gesetzt"/>
|
|
<node CREATED="1483581583411" ID="ID_650761020" MODIFIED="1483581594997" TEXT="thread join ist überflüssig"/>
|
|
<node CREATED="1483581640739" ID="ID_560356092" MODIFIED="1483581652445" TEXT="das Objekt wird in einem tail-call gelöscht"/>
|
|
<node CREATED="1483581682701" ID="ID_747399934" MODIFIED="1483581695879" TEXT="dieser callback selber vewrwendet nur Werte vom Stack"/>
|
|
<node CREATED="1483581696443" ID="ID_373783285" MODIFIED="1483581733454" TEXT="daher kann das Objekt gefahrlos "sich selber löschen"">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482464502542" ID="ID_284397306" MODIFIED="1531584182082" TEXT="Vorsicht beim Schließen der Session">
|
|
<arrowlink COLOR="#5a97df" DESTINATION="ID_1378897740" ENDARROW="Default" ENDINCLINATION="2126;95;" ID="Arrow_ID_1446486242" STARTARROW="None" STARTINCLINATION="2592;-81;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481599430804" HGAP="19" ID="ID_1105415989" MODIFIED="1512926191673" TEXT="Forwarding-Operationen implementieren" VSHIFT="10">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481686902156" ID="ID_1526215617" MODIFIED="1481686910633" TEXT="aktivieren /deaktivieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481686911938" ID="ID_17287395" MODIFIED="1483581788279" TEXT="stoppen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481599594399" ID="ID_1017459823" MODIFIED="1512926191674" TEXT="entscheiden, wer die Session öffnet">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481686982097" ID="ID_1925999031" MODIFIED="1576282358146" TEXT="passiert on demand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn jemand zugreift
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481599603757" ID="ID_812618450" MODIFIED="1481599612320" TEXT="Operation auf dem SessionManager"/>
|
|
<node CREATED="1481599612812" ID="ID_1970476027" MODIFIED="1481599618598" TEXT="der ist Singleton"/>
|
|
<node CREATED="1481599626194" ID="ID_1815350592" MODIFIED="1481599638105" TEXT="wenn Session öffnet, wird der Dispatcher aktiviert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1481687005813" ID="ID_1108477992" MODIFIED="1576282358146" TEXT="Entscheidung: Sesion-lifecycle und Dispatcher sind unabhängig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
grundlegende Design-Enscheidung
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wir haben Komponenten mit Dependency-Injection
|
|
</li>
|
|
<li>
|
|
da beide Komponenten nur nach ihren eigenen Hinsichten funktionieren,<br />wird das System insgesamt einfacher
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483581821347" HGAP="13" ID="ID_1893571865" MODIFIED="1512926191674" TEXT="Review Lebenszyklus" VSHIFT="8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483581829682" ID="ID_1563520696" MODIFIED="1483581904481" TEXT="alle Subsys-Operationen auf Semantik durchgeprüft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483581852071" ID="ID_1139549600" MODIFIED="1483581902223" TEXT="1/2017: Locking und Concurrency erscheint sauber behandelt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481510231986" HGAP="23" ID="ID_45803267" MODIFIED="1561827464694" TEXT="dort SessionCommandService instantiieren" VSHIFT="4">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481769089234" ID="ID_1152351588" MODIFIED="1518487921057" TEXT="lebt in der DispatcherLoop">
|
|
<arrowlink COLOR="#4aff51" DESTINATION="ID_1364443356" ENDARROW="Default" ENDINCLINATION="10;30;" ID="Arrow_ID_870320696" STARTARROW="Default" STARTINCLINATION="-221;-88;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1481769144226" ID="ID_1609251574" MODIFIED="1518487921057" TEXT="muß Service-API extrahieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481777039358" ID="ID_395609084" MODIFIED="1518487921057" TEXT="Shutdown sauber regeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481777054755" ID="ID_1551225439" MODIFIED="1518487921057">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß SessionCommandService schließen
|
|
</p>
|
|
<p>
|
|
<i>bevor</i> die Dispatcher-loop angehalten wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481778397600" ID="ID_1997192349" MODIFIED="1518487921057" TEXT="bereits wenn Anhalten signalisiert wird"/>
|
|
<node CREATED="1481778409942" ID="ID_100284739" MODIFIED="1518487921057" TEXT="zur Sicherheit nochmal im dtor"/>
|
|
</node>
|
|
<node CREATED="1481777114203" ID="ID_1156396729" MODIFIED="1518487921057" TEXT="Lock, um Deadlock zu vermeiden"/>
|
|
<node CREATED="1481777122306" ID="ID_1506554988" MODIFIED="1518487921057" TEXT="alles im dtor -> noexcept"/>
|
|
<node CREATED="1481777210447" ID="ID_1392452935" MODIFIED="1576282358145" TEXT="sicherstellen daß shutdown nicht blockt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
1/2017 Review durchgeführt und Logik überarbeitet.
|
|
</p>
|
|
<p>
|
|
Einziger Risikofaktor ist nun, wenn beim Schließen des SessionCommand-Intertfaces
|
|
</p>
|
|
<p>
|
|
oder beim Signalisieren an den Thread eine Exception fliegt; denn dann loggen wir zwar,
|
|
</p>
|
|
<p>
|
|
aber die Shutdown-Rückmeldung kommt u.U niemals an, und damit bleiben wir
|
|
</p>
|
|
<p>
|
|
am Ende von main() einfach hängen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<i>Ich halte diese Fälle aber für in der Praxis nicht relevant,</i>  und verzichte daher auf eine Spezialbehandlung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5a97df" DESTINATION="ID_1789585729" ENDARROW="Default" ENDINCLINATION="3225;0;" ID="Arrow_ID_1930701586" STARTARROW="None" STARTINCLINATION="2096;-122;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481510244184" ID="ID_1521406724" MODIFIED="1518487921057" TEXT="kann dann in CoreService einfach über die .facade() zugreifen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483748175610" HGAP="31" ID="ID_73597248" MODIFIED="1518487921057" VSHIFT="16">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Einfachen Aufruf
|
|
</p>
|
|
<p>
|
|
implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1483748214772" ID="ID_1642552563" MODIFIED="1518487921057" TEXT="#1046 Preliminary Definition of SessionCommand facade">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483748231330" ID="ID_1962213649" MODIFIED="1518487921057" TEXT="soll hierzu sehen, daß ein einfacher Aufruf wirklich klappt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483748323014" FOLDED="true" ID="ID_1031176077" MODIFIED="1582487641495" TEXT="Nachrichten vom UI-Bus entnehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#520262" CREATED="1483908814960" HGAP="34" ID="ID_430949603" MODIFIED="1561827464699" TEXT="Design sinnvoll?" VSHIFT="6">
|
|
<linktarget COLOR="#b694bf" DESTINATION="ID_430949603" ENDARROW="Default" ENDINCLINATION="178;425;" ID="Arrow_ID_1062305149" SOURCE="ID_329609486" STARTARROW="Default" STARTINCLINATION="-629;-2354;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1483908894494" ID="ID_1854211202" MODIFIED="1518487921057" TEXT="Proc-Commands...">
|
|
<node CREATED="1483908919274" ID="ID_184360294" MODIFIED="1518487921057" TEXT="könnte man direkt aufrufen"/>
|
|
<node CREATED="1483908982889" ID="ID_758147179" MODIFIED="1518487921057" TEXT="sind bereits ein Handle"/>
|
|
</node>
|
|
<node CREATED="1483909157290" ID="ID_1197073738" MODIFIED="1518487921057" TEXT="via UI-Bus">
|
|
<node CREATED="1483909161170" ID="ID_159742986" MODIFIED="1518487921057" TEXT="bleibt ein synchroner Aufruf"/>
|
|
<node CREATED="1483909179088" ID="ID_926171934" MODIFIED="1518487921057" TEXT="Command(Handle) auf beiden Seiten"/>
|
|
<node CREATED="1483909223058" ID="ID_582886428" MODIFIED="1518487921057" TEXT="Argument-Marshalling">
|
|
<node CREATED="1483909253550" ID="ID_824110666" MODIFIED="1518487921057" TEXT="umständlich, mehrstufig"/>
|
|
<node CREATED="1483909263620" ID="ID_1628441605" MODIFIED="1518487921057" TEXT="erzwingt mehrfache Indirektion"/>
|
|
<node CREATED="1483909333227" ID="ID_473681935" MODIFIED="1518487921057" TEXT="Umpacken -> Record -> Tuple -> function"/>
|
|
</node>
|
|
<node CREATED="1483909386820" ID="ID_311424247" MODIFIED="1518487921057" TEXT="mehrfache Indirektion">
|
|
<node CREATED="1483909440437" ID="ID_1792180060" MODIFIED="1518487921057" TEXT="Variant-Record VTable"/>
|
|
<node CREATED="1483909459226" ID="ID_1352346417" MODIFIED="1518487921057" TEXT="Bus-Term VTable"/>
|
|
<node CREATED="1483909468913" ID="ID_1209442982" MODIFIED="1518487921058" TEXT="Command-Handler double dispatch"/>
|
|
<node CREATED="1483909488622" ID="ID_856721427" MODIFIED="1518487921058" TEXT="Argument-Auswertung double dispatch"/>
|
|
<node CREATED="1483909496110" ID="ID_1500666281" MODIFIED="1518487921058" TEXT="Command-Functor invocation VTable"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1483909585362" HGAP="1" ID="ID_1047452263" MODIFIED="1538840272769" TEXT="muß sich noch rechtfertigen" VSHIFT="11">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1483909605879" ID="ID_1463483386" MODIFIED="1518487921058" TEXT="war eine Design-Wahl auf Verdacht">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1483909613670" ID="ID_223762457" MODIFIED="1518487921058" TEXT="erzwingt Trennung im Planen und Denken"/>
|
|
<node CREATED="1483909679605" ID="ID_1627582396" MODIFIED="1518487921058" TEXT="könnte Verallgemeinerungen im UI generieren"/>
|
|
<node CREATED="1483909714201" ID="ID_1677179961" MODIFIED="1518487921058" TEXT="könnte UI-Abläufe abstrakt testbar machen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483755303243" HGAP="86" ID="ID_1425274731" MODIFIED="1518487921058" TEXT="Brauche Command-Handler" VSHIFT="11">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483755317105" ID="ID_775818551" MODIFIED="1518487921058" TEXT="ist ein Visitor"/>
|
|
<node CREATED="1483755320136" ID="ID_1343109260" MODIFIED="1561827464703" TEXT="Knackpunkt: Command-ID">
|
|
<node CREATED="1483755331671" ID="ID_1913103415" MODIFIED="1518487921058" TEXT="wird im Visitor gebraucht">
|
|
<node CREATED="1483909964935" ID="ID_991182613" MODIFIED="1518487921058">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
will sagen: <i>in </i>den Visitor-Methoden-Implementierungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1483909984005" ID="ID_590392737" MODIFIED="1518487921058">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>aber</i> ist nicht auf dem Visitor-Interface darstellbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1483910035326" ID="ID_366990653" MODIFIED="1533608413554" TEXT="latentes Design-Problem">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1483910047148" ID="ID_1870862761" MODIFIED="1518487921058" TEXT="Design Rec<GenNode>"/>
|
|
<node CREATED="1483910056243" ID="ID_967619584" MODIFIED="1518487921058" TEXT="da Record eine Payload ist"/>
|
|
<node CREATED="1483910117819" ID="ID_117939525" MODIFIED="1576282358145" TEXT="man könnte....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....über einen GenNode-Visitor nachdenken
|
|
</p>
|
|
<p>
|
|
<b>aber</b>
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
nicht jetzt
|
|
</li>
|
|
<li>
|
|
das Problem müßte mehrfach auftreten
|
|
</li>
|
|
<li>
|
|
könnte zu Switch-On-Type-programming führen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483755341814" ID="ID_254491480" MODIFIED="1518487921058" TEXT="Instanz-Management fraglich">
|
|
<node CREATED="1483909934891" ID="ID_1608078388" MODIFIED="1518487921058" TEXT="nicht wirklich relevant"/>
|
|
<node CREATED="1483909940506" ID="ID_262925518" MODIFIED="1518487921058" TEXT="effektiv nur Stack-Storage"/>
|
|
</node>
|
|
<node CREATED="1483755347949" ID="ID_4176562" MODIFIED="1518487921058" TEXT="Performance-Überlegungen">
|
|
<node CREATED="1483909826690" ID="ID_1903951356" MODIFIED="1518487921058" TEXT="nicht wirklich schlimm">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1483909832385" ID="ID_136936347" MODIFIED="1518487921058" TEXT="Storage ist lokal"/>
|
|
<node CREATED="1483909836992" ID="ID_238373170" MODIFIED="1518487921058" TEXT="VTable ist vorbereitet"/>
|
|
<node CREATED="1483909866844" ID="ID_83144371" MODIFIED="1518487921058" TEXT="aber: double-dispatch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483755360196" ID="ID_514688462" MODIFIED="1518487921058" TEXT="Nachrichten kommen ohne bestimmte Ordnung an"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483910254385" FOLDED="true" HGAP="88" ID="ID_267402281" MODIFIED="1582487629892" TEXT="Command-Instanz-Management" VSHIFT="-8">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1483910266799" ID="ID_86909318" MODIFIED="1518487921058" TEXT="wie funktioniert's?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1483910289396" ID="ID_1014786685" MODIFIED="1518487921058" TEXT="Prototyp-Pattern"/>
|
|
<node CREATED="1483910293827" ID="ID_1957585594" MODIFIED="1518487921058" TEXT="irgendjemand...">
|
|
<node CREATED="1483910333137" ID="ID_1304876612" MODIFIED="1518487921058" TEXT="muß Command-Definitionen Klonen"/>
|
|
<node CREATED="1483910306458" ID="ID_601011326" MODIFIED="1518487921058" TEXT="und dabei IDs generieren / dekorieren"/>
|
|
</node>
|
|
<node CREATED="1483911060894" ID="ID_1204552049" MODIFIED="1518487921058" TEXT="wer">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1483911069277" ID="ID_277421164" MODIFIED="1518487921058" TEXT="InteractionStateManager">
|
|
<node CREATED="1483911145898" ID="ID_897832170" MODIFIED="1518487921058" TEXT="eigentlich nur opaque Command-IDs"/>
|
|
<node CREATED="1483911161248" ID="ID_283380145" MODIFIED="1518487921058" TEXT="aber: weiß wann neue Interaktion beginnt"/>
|
|
</node>
|
|
<node CREATED="1483911091314" ID="ID_842914123" MODIFIED="1518487921058" TEXT="SessionCommandService">
|
|
<node CREATED="1483911181669" ID="ID_1397857321" MODIFIED="1518487921058" TEXT="sitzt schon in Proc"/>
|
|
<node CREATED="1483911194940" ID="ID_485403998" MODIFIED="1518487921058" TEXT=""natürlich" nah am Command-Framework"/>
|
|
<node CREATED="1483911208546" ID="ID_380202969" MODIFIED="1518487921058" TEXT="weiß aber nichts von Interaktionen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483921000340" HGAP="-60" ID="ID_1814046433" MODIFIED="1518487921058" VSHIFT="31">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Idee:</i> Zusammenarbeit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1483921070115" ID="ID_398046799" MODIFIED="1518487921058" TEXT="Prototyp-Service"/>
|
|
<node CREATED="1483921132114" ID="ID_1652398711" MODIFIED="1518487921058" TEXT="liefert dekorierte Command-ID"/>
|
|
<node CREATED="1483921149368" ID="ID_1028150245" MODIFIED="1518487921058" TEXT="im GUI nur noch Command-IDs"/>
|
|
<node CREATED="1483924872930" ID="ID_242219866" MODIFIED="1582487507380">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das wäre eine <b>Protokoll-Erweiterung</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#8ba05e" DESTINATION="ID_242219866" ENDARROW="Default" ENDINCLINATION="1170;1204;" ID="Arrow_ID_1617518648" SOURCE="ID_1479669922" STARTARROW="None" STARTINCLINATION="3617;-1097;"/>
|
|
<node CREATED="1582487470565" ID="ID_323975519" MODIFIED="1582487479759" TEXT="teilweise umgesetzt"/>
|
|
<node CREATED="1582487480467" ID="ID_1883804803" MODIFIED="1582487486597" TEXT="Deokrieren von Command-IDs"/>
|
|
<node CREATED="1582487487266" ID="ID_1888880877" MODIFIED="1582487494285" TEXT="weitergehende Ideen verworfen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483927472385" HGAP="30" ID="ID_774425061" MODIFIED="1582487441000" VSHIFT="13">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
letztlich verworfen; siehe Ticket <font color="#c52a05">#1058</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483755390640" HGAP="66" ID="ID_1882657994" MODIFIED="1538840301236" TEXT="Vorlage" VSHIFT="-1">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1483755399334" ID="ID_582834462" MODIFIED="1518487921058" TEXT="AbstractTangible_test">
|
|
<node CREATED="1483755406254" ID="ID_1800773105" MODIFIED="1518487921058" TEXT="hat inline-Visitor"/>
|
|
<node CREATED="1483755445984" ID="ID_468077802" MODIFIED="1518487921058" TEXT="aber Command-ID fest gedrahtet">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483755412605" ID="ID_220502028" MODIFIED="1518487921058" TEXT="BusTerm_test">
|
|
<node CREATED="1483755417932" ID="ID_1696122428" MODIFIED="1518487921058" TEXT="verwendet Hanlder vom Test-Nexus"/>
|
|
<node CREATED="1483755428354" ID="ID_1619772942" MODIFIED="1518487921058" TEXT="der verwendet bereits komplettes Argument-Binding">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483924890656" HGAP="-45" ID="ID_815841886" MODIFIED="1518487921058" TEXT="Implementierung" VSHIFT="22">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483924900583" ID="ID_12753464" MODIFIED="1518487921058" TEXT="banal">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1483924903190" ID="ID_1436586014" MODIFIED="1576282358144" TEXT="wenn man das Design akzeptiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt,
|
|
</p>
|
|
<p>
|
|
die mehrfachen Indirektionen und das Ein-/Auspacken der Argumente
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483927552823" HGAP="-160" ID="ID_458362835" MODIFIED="1538840308219" TEXT="Unit-Test" VSHIFT="24">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1484294389310" ID="ID_100306048" MODIFIED="1518487921058" TEXT="direkter Aufruf der Facade">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484294397597" ID="ID_1461153044" MODIFIED="1518487921058" TEXT="Aufruf über Nachrichten + Visitor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484294409827" ID="ID_1014781174" MODIFIED="1518487921058" TEXT="massiv-paralleler Aufruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1484377327032" ID="ID_1461940140" MODIFIED="1518487921058" TEXT="war eine interessante Übung...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1484377336983" ID="ID_823071776" MODIFIED="1518487921058" TEXT="Hilfsmittel für Thread/Familien-IDs">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1484377358324" ID="ID_1280997474" MODIFIED="1518487921059" TEXT="in der Tat">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1484377383249" ID="ID_1422297147" MODIFIED="1518487921059" TEXT="Commands überholen sich"/>
|
|
<node CREATED="1484377389056" ID="ID_930164551" MODIFIED="1518487921059" TEXT="Command instanzen dürfen nicht geshared werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1483748340524" ID="ID_841368846" MODIFIED="1518487921059" TEXT="API-Funktionen aufrufen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482464658193" FOLDED="true" HGAP="-14" ID="ID_726798260" MODIFIED="1561827464711" TEXT="Ausgestaltung" VSHIFT="29">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482465840843" FOLDED="true" ID="ID_818984499" MODIFIED="1582487750838" TEXT="Entwurf">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1482464676366" ID="ID_1064506750" MODIFIED="1518487921059" TEXT="bekommt Nachrichten vom UI-Bus">
|
|
<node CREATED="1482464755404" ID="ID_213932356" MODIFIED="1518487921059" TEXT="entnimmt Argument"/>
|
|
<node CREATED="1482464758148" ID="ID_545671857" MODIFIED="1518487921059" TEXT="triggert sofort"/>
|
|
<node CREATED="1492205571235" ID="ID_166892291" MODIFIED="1576282358143" TEXT="Zukunft: partiell schließen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es wäre denkbar, an dieser Stelle
|
|
</p>
|
|
<p>
|
|
unvollständige Argument-Tupel zu akzeptieren
|
|
</p>
|
|
<p>
|
|
und die Argumente von links her zu schließen (currying)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482464696668" ID="ID_1191503480" MODIFIED="1518487921059" TEXT="müssen in Command-Objekte übersetzt werden"/>
|
|
<node CREATED="1482464712474" ID="ID_1386285986" MODIFIED="1518487921059" TEXT="Interface sollte noch GenNodes nehmen"/>
|
|
<node CREATED="1482464719513" ID="ID_1003624750" MODIFIED="1518487921059" TEXT="aber synchron die Commands beziehen"/>
|
|
<node CREATED="1482464730783" ID="ID_1225624791" MODIFIED="1518487921059" TEXT="damit Exceptions sofort fliegen"/>
|
|
</node>
|
|
<node CREATED="1484377470133" FOLDED="true" HGAP="35" ID="ID_62981197" MODIFIED="1582487752710" TEXT="Weiterungen" VSHIFT="11">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1484377485339" ID="ID_414407137" MODIFIED="1518487921059" TEXT="Commands mit verschiedener Priorität"/>
|
|
<node CREATED="1484377503465" ID="ID_72812588" MODIFIED="1518487921059" TEXT="Commands aggregieren"/>
|
|
<node CREATED="1484377535829" ID="ID_488242691" MODIFIED="1518487921059" TEXT="Verwerfen von Commands"/>
|
|
<node CREATED="1484377546779" ID="ID_1097356179" MODIFIED="1518487921059" TEXT="Command-ID - Typ"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1482465854513" HGAP="26" ID="ID_1477532018" MODIFIED="1538840324244" TEXT="Widerspruch zu Tangible " VSHIFT="12">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1482465965660" ID="ID_1945056449" MODIFIED="1518487921059" TEXT="Tangible::prepareCommand"/>
|
|
<node CREATED="1482466012484" ID="ID_283758092" MODIFIED="1518487921059" TEXT="verwendet InvocationTrail">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1482466021562" ID="ID_620393388" MODIFIED="1518487921059" TEXT="dieser wird direkt mit Command erzeugt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1482466509953" ID="ID_565604124" MODIFIED="1576282358143" TEXT="...dient der Sicherheit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn es erzwingt,
|
|
</p>
|
|
<p>
|
|
daß die betreffenden Commands schon erzeugt und registriert sein müssen,
|
|
</p>
|
|
<p>
|
|
wenn in der UI ein InvocationTrail angelegt wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1482466104359" ID="ID_235553653" MODIFIED="1518487921059" TEXT="speichert aber eigentlich nur die Cmd-ID">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492443474996" HGAP="21" ID="ID_440734267" MODIFIED="1518487921059" TEXT="Schlußfolgerung: direkter Aufruf mit Cmd-ID genügt" VSHIFT="10">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482466197707" ID="ID_832611965" MODIFIED="1518487921059">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Architektur-Entscheidung
|
|
</p>
|
|
<p>
|
|
<i>kann offen bleiben</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1482466246933" ID="ID_870716233" MODIFIED="1518487921059" TEXT="hängt von der Verwendung ab"/>
|
|
<node CREATED="1482466260627" ID="ID_1708185529" MODIFIED="1518487921059" TEXT="wie Commands im UI gebunden werden"/>
|
|
<node CREATED="1482466271713" ID="ID_1519273419" MODIFIED="1518487921059" TEXT="Nur IDs gehen über die Leitung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1482466587807" ID="ID_135147405" MODIFIED="1518487921059">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
reine ID-Wirtschaft <i>wäre möglich</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482466285359" ID="ID_1077952925" MODIFIED="1518487921059" TEXT="Zugriff auf proc::control::Command is OK">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#c0425f" CREATED="1482466320947" ID="ID_431246960" MODIFIED="1518487921059" TEXT="Grundsatz-Entscheidung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482466328482" ID="ID_1223809722" MODIFIED="1518487921059" TEXT="GUI darf von unteren Layern abhängen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1482466347767" ID="ID_755953852" MODIFIED="1518487921059" TEXT="C++ ist das maßgebliche Ausdrucksmedium">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1482466368068" ID="ID_149410251" MODIFIED="1518487921059" TEXT="und nicht irgend ein abstraktes CLI-Binding">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1481320870369" HGAP="17" ID="ID_454465129" MODIFIED="1557498707217" TEXT="Rolle des "Model" klären" VSHIFT="20">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1484882430390" HGAP="56" ID="ID_836665320" MODIFIED="1557498707217" TEXT="Diff-Nachrichten" VSHIFT="-23">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1484882437421" ID="ID_1948154354" MODIFIED="1557498707217" TEXT="#1066 concept to pass diff messages">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1484882477368" ID="ID_224140586" MODIFIED="1557498707217" TEXT="Probleme">
|
|
<node CREATED="1484882480568" ID="ID_1399902588" MODIFIED="1557498707217" TEXT="unbekannter Quelltyp"/>
|
|
<node CREATED="1484882487911" ID="ID_651657111" MODIFIED="1557498707217" TEXT="Storage-Management"/>
|
|
<node CREATED="1484882493501" ID="ID_935689465" MODIFIED="1557498707217" TEXT="Übergabe in den Event-Thread">
|
|
<arrowlink COLOR="#b7748e" DESTINATION="ID_31825421" ENDARROW="Default" ENDINCLINATION="560;150;" ID="Arrow_ID_1434676575" STARTARROW="Default" STARTINCLINATION="587;44;"/>
|
|
</node>
|
|
<node CREATED="1484882506156" ID="ID_1297602514" MODIFIED="1557498707217" TEXT="Callback aus dem Event-Thread"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538840339858" ID="ID_304902509" MODIFIED="1557498707217" TEXT="es gibt kein Model im klassischen Sinn">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477784829157" ID="ID_1998357180" MODIFIED="1662053420334" TEXT="Icon-Laden modernisieren">
|
|
<linktarget COLOR="#b73b74" DESTINATION="ID_1998357180" ENDARROW="Default" ENDINCLINATION="-1444;146;" ID="Arrow_ID_373354654" SOURCE="ID_264004203" STARTARROW="None" STARTINCLINATION="-586;-482;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1662052083304" ID="ID_1536704401" MODIFIED="1662052109690">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Stock-IDs sind <font color="#e94312" face="Monospaced">@deprecated</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1662052322319" ID="ID_1280255371" MODIFIED="1662052382908" TEXT="Implementierung: im UiManager">
|
|
<arrowlink COLOR="#864e7a" DESTINATION="ID_297910960" ENDARROW="Default" ENDINCLINATION="-843;-48;" ID="Arrow_ID_154615679" STARTARROW="None" STARTINCLINATION="695;60;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477784821925" ID="ID_1871474250" MODIFIED="1557498707217" TEXT="Styling aufräumen">
|
|
<node CREATED="1477784846162" ID="ID_1164942946" MODIFIED="1557498707217" TEXT="siehe Info zum CssProvider">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_1810760662" ENDARROW="Default" ENDINCLINATION="1600;-25;" ID="Arrow_ID_1610122569" STARTARROW="None" STARTINCLINATION="-840;95;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1538938570760" HGAP="57" ID="ID_1165433334" MODIFIED="1679362063150" TEXT="Neubau" VSHIFT="41">
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1538938751743" FOLDED="true" ID="ID_243888746" MODIFIED="1679361235146">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
»die <b>Timeline</b>«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1477784813895" ID="ID_330280074" MODIFIED="1567875934606">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Aufgabe</u>: <i><font size="4" color="#821b58">populate timeline</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#f9b709" DESTINATION="ID_330280074" ENDARROW="Default" ENDINCLINATION="-37;-88;" ID="Arrow_ID_779644313" SOURCE="ID_635303062" STARTARROW="None" STARTINCLINATION="-34;70;"/>
|
|
<linktarget COLOR="#6db0a6" DESTINATION="ID_330280074" ENDARROW="Default" ENDINCLINATION="-770;358;" ID="Arrow_ID_690602400" SOURCE="ID_1435888336" STARTARROW="None" STARTINCLINATION="1193;46;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1538942842294" ID="ID_1752483939" MODIFIED="1587220691511" TEXT="minimalen Diff für eine Timeline">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1538942872402" ID="ID_932408081" MODIFIED="1561827464711" TEXT="Panel wird erzeugt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1553902314962" ID="ID_1100232681" MODIFIED="1553902322907" TEXT="vorläufige Platzhalter-Implementierung"/>
|
|
<node CREATED="1553902329566" ID="ID_149032705" MODIFIED="1576282358142" TEXT="PanelLocator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
8/2018 there is some overlap with the (not yet fully functional) 
|
|
</p>
|
|
<p>
|
|
ViewLocator in the InteractionDirector. Right now, PanelLocator  
|
|
</p>
|
|
<p>
|
|
fills some gaps here and offers preliminary solutions for some   
|
|
</p>
|
|
<p>
|
|
lookup and allocation tasks ultimately to be performed on a more 
|
|
</p>
|
|
<p>
|
|
abstract level through the ViewSpec-DSL. This corresponds to the 
|
|
</p>
|
|
<p>
|
|
observation, that PanelLocator and WindowLocator are somewhat    
|
|
</p>
|
|
<p>
|
|
tangled currently. The goal is to turn them into access services,
|
|
</p>
|
|
<p>
|
|
and shift the allocation logic to the aforementioned higher level.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1553902425206" ID="ID_908225698" MODIFIED="1576282358142" TEXT="verwendet im Hintergrund noch den alten PanelManager">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...der aber irgendwann (demnächst in diesem Theater) umgebaut/zurückgebaut werden soll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538942878609" ID="ID_689625343" MODIFIED="1557498707218" TEXT="Timeline-Tab wird belegt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538942890792" ID="ID_642469734" MODIFIED="1587220691511" TEXT="hat einen Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538942901590" ID="ID_758238752" MODIFIED="1587220691511" TEXT="ein Clip erscheint">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538943061633" ID="ID_1972040317" MODIFIED="1557498707218" TEXT="minimale Feedback-Aktionen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538943095252" ID="ID_1784185766" MODIFIED="1557498707218" TEXT="drag clip">
|
|
<arrowlink COLOR="#fbd7b5" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-1443;-151;" ID="Arrow_ID_1918638969" STARTARROW="None" STARTINCLINATION="1644;332;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538943104651" ID="ID_948012732" MODIFIED="1557498707218" TEXT="delete clip">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539525762357" ID="ID_401544840" MODIFIED="1557498707218" TEXT="Test-Infrastruktur">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1539525774683" ID="ID_800878475" MODIFIED="1557498707218" TEXT="neuer Tab im TestControl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539525811238" ID="ID_257363214" MODIFIED="1557498707218" TEXT="Buttons / Commands">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1539525817565" ID="ID_609053758" MODIFIED="1557498707218" TEXT="Sequence-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539525949443" ID="ID_1576521954" MODIFIED="1557498707218" STYLE="fork" TEXT="einfacher Standardfall">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539554145649" ID="ID_1360223401" MODIFIED="1557498707218" TEXT="Diff anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539564584429" ID="ID_1716609826" MODIFIED="1557498707218" TEXT="Root-Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539564589548" ID="ID_1561391207" MODIFIED="1586612902058" TEXT="zwei Clips darin">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539525933590" ID="ID_1481796996" MODIFIED="1586612902609" TEXT="Sequence-2">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539525938045" ID="ID_940685408" MODIFIED="1557498707218" TEXT="komplex geschachtelt">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1624020679822" ID="ID_1951868587" MODIFIED="1624020697138" TEXT="mehrere Clips">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539525972400" ID="ID_1975832820" MODIFIED="1557498707218" TEXT="Testdaten-Verwaltung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1539525981879" ID="ID_1137936334" MODIFIED="1557498707218" TEXT="DummySessionConnection etablieren #1042">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1539525998157" ID="ID_1482744929" MODIFIED="1557498707218" TEXT="Diff-tee">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539526035136" ID="ID_1859459942" MODIFIED="1557498707218" TEXT="Daten-Dump">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539528791316" ID="ID_130694385" MODIFIED="1679087465382" TEXT="#1014 populate timeline">
|
|
<arrowlink COLOR="#4989d4" DESTINATION="ID_1661495339" ENDARROW="Default" ENDINCLINATION="143;-11;" ID="Arrow_ID_184610773" STARTARROW="None" STARTINCLINATION="93;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1539528779894" ID="ID_1661495339" MODIFIED="1679087491842" TEXT="#1016 GUI timeline layout structure">
|
|
<linktarget COLOR="#4989d4" DESTINATION="ID_1661495339" ENDARROW="Default" ENDINCLINATION="143;-11;" ID="Arrow_ID_184610773" SOURCE="ID_130694385" STARTARROW="None" STARTINCLINATION="93;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1538940061190" ID="ID_1231562526" MODIFIED="1679087423123" TEXT="Timeline Panel bauen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_712786561" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_433721169" STARTARROW="None" STARTINCLINATION="860;206;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1538940061190" ID="ID_1375216048" MODIFIED="1557498707218" TEXT="verankern im InteractonDirector">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_810032444" ENDARROW="Default" ENDINCLINATION="-451;-531;" ID="Arrow_ID_1378803021" STARTARROW="None" STARTINCLINATION="345;28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538941158698" ID="ID_513093052" MODIFIED="1557498707218" TEXT="vorläufiger Allokator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538941253181" ID="ID_1144811315" MODIFIED="1557498707218" TEXT="multi-Tab-Anzeige">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538940061190" ID="ID_1325225528" MODIFIED="1557498707218" TEXT="Aktion re-Locate">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_1992201258" ENDARROW="Default" ENDINCLINATION="-784;-81;" ID="Arrow_ID_126634995" STARTARROW="None" STARTINCLINATION="651;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538940061190" ID="ID_977311190" MODIFIED="1557498707218" TEXT="Aktion re-Populate">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_501539344" ENDARROW="Default" ENDINCLINATION="-1280;-81;" ID="Arrow_ID_938812574" STARTARROW="None" STARTINCLINATION="335;22;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538939781588" FOLDED="true" ID="ID_1327960211" MODIFIED="1679087404467" TEXT="Timeline Widget bauen">
|
|
<arrowlink COLOR="#7d91d6" DESTINATION="ID_1613745412" ENDARROW="Default" ENDINCLINATION="-63;-32;" ID="Arrow_ID_1377777978" STARTARROW="None" STARTINCLINATION="-144;16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1538941097739" ID="ID_368023009" MODIFIED="1679087363046" TEXT="Klassen anlegen und verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1538941119416" ID="ID_1730845721" MODIFIED="1561827464711" TEXT="Panel">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1553904058976" ID="ID_1691737302" MODIFIED="1553904063506" TEXT="vorläufig"/>
|
|
<node CREATED="1553904064045" ID="ID_243039089" MODIFIED="1553904072649" TEXT="wartet noch auf Umbau PanelManager"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538941122447" ID="ID_1577513149" MODIFIED="1557498707218" TEXT="Widget">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538941130390" ID="ID_813480105" MODIFIED="1557498707218" TEXT="Controller">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538941132710" ID="ID_878237612" MODIFIED="1611914013999" TEXT="Presenter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538940061190" ID="ID_693425928" MODIFIED="1679087373385" TEXT="Timeline-Controller bauen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_391329400" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1839172502" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538940061190" ID="ID_1570849604" MODIFIED="1679087375814" TEXT="Presenter bauen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_1306244096" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_951723874" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_483670351" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1538939792267" ID="ID_1104238784" MODIFIED="1679087400777" TEXT="Präsentation bauen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1538940061190" ID="ID_758873433" MODIFIED="1679087392224" TEXT="Layout-Control">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_562532566" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_130009025" STARTARROW="None" STARTINCLINATION="611;93;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538940061190" ID="ID_1131206858" MODIFIED="1679087394262" TEXT="konkrete Anzeige">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_1999928728" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_506785204" STARTARROW="None" STARTINCLINATION="368;125;"/>
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_1240926804" ENDARROW="Default" ENDINCLINATION="-1142;35;" ID="Arrow_ID_435369727" STARTARROW="None" STARTINCLINATION="394;108;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1624027332115" ID="ID_1575894780" MODIFIED="1679084608014" TEXT="Fork-Heads darstellen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_530086217" ENDARROW="Default" ENDINCLINATION="-1511;-125;" ID="Arrow_ID_1923188182" STARTARROW="None" STARTINCLINATION="1147;124;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1624027322054" ID="ID_416633797" MODIFIED="1679087382174" TEXT="Timeline-Canvas darstellen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_457526663" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1979848335" STARTARROW="None" STARTINCLINATION="709;70;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1624027591203" ID="ID_632606530" MODIFIED="1679087388212" TEXT="Clips darstellen">
|
|
<arrowlink COLOR="#fec680" DESTINATION="ID_1240926804" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1799878244" STARTARROW="None" STARTINCLINATION="933;139;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538938796825" ID="ID_1428561726" MODIFIED="1557498707218">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
»der <b>Viewer</b>«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1538938835228" ID="ID_1454224639" MODIFIED="1557498707218" TEXT="»Properties«">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1538938838779" ID="ID_112266805" MODIFIED="1557498707218" TEXT="»Assets«">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1538938942294" ID="ID_59353951" MODIFIED="1557498707218" TEXT="»Hilfe«">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665345185616" FOLDED="true" ID="ID_101940844" MODIFIED="1665345203007" TEXT="Gestaltung">
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1665345228705" ID="ID_1925832789" MODIFIED="1665345233401" TEXT="Erscheinungsbild">
|
|
<node CREATED="1665345276391" ID="ID_1994007828" MODIFIED="1665345283311" TEXT="Grundsätzliches">
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1665345284722" ID="ID_1079113450" MODIFIED="1665345322919">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
»professionell« bedeutet: <b>unaufdringlich</b> und <b>klar</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1665345366992" ID="ID_121066086" MODIFIED="1665345388417" TEXT="Langfristig anlegen — sinnvolle Neuerungen aufnehmen"/>
|
|
</node>
|
|
<node CREATED="1665345516616" ID="ID_381359824" MODIFIED="1665345520495" TEXT="Design-Aufgaben">
|
|
<node CREATED="1665345521627" ID="ID_1001028233" MODIFIED="1665345524962" TEXT="Themes">
|
|
<node CREATED="1665345537216" ID="ID_1252537015" MODIFIED="1665345553041" TEXT="Eigenständiges Theme">
|
|
<node CREATED="1665345555462" ID="ID_38945127" MODIFIED="1665345585015" TEXT="Grundentscheidungen">
|
|
<node CREATED="1665345645842" ID="ID_1301597547" MODIFIED="1665345659773" TEXT="Stilmuster: Medien-Arbeit"/>
|
|
<node CREATED="1665345660936" ID="ID_161658053" MODIFIED="1665345670197" TEXT="halb abgedunkelt">
|
|
<node CREATED="1665345679342" ID="ID_865100875" MODIFIED="1665345695734" TEXT="Schrift grundsätzlich schwarz"/>
|
|
<node CREATED="1665345697475" ID="ID_636671195" MODIFIED="1665345714885" TEXT="dunkel genug, damit Inhalte hervortreten"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665345526106" ID="ID_1461752003" MODIFIED="1665346437138" TEXT="Integration Desktop-Themes">
|
|
<arrowlink COLOR="#5284c5" DESTINATION="ID_441937774" ENDARROW="Default" ENDINCLINATION="-1007;-1223;" ID="Arrow_ID_1036308053" STARTARROW="None" STARTINCLINATION="-344;581;"/>
|
|
<node CREATED="1665345607216" ID="ID_1511504840" MODIFIED="1665345609635" TEXT="hell"/>
|
|
<node CREATED="1665345610391" ID="ID_527297290" MODIFIED="1665345612315" TEXT="dunkel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665345726447" ID="ID_1745324854" MODIFIED="1665345733936" TEXT="Grafik-Elemente">
|
|
<node CREATED="1665345734862" ID="ID_1876392387" MODIFIED="1665802081759" TEXT="Basis-Icons">
|
|
<arrowlink COLOR="#8487c2" DESTINATION="ID_1034074054" ENDARROW="Default" ENDINCLINATION="-757;-939;" ID="Arrow_ID_186260230" STARTARROW="None" STARTINCLINATION="-258;57;"/>
|
|
<node CREATED="1665345747229" ID="ID_354372547" MODIFIED="1665345789624" TEXT="möglichst eigenen Basis-Satz verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit wir nicht der extremen Variabilität für Desktop-Icons unterliegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1665345798270" ID="ID_194586692" MODIFIED="1665345807889" TEXT="Standard-Aktionen aber vom Desktiop">
|
|
<node CREATED="1665345812836" ID="ID_1218015983" MODIFIED="1665345840211" TEXT="New, Open, Save, Undo/Redo, Clipboard"/>
|
|
</node>
|
|
<node CREATED="1665345851063" ID="ID_1597996676" MODIFIED="1665345875776" TEXT="Charakter-Zeichen">
|
|
<node COLOR="#338800" CREATED="1665346240663" ID="ID_1763162264" MODIFIED="1665346249075" TEXT="Lumiera-Logo">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665345876873" FOLDED="true" ID="ID_1015286402" MODIFIED="1665802131501" TEXT="Placement-Icon">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1665345929580" ID="ID_60603155" MODIFIED="1665802111894" TEXT="unterstreicht den Grundcharakter von Lumiera"/>
|
|
<node CREATED="1665345968399" ID="ID_540465051" MODIFIED="1665802111894" TEXT="soll pervasiv verwendet werden">
|
|
<node CREATED="1665346130257" ID="ID_858257568" MODIFIED="1665802111894" TEXT="für alle "strukturellen" Verwendungen"/>
|
|
<node COLOR="#435e98" CREATED="1665345985124" ID="ID_1904965684" MODIFIED="1665855410112" TEXT="⟹ integriert in ElementBoxWidget">
|
|
<arrowlink COLOR="#6681be" DESTINATION="ID_178231784" ENDARROW="Default" ENDINCLINATION="-1422;-171;" ID="Arrow_ID_287037902" STARTARROW="None" STARTINCLINATION="626;53;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665346164380" ID="ID_219154210" MODIFIED="1665802111894" TEXT="Gestaltung als Emblem">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1665346202240" ID="ID_417992919" MODIFIED="1665802111894" TEXT="mehrdeutig"/>
|
|
<node CREATED="1665346191201" ID="ID_341321105" MODIFIED="1665802111894" TEXT="prägnant"/>
|
|
<node CREATED="1665346199033" ID="ID_437888137" MODIFIED="1665802111894" TEXT="abstrakt"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1665346273206" ID="ID_947650361" MODIFIED="1665346298608" TEXT="Aktivitäts-Anzeige">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665346300639" ID="ID_860259459" MODIFIED="1665346327196" TEXT="Idee: das »Auge«-Icon von Joel Holdsworth">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665346287044" FOLDED="true" ID="ID_748668128" MODIFIED="1665855636691" TEXT="Expander und Menü">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1665348077444" ID="ID_488652048" MODIFIED="1665801857144" TEXT="Idee">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1665348091322" ID="ID_1073825658" MODIFIED="1665348096120" TEXT="Dreieck als Pfeil"/>
|
|
<node CREATED="1665348096802" ID="ID_1569524261" MODIFIED="1665348109205" TEXT="wahlweise aufwärts, abwärts oder rechts gedreht"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665348136916" FOLDED="true" ID="ID_759870258" MODIFIED="1665802054607" TEXT="Ausführung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1665348145307" ID="ID_102563036" MODIFIED="1665348150902" TEXT="erhaben ohne Rahmen">
|
|
<node CREATED="1665348443628" ID="ID_1447716255" MODIFIED="1665348455285" TEXT="2px Kontur abgedunkelt"/>
|
|
<node CREATED="1665348457668" ID="ID_48846452" MODIFIED="1665348470750" TEXT="Glanzlicht aufgehellt im Inneren"/>
|
|
<node CREATED="1665348472343" ID="ID_1076446520" MODIFIED="1665348498629" TEXT="Inset-Kontur sub-Pixel"/>
|
|
</node>
|
|
<node CREATED="1665348212810" ID="ID_373482856" MODIFIED="1665348225676" TEXT="Rahmen symmetrisch füllen">
|
|
<node CREATED="1665348226825" ID="ID_1659240915" MODIFIED="1665349953403" TEXT="+3px Gehrung"/>
|
|
<node CREATED="1665348267595" ID="ID_1466240766" MODIFIED="1665348436848" TEXT="+2px Schatten"/>
|
|
</node>
|
|
<node CREATED="1665350012213" ID="ID_1923573190" MODIFIED="1665363524296" TEXT="möglichst nur mit Transparenz arbeiten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit das Icon in verschiedenstem Kontext gleichermaßen funktioniert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665363525484" ID="ID_1637269112" MODIFIED="1665363834236" TEXT="mühsam... will nicht recht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1665363537099" ID="ID_1774949023" MODIFIED="1665363547270" TEXT="das Icon ist mi 16x16px verdammt klein"/>
|
|
<node CREATED="1665363548141" ID="ID_1303573631" MODIFIED="1665363566155" TEXT="vermutlich wollte ich viel zu viel">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1665363577646" ID="ID_1126441793" MODIFIED="1665363583905" TEXT="sowohl Rahmen"/>
|
|
<node CREATED="1665363584493" ID="ID_1440525144" MODIFIED="1665363588024" TEXT="alsauch Glanzlicht"/>
|
|
<node CREATED="1665363588708" ID="ID_195148225" MODIFIED="1665363595255" TEXT="und ein Inset"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665363605996" ID="ID_491620065" MODIFIED="1665363830324" TEXT="vereinfachen....?">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1665363705644" ID="ID_1138426529" MODIFIED="1665363714032" TEXT="großzügige Fläche"/>
|
|
<node CREATED="1665363714710" ID="ID_938502860" MODIFIED="1665363752976" TEXT="alle zusätzlichen Tricks weglassen...">
|
|
<arrowlink COLOR="#406f78" DESTINATION="ID_1971428167" ENDARROW="Default" ENDINCLINATION="27;-48;" ID="Arrow_ID_1069676467" STARTARROW="None" STARTINCLINATION="-197;15;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665363649940" ID="ID_1971428167" MODIFIED="1665799112395" TEXT="in der Applikation gar nicht so schlecht">
|
|
<linktarget COLOR="#406f78" DESTINATION="ID_1971428167" ENDARROW="Default" ENDINCLINATION="27;-48;" ID="Arrow_ID_1069676467" SOURCE="ID_938502860" STARTARROW="None" STARTINCLINATION="-197;15;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1665363758814" ID="ID_1752890921" MODIFIED="1665799109913" TEXT="jetzt mal nur ein einfaches Innen-Symbol (Dreieck) versuchen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665363793568" ID="ID_34619055" MODIFIED="1665799109920" TEXT="und die Schatten auf den Gehrungen zurücknehmen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665363810022" ID="ID_816374371" MODIFIED="1665799109920" TEXT="und dafür noch einen drop-Shadow dazubauen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665801881413" ID="ID_856020386" MODIFIED="1665855536788" TEXT="Ergebnis: rein plastisch, glänzend, scharf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
letztlich bin ich davon abgekommen, einen <i>gezeichneten </i>Pfeil zu integrieren; auch die Insets habe ich aufgegeben, dadurch wird das Design stringenter. Die Hervorhebung erfolgt nur durch ein Glanzlicht oben links, im Zusammenspiel mit den 2px Gehrungen und einem zusätzlichen Schatten an der Kehle der Gehrung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665855301858" ID="ID_446507732" MODIFIED="1665855630056" TEXT="vielleicht etwas zu hell geraten?">
|
|
<linktarget COLOR="#f27d99" DESTINATION="ID_446507732" ENDARROW="Default" ENDINCLINATION="356;501;" ID="Arrow_ID_1734621230" SOURCE="ID_1045883941" STARTARROW="None" STARTINCLINATION="225;17;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1665800212205" ID="ID_726081290" MODIFIED="1665800217512" TEXT="Richtlinien">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1665800359809" FOLDED="true" ID="ID_1618186555" MODIFIED="1665801587336" TEXT="SVG sauber halten">
|
|
<arrowlink COLOR="#4660c4" DESTINATION="ID_1598706179" ENDARROW="Default" ENDINCLINATION="-1583;-200;" ID="Arrow_ID_1296361422" STARTARROW="Default" STARTINCLINATION="-2177;271;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1665800366152" ID="ID_1831328523" MODIFIED="1665800384165" TEXT="__Icon_TEMPLATE verwenden"/>
|
|
<node CREATED="1665800390503" ID="ID_465047171" MODIFIED="1665800417246" TEXT="Stacking-Order stets gleich (kleiner ‣‣ größer)"/>
|
|
<node CREATED="1665800464019" ID="ID_1053244575" MODIFIED="1665800476310" TEXT="stets gruppieren und sinnvoll gliedern"/>
|
|
<node CREATED="1665800420413" ID="ID_1816161542" MODIFIED="1665800429423" TEXT="IDs der Hauptgruppen benennen"/>
|
|
<node CREATED="1665800481228" ID="ID_1358268582" MODIFIED="1665800494158" TEXT="Transformationen anwenden">
|
|
<node CREATED="1665800496063" ID="ID_547172174" MODIFIED="1665801184257" TEXT="Problem: Gruppen und Filter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Inkscape wendet Transformationen normalerweise nur auf Blatt-Elemente direkt an; sonst fügt es ein "transform"-Element ein; dieses ist eine Matrix für homogene Koordinaten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665800514028" ID="ID_1925132136" MODIFIED="1665801292480" TEXT="Filter deaktivieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man den Filter entfernt / auf Null dreht (Blur), dann wendet Inkscape die Transformation an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1665800503910" ID="ID_1120591972" MODIFIED="1665801294931" TEXT="Gruppen auflösen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man die Gruppe auflöst, wendet Inkscape die Transformation auf jedes Einzelelement an, und schiebt eine inverse Transformation in alle referenzierten Gradienten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665801312049" ID="ID_904420529" MODIFIED="1665801548562" TEXT="Styles kann man bisweilen vereinfachen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und Inkscape wird das erhalten, solange man die betr. Features nicht wieder aktiviert. Im Besonderen kann man
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
alle "Stroke"-Features entfernen, wenn der Stroke deaktiviert ist
|
|
</li>
|
|
<li>
|
|
opacity:1 weglassen
|
|
</li>
|
|
<li>
|
|
diverse Vector-Filter und display-styles weglassen (wenn sie auf dem default-Wert stehen)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1665801453869" ID="ID_416037424" MODIFIED="1665801551225" TEXT="numerisch versäubern">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1665801466126" ID="ID_1192263503" MODIFIED="1665801482470" TEXT="bedingt durch Transformationen werden Kreise oft zu Ellipsen"/>
|
|
<node CREATED="1665801487210" ID="ID_991962556" MODIFIED="1665801525411" TEXT="Transparenzen, Opacity und Graustufen driften auch bisweilen weg"/>
|
|
</node>
|
|
<node CREATED="1665801531178" ID="ID_704543645" MODIFIED="1665801537800" TEXT="nicht übertreiben">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665800221636" ID="ID_1388153957" MODIFIED="1665801591668" TEXT="plastische Modellierung nur mit Transparenz">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1665800287403" ID="ID_1441434972" MODIFIED="1665800301597" TEXT="Farben">
|
|
<node CREATED="1665800302682" ID="ID_1441318458" MODIFIED="1665800316090" TEXT="als Schmuck-Farben"/>
|
|
<node CREATED="1665800316735" ID="ID_337763174" MODIFIED="1665800336568" TEXT="als subtile Tönung"/>
|
|
</node>
|
|
<node CREATED="1665801624247" ID="ID_738176993" MODIFIED="1665801755873" TEXT="Hinting und Scharfzeichnen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist Handarbeit und erfordert Erfahrung
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wichtige Formen auf eine Grid-Linie verschieben
|
|
</li>
|
|
<li>
|
|
Gewicht exakt vertikaler/horizontaler Linien beachten
|
|
</li>
|
|
<li>
|
|
scharfzeichnen mit einer sub-Pixel-Linie mit komplementärem Helligkeitswert
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665801812606" ID="ID_437217153" MODIFIED="1665801844475" TEXT="1-2 Pixel »Luft« lassen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
notwendig, damit Hinting, Scharfzeichnen und drop-Shaddows funktionieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665345893180" ID="ID_980730763" MODIFIED="1665345897350" TEXT="custom-drawing">
|
|
<node CREATED="1665345898401" ID="ID_1689490488" MODIFIED="1665345902340" TEXT="Timeline">
|
|
<node CREATED="1665345910140" ID="ID_1049224098" MODIFIED="1665345922135" TEXT="Farben aus normalem Stylesheet "fischen""/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665345451709" ID="ID_959477781" MODIFIED="1665345455640" TEXT="Verhaltensmuster">
|
|
<node CREATED="1665346345101" ID="ID_1210725333" MODIFIED="1665346349840" TEXT="Einsatz von Farben"/>
|
|
<node CREATED="1665346350340" ID="ID_1916831615" MODIFIED="1665346353523" TEXT="Animationen"/>
|
|
</node>
|
|
<node CREATED="1665345501421" ID="ID_412402750" MODIFIED="1665345503833" TEXT="Methode"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534336252375" FOLDED="true" HGAP="216" ID="ID_1755017021" MODIFIED="1679362496041" TEXT="Hilfsmittel" VSHIFT="6">
|
|
<node CREATED="1534336320373" ID="ID_708892482" MODIFIED="1557498707218" TEXT="Grundbausteine">
|
|
<node CREATED="1537659522174" ID="ID_1583657425" MODIFIED="1679362063142" TEXT="primary widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Definition</b>: komplexe Widget-Strukturen,
|
|
</p>
|
|
<p>
|
|
welche nur einmal in dieser speziellen Konfiguration exisiteren,
|
|
</p>
|
|
<p>
|
|
und dabei eine zentrale Rolle im UI spielen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<u>Beispiel</u>:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Timeline
|
|
</li>
|
|
<li>
|
|
Property-Grid
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1537659866783" ID="ID_1613745412" MODIFIED="1557498707218" TEXT="Timeline">
|
|
<linktarget COLOR="#7d91d6" DESTINATION="ID_1613745412" ENDARROW="Default" ENDINCLINATION="-63;-32;" ID="Arrow_ID_1377777978" SOURCE="ID_1327960211" STARTARROW="None" STARTINCLINATION="-144;16;"/>
|
|
</node>
|
|
<node CREATED="1537659870415" ID="ID_1181375258" MODIFIED="1557498707218" TEXT="Property-Grid"/>
|
|
</node>
|
|
<node CREATED="1537659527741" ID="ID_856745741" MODIFIED="1679362063141" TEXT="building blocks">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Definition</b>: speziell konfigurierte und verdrahtete Teil-Komponenten,
|
|
</p>
|
|
<p>
|
|
welche wiederholt an verschiedensten Stellen im UI eingesetzt werden,
|
|
</p>
|
|
<p>
|
|
und sich dort jeweils konsistent und uniform verhalten.
|
|
</p>
|
|
<p>
|
|
<u>Beispiel</u>:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Timecode-Widget
|
|
</li>
|
|
<li>
|
|
Placement-Widget
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1538583873795" ID="ID_1515056203" MODIFIED="1557498707218" TEXT="spezifisch">
|
|
<node CREATED="1537659880597" ID="ID_1214109906" MODIFIED="1557498707218" TEXT="Timecode"/>
|
|
<node CREATED="1537659890292" ID="ID_1230379898" MODIFIED="1557498707218" TEXT="Placement"/>
|
|
</node>
|
|
<node CREATED="1538583877106" ID="ID_1825646582" MODIFIED="1557498707218" TEXT="generisch">
|
|
<node CREATED="1538583886065" FOLDED="true" ID="ID_217810080" MODIFIED="1557498707218" TEXT="ErrorLogView">
|
|
<linktarget COLOR="#98a2c5" DESTINATION="ID_217810080" ENDARROW="Default" ENDINCLINATION="1891;-1228;" ID="Arrow_ID_1688804340" SOURCE="ID_1745777873" STARTARROW="None" STARTINCLINATION="-1261;74;"/>
|
|
<node CREATED="1538583894072" ID="ID_1836686899" MODIFIED="1557498707218" TEXT="Gtk::TextView + Mark-Index">
|
|
<arrowlink COLOR="#3251a9" DESTINATION="ID_243616989" ENDARROW="Default" ENDINCLINATION="-2060;-1360;" ID="Arrow_ID_794678010" STARTARROW="None" STARTINCLINATION="-3506;-148;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537961656982" ID="ID_1251358269" MODIFIED="1576282358140" TEXT="frameworks">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vorbereitete Grundstrukturen für immer wiederkehrende Setups
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1537961734956" ID="ID_345535043" MODIFIED="1567875424269" TEXT="Notebook-Widget">
|
|
<linktarget COLOR="#7895b6" DESTINATION="ID_345535043" ENDARROW="Default" ENDINCLINATION="-60;247;" ID="Arrow_ID_81056795" SOURCE="ID_18019089" STARTARROW="None" STARTINCLINATION="382;0;"/>
|
|
<node CREATED="1537961776184" ID="ID_167848646" MODIFIED="1537961791126" TEXT="Problematik">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1537961797061" ID="ID_104206298" MODIFIED="1537961806159" TEXT="extrem viele Komponenten-Widgets"/>
|
|
<node CREATED="1537961807436" ID="ID_1420879044" MODIFIED="1537961819742" TEXT="Namenskollisionen zwischen Pages"/>
|
|
<node CREATED="1537961832009" ID="ID_380956030" MODIFIED="1537961842907" TEXT="Boilerplate-Code goes Spaghetti"/>
|
|
</node>
|
|
<node CREATED="1537961848735" ID="ID_1187685583" MODIFIED="1537961889952" TEXT="Lösungs-Ideen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1537961860374" ID="ID_933681325" MODIFIED="1537961871080" TEXT="managing container"/>
|
|
<node CREATED="1537961872836" ID="ID_1674501396" MODIFIED="1537961884942" TEXT="builder lambda"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537961894394" ID="ID_1253130867" MODIFIED="1537969684728" TEXT="Prototyp">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537961917592" ID="ID_591860371" MODIFIED="1537962293792" TEXT="im TestControl">
|
|
<linktarget COLOR="#6ea8be" DESTINATION="ID_591860371" ENDARROW="Default" ENDINCLINATION="1162;51;" ID="Arrow_ID_1534615646" SOURCE="ID_1553519505" STARTARROW="None" STARTINCLINATION="-185;836;"/>
|
|
</node>
|
|
<node CREATED="1537961950003" ID="ID_1083792924" MODIFIED="1576282358140" TEXT="Schema "managing container"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das erscheint mir bodenständiger.
|
|
</p>
|
|
<p>
|
|
GUI-Programmierung muß bodenstäding bleiben,
|
|
</p>
|
|
<p>
|
|
man gewinnt hier nichts durch blendende Abstraktionen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Ich hoffe, daß der Hilfscontainer <i>nahezu transparent </i>gemacht werden kann.
|
|
</p>
|
|
<p>
|
|
Und der Rest sollte so <i>vertraut</i> aussehen, daß es selbsterklärend wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534336335963" ID="ID_1176525116" MODIFIED="1557498707218" TEXT="Werkzeug">
|
|
<node COLOR="#338800" CREATED="1534334810537" FOLDED="true" ID="ID_1326202399" MODIFIED="1561827464715" TEXT="Link zum Widget">
|
|
<linktarget COLOR="#a66b86" DESTINATION="ID_1326202399" ENDARROW="Default" ENDINCLINATION="279;-1333;" ID="Arrow_ID_664593340" SOURCE="ID_203145360" STARTARROW="None" STARTINCLINATION="-1296;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534334914667" ID="ID_511749457" MODIFIED="1534436573129" TEXT="smart-Ref">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534334939159" ID="ID_1853703071" MODIFIED="1534436570387" TEXT="leer konstruierbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534334944207" ID="ID_1989000221" MODIFIED="1534342998767" TEXT="bool testbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534334964700" ID="ID_1509791330" MODIFIED="1534343003956" TEXT="dereferenzierbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534335220066" ID="ID_132223755" MODIFIED="1534388600416" TEXT="target anbinden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1534335240246" ID="ID_1480460700" MODIFIED="1534336108969" TEXT="sigc::trackable">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534336110858" ID="ID_280796006" MODIFIED="1534388602201" TEXT="connect()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534336116617" ID="ID_1274372728" MODIFIED="1534388603779" TEXT="clear()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534335253941" ID="ID_269300171" MODIFIED="1534388596484" TEXT="magisch kopierbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534336069415" ID="ID_1775411301" MODIFIED="1534337958030">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Name: <b>WLink</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534336127895" HGAP="21" ID="ID_352867763" MODIFIED="1534436566889" TEXT="WLink_test" VSHIFT="9">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534340031277" ID="ID_506504727" MODIFIED="1534341378412" TEXT="test-dummy-trackable">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534340016027" ID="ID_109515645" MODIFIED="1534388606258" TEXT="verify_standardUsage">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534340023288" ID="ID_1266509201" MODIFIED="1534388607832" TEXT="verify_reconnect">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534340028094" ID="ID_1406183687" MODIFIED="1534388609833" TEXT="verify_copy">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534436582390" ID="ID_880451727" MODIFIED="1534436621371" TEXT="nur EX_SANE">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1534436589806" ID="ID_1530771493" MODIFIED="1534436645751" TEXT="unter der Annahme, daß sigc::trackable EX_SANE ist">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534436609323" ID="ID_1966799512" MODIFIED="1534436641103" TEXT="nicht wirklich geprüft">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1567875279032" FOLDED="true" ID="ID_740945922" MODIFIED="1679361296393" TEXT="Test-Hilfsmittel">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1567875285952" ID="ID_979231150" MODIFIED="1567875288691" TEXT="TestControl"/>
|
|
<node COLOR="#435e98" CREATED="1567875664340" ID="ID_994953692" MODIFIED="1567875770727">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>TestControl</b> Dialogbox
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#57b762" DESTINATION="ID_1760873318" ENDARROW="Default" ENDINCLINATION="-989;0;" ID="Arrow_ID_782679142" STARTARROW="None" STARTINCLINATION="-756;-143;"/>
|
|
<node CREATED="1567875290021" ID="ID_286133902" MODIFIED="1567875757319" TEXT="ein non-modaler Dialog"/>
|
|
<node CREATED="1567875314411" ID="ID_26242186" MODIFIED="1567875341444" TEXT="erreichbar im Wizard | Menü "help" > "self tests...""/>
|
|
<node CREATED="1567875342584" ID="ID_18019089" MODIFIED="1576282358139" TEXT="hat ein Notebook mit diversen Tabs...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welche ad hoc mit beiläufig geschriebenem Debug/Test-Code belegt werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7895b6" DESTINATION="ID_345535043" ENDARROW="Default" ENDINCLINATION="-60;247;" ID="Arrow_ID_81056795" STARTARROW="None" STARTINCLINATION="382;0;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1567875433443" ID="ID_1033273101" MODIFIED="1567875940590" TEXT="TestControl-Tabs">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1567875526281" ID="ID_504220515" MODIFIED="1567875602930" TEXT="Tab-1: #1099 : Nachrichten via ProcDispatcher und UI-Bus senden an das ErrorLogDisplay">
|
|
<arrowlink COLOR="#64bf95" DESTINATION="ID_1925240675" ENDARROW="Default" ENDINCLINATION="-664;1183;" ID="Arrow_ID_1404986843" STARTARROW="None" STARTINCLINATION="821;0;"/>
|
|
</node>
|
|
<node CREATED="1567875813488" ID="ID_1435888336" MODIFIED="1567875934606" TEXT="Tab-2: #1014 : »populate Timeline« ― generiert Dummy-Timelines für das GUI">
|
|
<arrowlink COLOR="#6db0a6" DESTINATION="ID_330280074" ENDARROW="Default" ENDINCLINATION="-770;358;" ID="Arrow_ID_690602400" STARTARROW="None" STARTINCLINATION="1193;46;"/>
|
|
<node CREATED="1567876207795" HGAP="44" ID="ID_320559885" MODIFIED="1567876244788" TEXT="kann jetzt auch beliebige mark()-Nachricht senden" VSHIFT="25">
|
|
<linktarget COLOR="#687584" DESTINATION="ID_320559885" ENDARROW="Default" ENDINCLINATION="-28;61;" ID="Arrow_ID_1133205207" SOURCE="ID_1232074573" STARTARROW="Default" STARTINCLINATION="206;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567876056816" ID="ID_1341115014" MODIFIED="1575131552362" TEXT="UIBus::mark - Nachricht an beliebiges Element senden">
|
|
<linktarget COLOR="#54bbd6" DESTINATION="ID_1341115014" ENDARROW="Default" ENDINCLINATION="-3095;0;" ID="Arrow_ID_547692411" SOURCE="ID_1701413392" STARTARROW="None" STARTINCLINATION="1167;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1567876176943" ID="ID_1120090317" MODIFIED="1567876185194" TEXT="schnell geschriebener Debug/Test-Code"/>
|
|
<node CREATED="1567876185972" ID="ID_1232074573" MODIFIED="1567876244788" TEXT="im Moment mal eben auf Tab-2 vom TestControl eingehängt">
|
|
<arrowlink COLOR="#687584" DESTINATION="ID_320559885" ENDARROW="Default" ENDINCLINATION="-28;61;" ID="Arrow_ID_1133205207" STARTARROW="Default" STARTINCLINATION="206;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534336325916" ID="ID_762624766" MODIFIED="1661695557878" TEXT="Bindeglieder">
|
|
<node CREATED="1661695565675" ID="ID_1782348054" MODIFIED="1661695571623" TEXT="UI-Koordinaten"/>
|
|
<node CREATED="1661695572958" ID="ID_913092890" MODIFIED="1661695581265" TEXT="Docking"/>
|
|
<node CREATED="1661695582329" ID="ID_42645093" MODIFIED="1661695594438" TEXT="Pop-up-Menüs"/>
|
|
<node CREATED="1661695595096" ID="ID_1811221630" MODIFIED="1661695602731" TEXT="Property-Box-Connection"/>
|
|
</node>
|
|
<node CREATED="1537659082073" ID="ID_986070389" MODIFIED="1557498707218" TEXT="Schema">
|
|
<node CREATED="1618677634680" ID="ID_1029801853" MODIFIED="1618677651554" TEXT="Konventionen">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618677661972" ID="ID_1188964744" MODIFIED="1618677666928" TEXT="GTK-Datentypen">
|
|
<node CREATED="1618677671271" ID="ID_1068107778" MODIFIED="1618677684903" TEXT="Unterscheidung Framework-nah">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1618677686257" ID="ID_144011796" MODIFIED="1618677697439" TEXT="Framework-naher Code verwendet GTK-Datentypen">
|
|
<node CREATED="1618677785956" ID="ID_472749737" MODIFIED="1618677813236" TEXT="GString für UI-Labels"/>
|
|
<node CREATED="1618677813944" ID="ID_389115801" MODIFIED="1618678210573" TEXT="gdouble für Screen-Koordinaten">
|
|
<linktarget COLOR="#798bb0" DESTINATION="ID_389115801" ENDARROW="Default" ENDINCLINATION="1665;148;" ID="Arrow_ID_267819706" SOURCE="ID_1287724015" STARTARROW="None" STARTINCLINATION="2440;141;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618677699359" ID="ID_1890482479" MODIFIED="1618677716892" TEXT="Aber: GObject ist zu vermeiden wannimmer möglich">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1618677723026" ID="ID_910079217" MODIFIED="1618677755632" TEXT="keine Sprache über der Sprache schaffen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1618677765275" ID="ID_1013650167" MODIFIED="1618677775137" TEXT="die Ausdrucksmittel von C++ sind gut genug"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537659311850" ID="ID_741254991" MODIFIED="1557498707218" TEXT="Struktur">
|
|
<node CREATED="1618677865801" ID="ID_708518061" MODIFIED="1618678028294" TEXT="Innere Struktur: Struktur-Schemata">
|
|
<arrowlink COLOR="#86889b" DESTINATION="ID_974158229" ENDARROW="Default" ENDINCLINATION="-381;-944;" ID="Arrow_ID_1816207037" STARTARROW="None" STARTINCLINATION="1299;101;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1537659316321" FOLDED="true" ID="ID_1046162234" MODIFIED="1679361287682" TEXT="Style">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1537660235757" ID="ID_1679504678" MODIFIED="1679362063137" TEXT="Leitlinie">
|
|
<node CREATED="1537660241420" ID="ID_1559839657" MODIFIED="1557498707218" TEXT="möglichst generisch belassen"/>
|
|
<node CREATED="1537660355669" ID="ID_407535546" MODIFIED="1557498707218" TEXT="zentrale Palette für Extra-Auszeichnungen">
|
|
<linktarget COLOR="#8f81b2" DESTINATION="ID_407535546" ENDARROW="Default" ENDINCLINATION="3769;-2728;" ID="Arrow_ID_1203118148" SOURCE="ID_758790930" STARTARROW="None" STARTINCLINATION="-1594;0;"/>
|
|
<node CREATED="1537661251763" ID="ID_896084387" MODIFIED="1557498707218" TEXT="virtuelle Widget-Struktur"/>
|
|
<node CREATED="1537661267561" ID="ID_1282505273" MODIFIED="1557498707218" TEXT="systematisch organisiert"/>
|
|
<node CREATED="1537661279344" ID="ID_635630811" MODIFIED="1557498707219" TEXT="wird bei Bedarf abgefragt"/>
|
|
<node CREATED="1537661322914" ID="ID_165076190" MODIFIED="1557498707219" TEXT="per synthetisiertem Widget-Path"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1678573145778" ID="ID_529832770" MODIFIED="1678576114059">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font size="5">Style-Scheme</font> for Lumiera
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8b1d60" DESTINATION="ID_281557130" ENDARROW="Default" ENDINCLINATION="-986;-81;" ID="Arrow_ID_1840161927" STARTARROW="None" STARTINCLINATION="-625;67;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1678573175156" ID="ID_1210386404" MODIFIED="1678573180188" TEXT="entwickeln...">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538588393995" ID="ID_1149076483" MODIFIED="1678573209829">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
#1168 : find a way to manage style of
|
|
</p>
|
|
<p>
|
|
              custom extended UI elements
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1678575013546" HGAP="59" ID="ID_1275966904" MODIFIED="1678575229481" TEXT="Lösungsansatz per Prototyp bestätigt" VSHIFT="21">
|
|
<arrowlink COLOR="#40a5bc" DESTINATION="ID_1949200690" ENDARROW="Default" ENDINCLINATION="-2003;-104;" ID="Arrow_ID_398104912" STARTARROW="None" STARTINCLINATION="2327;166;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1678576263610" ID="ID_1861505787" MODIFIED="1678576267709" TEXT="Spezialitäten">
|
|
<node COLOR="#435e98" CREATED="1678576309372" ID="ID_650016552" MODIFIED="1678576514278" TEXT="CSS-Styling der Timeline">
|
|
<arrowlink COLOR="#5f7783" DESTINATION="ID_1232986902" ENDARROW="Default" ENDINCLINATION="2218;-176;" ID="Arrow_ID_691307229" STARTARROW="None" STARTINCLINATION="7697;843;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561898940013" ID="ID_1812249534" MODIFIED="1561898964578" TEXT="Aufgabe: globaler Layout-Manager">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1561898713460" ID="ID_44229333" MODIFIED="1561899095357" TEXT="Aufgabe: Theming/Styling unserer speziellen UI-Elemente">
|
|
<linktarget COLOR="#7339d4" DESTINATION="ID_44229333" ENDARROW="Default" ENDINCLINATION="-1147;0;" ID="Arrow_ID_61031233" SOURCE="ID_1426731428" STARTARROW="None" STARTINCLINATION="797;0;"/>
|
|
<linktarget COLOR="#555080" DESTINATION="ID_44229333" ENDARROW="Default" ENDINCLINATION="-1124;49;" ID="Arrow_ID_1040482296" SOURCE="ID_1068573244" STARTARROW="None" STARTINCLINATION="808;-134;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666378011037" ID="ID_134472006" MODIFIED="1666378421971" TEXT="#1252 Timeline display-evaluation-pass">
|
|
<arrowlink COLOR="#735667" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="68;-547;" ID="Arrow_ID_672337506" STARTARROW="None" STARTINCLINATION="1091;68;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538695838262" ID="ID_407627538" MODIFIED="1557498707219" TEXT="lumiera-(light|dark)-theme-complement.css">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538695878400" ID="ID_1937289801" MODIFIED="1557498707219" TEXT="wir liefern Stylesheets zur Ergänzung des System-Themas">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538695897046" ID="ID_382934959" MODIFIED="1557498707219" TEXT="als wählbare Alternative zu unserem Applikations-Stylesheet"/>
|
|
<node CREATED="1538695912900" ID="ID_161292075" MODIFIED="1557498707219" TEXT="diese enthalten nur die minimal notwendigen Ergänzungen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538702238122" ID="ID_1439139961" MODIFIED="1557498707219" TEXT="#1170 care for interplay with light, dark and high contrast themes">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1538696008591" ID="ID_441937774" MODIFIED="1679362063137" TEXT="Lumiera Stylesheet">
|
|
<linktarget COLOR="#5284c5" DESTINATION="ID_441937774" ENDARROW="Default" ENDINCLINATION="-1007;-1223;" ID="Arrow_ID_1036308053" SOURCE="ID_1461752003" STARTARROW="None" STARTINCLINATION="-344;581;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="flag"/>
|
|
<node CREATED="1538696023165" ID="ID_698985788" MODIFIED="1557498707219" TEXT="lumiera.css"/>
|
|
<node CREATED="1538696026884" ID="ID_1880901613" MODIFIED="1557498707219" TEXT="wir liefern unser eigenes Applikations-Stylesheet">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538696052161" ID="ID_1715392243" MODIFIED="1557498707219" TEXT="abgeleitet vom Ardour-Stylesheet">
|
|
<arrowlink DESTINATION="ID_1918479292" ENDARROW="Default" ENDINCLINATION="132;0;" ID="Arrow_ID_146898233" STARTARROW="None" STARTINCLINATION="74;-5;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538696060808" ID="ID_82400982" MODIFIED="1557498707219" TEXT="seinerzeit von Joel Holdsworth">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538696069551" ID="ID_1095339421" MODIFIED="1557498707219" TEXT="dezenter Meda-Application look">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1538696238952" ID="ID_1693017073" MODIFIED="1557498707219" TEXT="Portierung GTK2 -> CSS (GTK3)">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538696262533" ID="ID_472703036" MODIFIED="1557498707219" TEXT="2014 rudimentär, dann steckengeblieben">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1538696307615" ID="ID_1918479292" MODIFIED="1557498707219" TEXT="was macht eigentlich Ardour heute?">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1918479292" ENDARROW="Default" ENDINCLINATION="132;0;" ID="Arrow_ID_146898233" SOURCE="ID_1715392243" STARTARROW="None" STARTINCLINATION="74;-5;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1538699094129" HGAP="61" ID="ID_1901117568" MODIFIED="1557498707219" TEXT="Bäääh! GTK-2 verwenden" VSHIFT="3">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538702167475" ID="ID_1067979840" MODIFIED="1557498707219" TEXT="#1023 Lumiera GTK stylesheet">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538710332658" ID="ID_584658644" MODIFIED="1557498707219" TEXT="Bugfixes...">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538710354271" ID="ID_79614027" MODIFIED="1557498707219" TEXT="inherit verwenden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538710363741" ID="ID_1130951877" MODIFIED="1557498707219" TEXT="Widget-Namen korrekt schreiben">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1538710376229" ID="ID_806378376" MODIFIED="1557498707219" TEXT="in GTK-2 war das z.B. GtkWindow">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538710388956" ID="ID_17203500" MODIFIED="1557498707219" TEXT="in GTK-3 entspricht das window">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1538710407602" ID="ID_1860886507" MODIFIED="1576282358138" TEXT="Regel...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den Klassennamen ohne das Namespace-Präfix "GTK", und alles lower case.
|
|
</p>
|
|
<p>
|
|
Im Zweifelsfall den GTK+ Inspector verwenden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538696355832" ID="ID_1442093424" MODIFIED="1557498707219" TEXT="Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1538696365447" ID="ID_721732470" MODIFIED="1557498707219" TEXT="Theming-Engine">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1538696371086" ID="ID_1893037783" MODIFIED="1557498707219" TEXT="wir hatten Clearlooks. Gibts nicht mehr">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538696393835" ID="ID_1157806021" MODIFIED="1557498707219" TEXT="ersatzweise Adwaita, Gibts auch nicht mehr">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538696429774" ID="ID_1862679821" LINK="https://web.archive.org/web/20180829072234/https://blogs.gnome.org/mclasen/2014/06/13/a-new-default-theme-for-gtk/" MODIFIED="1557498707219" TEXT="das ganze Konzept ist obsolet">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538696720743" ID="ID_50558236" MODIFIED="1576282358138" TEXT="ersatzlos entfernt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
CSS genügt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538696756026" ID="ID_67620335" MODIFIED="1557498707219" TEXT="Interferenz mit dem System-Thema">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1538696777327" ID="ID_1226163317" MODIFIED="1557498707219" TEXT="Problem: repetitive Definitionen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538696788838" ID="ID_12898010" LINK="https://stackoverflow.com/q/52655725/444796" MODIFIED="1557498707219" TEXT="auf Stackoverflow gefragt">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1538696930403" HGAP="38" ID="ID_280002018" MODIFIED="1557498707219" TEXT="Idee: "inherit" auf höchster Ebene" VSHIFT="3">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1538696962271" ID="ID_46020871" MODIFIED="1557498707219" TEXT="unser Stylesheet hat GTK_STYLE_PROVIDER_PRIORITY_APPLICATION"/>
|
|
<node CREATED="1538696988803" ID="ID_1662822982" MODIFIED="1576282358137">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
füge <i>möglichst hoch</i> in der Hierarchie Regeln ein,
|
|
</p>
|
|
<p>
|
|
die ein property auf den Wert '<font face="Monospaced"><b>inherit</b></font>' setzten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
z.B. in den Block mit den "default-Regeln"
|
|
</p>
|
|
<p>
|
|
  * {
|
|
</p>
|
|
<p>
|
|
    color:            inherit; /* by default inherit content colour from parent widget */
|
|
</p>
|
|
<p>
|
|
    background-color: inherit;
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538697207110" ID="ID_415528083" MODIFIED="1557498707219" TEXT="border korrekt/geschickt setzen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665346468548" ID="ID_1034074054" MODIFIED="1665802081759" TEXT="Icon-Management">
|
|
<linktarget COLOR="#8487c2" DESTINATION="ID_1034074054" ENDARROW="Default" ENDINCLINATION="-757;-939;" ID="Arrow_ID_186260230" SOURCE="ID_1876392387" STARTARROW="None" STARTINCLINATION="-258;57;"/>
|
|
<node CREATED="1665346474211" ID="ID_465159869" MODIFIED="1665346622225" TEXT="Icon-Designs per Inkscape">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beruht auf der sehr sinnigen Einrichtung von Joel Holdsworth
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#668497" DESTINATION="ID_1174319279" ENDARROW="Default" ENDINCLINATION="-533;-310;" ID="Arrow_ID_1274211300" STARTARROW="None" STARTINCLINATION="-2393;215;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1665346844754" ID="ID_719864598" MODIFIED="1665346909386" TEXT="Thema: Icon-Namen">
|
|
<arrowlink COLOR="#7f668c" DESTINATION="ID_127382457" ENDARROW="Default" ENDINCLINATION="629;-31;" ID="Arrow_ID_1767981957" STARTARROW="None" STARTINCLINATION="560;80;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1485126385235" FOLDED="true" HGAP="38" ID="ID_548720270" MODIFIED="1679362194689" TEXT="top-Level" VSHIFT="11">
|
|
<linktarget COLOR="#851358" DESTINATION="ID_548720270" ENDARROW="Default" ENDINCLINATION="-663;-614;" ID="Arrow_ID_325703166" SOURCE="ID_471609909" STARTARROW="None" STARTINCLINATION="1110;608;"/>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1485126400233" FOLDED="true" ID="ID_885004423" MODIFIED="1678459235306" TEXT="unsauberes Design">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1485126410424" ID="ID_1158773288" MODIFIED="1557498707219" TEXT="wir haben mehrere Fenster">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485126418431" ID="ID_1145950660" MODIFIED="1557498707219" TEXT="GtkLumiera sollte kein Singleton sein">
|
|
<arrowlink COLOR="#80b3ef" DESTINATION="ID_164246989" ENDARROW="Default" ENDINCLINATION="-42;-74;" ID="Arrow_ID_401425747" STARTARROW="None" STARTINCLINATION="387;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1485549610040" ID="ID_699947133" MODIFIED="1557498707219" TEXT="Aktionen für jedes top-level Window repliziert">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1485549646739" ID="ID_1714638860" MODIFIED="1557498707219" TEXT="Abhängigkeit vom Fenster identifizieren"/>
|
|
<node CREATED="1485549666424" ID="ID_1909892697" MODIFIED="1557498707219" TEXT="generisch machen"/>
|
|
<node CREATED="1485549672943" ID="ID_1716269299" MODIFIED="1557498707219" TEXT="Aktionen in UiManager verschieben"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1485126429445" ID="ID_832156304" MODIFIED="1678459243180" TEXT="aufräumen">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1485126506699" ID="ID_1776936645" MODIFIED="1679087617717" TEXT="#1067 rearrange GUI Application top-level">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485126573818" ID="ID_206480879" MODIFIED="1557498707219" TEXT="#1032 use gtk::Application instead of gtk::Main">
|
|
<arrowlink COLOR="#ae182e" DESTINATION="ID_1476863246" ENDARROW="Default" ENDINCLINATION="283;-164;" ID="Arrow_ID_1851148216" STARTARROW="Default" STARTINCLINATION="481;0;"/>
|
|
<linktarget COLOR="#ae1856" DESTINATION="ID_206480879" ENDARROW="Default" ENDINCLINATION="715;0;" ID="Arrow_ID_926482654" SOURCE="ID_392996871" STARTARROW="Default" STARTINCLINATION="134;383;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485126609878" ID="ID_815018040" MODIFIED="1557498707219" TEXT="#1064 investigate WindowManager lifecycle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1493752896125" ID="ID_1471478347" MODIFIED="1557498707219" TEXT="erledigt"/>
|
|
<node CREATED="1493752899224" ID="ID_83018735" MODIFIED="1557498707219" TEXT="WindowManager war gar nicht so wichtig"/>
|
|
<node CREATED="1493752906736" ID="ID_1191055389" MODIFIED="1557498707219" TEXT="er ist jetzt nur noch eine Fenster-Liste"/>
|
|
<node CREATED="1504368788471" ID="ID_1811705494" MODIFIED="1557498707219" TEXT="und die heißt jetzt WindowLocator"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485550950793" ID="ID_50100583" MODIFIED="1557498707219" TEXT="#1048 rectify UI Lifecycle">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1485550968230" ID="ID_164246989" MODIFIED="1557498707219" TEXT="GtkLumiera darf kein Singleton mehr sein">
|
|
<linktarget COLOR="#80b3ef" DESTINATION="ID_164246989" ENDARROW="Default" ENDINCLINATION="-42;-74;" ID="Arrow_ID_401425747" SOURCE="ID_1145950660" STARTARROW="None" STARTINCLINATION="387;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1485561982971" ID="ID_287757293" MODIFIED="1557498707219" TEXT="Blocker entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1485562029644" ID="ID_1022779645" MODIFIED="1557498707219" TEXT="wieder das Problem mit dem BInden der Actions">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_530209145" ENDARROW="Default" ENDINCLINATION="-17;-195;" ID="Arrow_ID_626063593" STARTARROW="None" STARTINCLINATION="9;270;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1493846161963" ID="ID_358400969" MODIFIED="1557498707219" TEXT="durch fortgesetztes Refactoring gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485550992299" ID="ID_1685125156" MODIFIED="1557498707219" TEXT="es blocken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485550999762" ID="ID_249139218" MODIFIED="1557498707219" TEXT="WindowManager">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1485551007297" ID="ID_1398242341" MODIFIED="1557498707219" TEXT="Project & Controller">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1493853541747" ID="ID_689819683" MODIFIED="1557498707219" TEXT="TODO">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1493853548739" ID="ID_949985796" MODIFIED="1576282358137" TEXT="Project & Controller restlos entfernen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wartet noch darauf,
|
|
</p>
|
|
<p>
|
|
daß die alte, obsolete Timeline zurückgebaut ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1493853590149" ID="ID_1075149702" MODIFIED="1576282358136" TEXT="Race beim triggerShutdown">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
siehe guifacade.cpp
|
|
</p>
|
|
<p>
|
|
Problem ist: wenn das triggerShutdown kommt,
|
|
</p>
|
|
<p>
|
|
bevor die Notification-Facade geöffnet werden konnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504191345606" ID="ID_1249897876" MODIFIED="1557498707220" TEXT="#1026 cleanup PanelManager">
|
|
<linktarget COLOR="#ce6b5f" DESTINATION="ID_1249897876" ENDARROW="Default" ENDINCLINATION="1299;0;" ID="Arrow_ID_1635700276" SOURCE="ID_1335931102" STARTARROW="Default" STARTINCLINATION="-1412;-1014;"/>
|
|
<linktarget COLOR="#e1a169" DESTINATION="ID_1249897876" ENDARROW="Default" ENDINCLINATION="-636;0;" ID="Arrow_ID_446871395" SOURCE="ID_125942292" STARTARROW="None" STARTINCLINATION="-311;562;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193029907" ID="ID_1020871440" MODIFIED="1557498707220" TEXT="#1104 how to instruct actions through panels">
|
|
<linktarget COLOR="#806893" DESTINATION="ID_1020871440" ENDARROW="Default" ENDINCLINATION="-3;460;" ID="Arrow_ID_412107208" SOURCE="ID_1943521361" STARTARROW="Default" STARTINCLINATION="-618;-18;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529235342511" ID="ID_1922506931" MODIFIED="1557498707220">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Aufgabe</b>: docking panels global
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b0466a" DESTINATION="ID_629544763" ENDARROW="Default" ENDINCLINATION="-849;-1967;" ID="Arrow_ID_1826422316" STARTARROW="None" STARTINCLINATION="690;23;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485551018975" ID="ID_1865473127" MODIFIED="1557498707220" TEXT="obsoletes Project & Controller">
|
|
<node CREATED="1485551030086" ID="ID_1052165402" MODIFIED="1557498707220" TEXT="in GtkLumiera definiert"/>
|
|
<node CREATED="1485551035413" ID="ID_1861899005" MODIFIED="1557498707220" TEXT="tatsächlich im Panel (Basisklasse) gespeichert"/>
|
|
<node CREATED="1485551056834" ID="ID_538186909" MODIFIED="1557498707220" TEXT="tatsächlich nur im alten TimelinePannel gebraucht"/>
|
|
<node COLOR="#338800" CREATED="1485551067353" ID="ID_1684200224" MODIFIED="1557498707220" TEXT="Übergangslösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485551080687" ID="ID_405147511" MODIFIED="1557498707220" TEXT="als Felder dort">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1485551085454" ID="ID_472031977" MODIFIED="1557498707220" TEXT="ist ohnehin defunkt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485551096445" ID="ID_258972556" MODIFIED="1557498707220" TEXT="dann Parameter entfernen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#ae1856" CREATED="1485126686643" ID="ID_405470138" MODIFIED="1557498707220" TEXT="sauberer Shutdown">
|
|
<arrowlink COLOR="#872666" DESTINATION="ID_286857196" ENDARROW="Default" ENDINCLINATION="-684;0;" ID="Arrow_ID_1606936924" STARTARROW="Default" STARTINCLINATION="1461;0;"/>
|
|
<node CREATED="1502411273154" HGAP="57" ID="ID_1087419686" MODIFIED="1557498707220" TEXT="komplett?" VSHIFT="39">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1493762490205" ID="ID_159568066" MODIFIED="1557498707220" TEXT="alle noch offenen Fenster verbergen">
|
|
<linktarget COLOR="#543c6f" DESTINATION="ID_159568066" ENDARROW="Default" ENDINCLINATION="489;-554;" ID="Arrow_ID_373486067" SOURCE="ID_869056268" STARTARROW="None" STARTINCLINATION="-762;-46;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1495234856782" ID="ID_1605922951" MODIFIED="1557498707220" TEXT="machen wir bisher nicht"/>
|
|
<node CREATED="1495234865717" ID="ID_1261122199" MODIFIED="1557498707220" TEXT="ist das notwendig?"/>
|
|
<node CREATED="1538588192126" ID="ID_1032145387" MODIFIED="1576282358136" TEXT="wohl nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn die GTK-Loop angehalten wird,
|
|
</p>
|
|
<p>
|
|
dann koppelt sich GTK anscheinend auch
|
|
</p>
|
|
<p>
|
|
automatisch vom Window-Manager ab.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Jedenfalls habe ich nun schon mehrfach den Shutdown "von unten" getriggert,
|
|
</p>
|
|
<p>
|
|
und es wurden alle Fenster geschlossen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings habe ich an der Stelle immer noch GTK-Assertions
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485463620403" ID="ID_40172420" MODIFIED="1557498707220" TEXT="zentralen UiManager einführen">
|
|
<arrowlink COLOR="#667b93" DESTINATION="ID_1698853761" ENDARROW="Default" ENDINCLINATION="19;-86;" ID="Arrow_ID_1952755524" STARTARROW="None" STARTINCLINATION="-290;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485126441508" HGAP="32" ID="ID_1227132808" MODIFIED="1557498707220" TEXT="GtkLumiera" VSHIFT="-26">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485454326827" ID="ID_1493501410" MODIFIED="1557498707220" TEXT="Applikation == Lebenszyklus">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1485463515929" ID="ID_785456397" MODIFIED="1557498707220" TEXT="für die Verdrahtung zuständig"/>
|
|
<node CREATED="1485463525736" ID="ID_1608786246" MODIFIED="1557498707220" TEXT="hält alle zentralen Komponenten"/>
|
|
<node CREATED="1493846135327" ID="ID_832439809" MODIFIED="1557498707220" TEXT="initialisiert und startet Backbone"/>
|
|
<node CREATED="1485463537111" ID="ID_929585985" MODIFIED="1557498707220" TEXT="wird nie selber direkt angesprochen"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1485126457025" FOLDED="true" ID="ID_1698853761" MODIFIED="1557498707220" TEXT="ctrl::UiManager">
|
|
<linktarget COLOR="#667b93" DESTINATION="ID_1698853761" ENDARROW="Default" ENDINCLINATION="19;-86;" ID="Arrow_ID_1952755524" SOURCE="ID_40172420" STARTARROW="None" STARTINCLINATION="-290;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1485454242368" ID="ID_482639947" MODIFIED="1557498707220" TEXT="Hub für Framework">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1485454284961" ID="ID_940728768" MODIFIED="1557498707220" TEXT="es gibt nur einen">
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485454375917" ID="ID_1935695209" MODIFIED="1557498707220" TEXT="erbt von Gtk::UiManager">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533303793015" ID="ID_433225506" MODIFIED="1557498707220" TEXT="Infos zu Gtk::Main, Gtk::Application und Gio::Application">
|
|
<arrowlink COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-1088;-39;" ID="Arrow_ID_234165792" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485457021805" ID="ID_1476863246" MODIFIED="1582487797600" TEXT="Gtk::UiManager ist deprecated">
|
|
<linktarget COLOR="#6d7495" DESTINATION="ID_1476863246" ENDARROW="Default" ENDINCLINATION="1126;-247;" ID="Arrow_ID_1941890495" SOURCE="ID_384827553" STARTARROW="None" STARTINCLINATION="-373;28;"/>
|
|
<linktarget COLOR="#ae182e" DESTINATION="ID_1476863246" ENDARROW="Default" ENDINCLINATION="283;-164;" ID="Arrow_ID_1851148216" SOURCE="ID_206480879" STARTARROW="Default" STARTINCLINATION="481;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1493768617653" ID="ID_292624709" MODIFIED="1557498707220" TEXT="fällt anscheinend ersatzlos weg"/>
|
|
<node CREATED="1493768625564" ID="ID_1620270152" MODIFIED="1557498707220" TEXT="Verdacht: stattdessen Gtk::Application"/>
|
|
<node CREATED="1495218227391" ID="ID_1156276489" MODIFIED="1576282358135" TEXT="Beschluß: vorerst Gtk::Action / ActionGroup weiter verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Begründung</u>:
|
|
</p>
|
|
<p>
|
|
Das neue System ist anscheinend fest integriert in Gio::Application.
|
|
</p>
|
|
<p>
|
|
Mir ist nicht klar, wieso ein Fenster/Widget das Interface Gio::Actionable implementieren muß.
|
|
</p>
|
|
<p>
|
|
Ich werde den Verdacht nicht los, daß hier das Ziel verfolgt wird, eine "Action" von den
|
|
</p>
|
|
<p>
|
|
Grenzen der Applikation zu befreien und direkt in den Desktop zu integrieren.
|
|
</p>
|
|
<p>
|
|
Mit Desktop ist natürlich der Gnome-Desktop gemeint. Was diesen Verdacht bestärkt,
|
|
</p>
|
|
<p>
|
|
ist, daß Gio::Application sofort auch gleich eine dBus-Verbindung hochfährt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1485457105010" HGAP="49" ID="ID_202831328" MODIFIED="1557498707220" TEXT="neuer Weg" VSHIFT="21">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1485457108425" ID="ID_152284167" MODIFIED="1557498707220" TEXT="man erzeugt Gio::SimpleActionGroup"/>
|
|
<node CREATED="1485457141853" ID="ID_1841602685" MODIFIED="1557498707220" TEXT="man fügt diese dem Fenster hinzu"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485454243767" HGAP="43" ID="ID_3699127" MODIFIED="1563020397025" TEXT="Zweck: konsistentes UI" VSHIFT="-4">
|
|
<node CREATED="1485454248335" ID="ID_623536019" MODIFIED="1557498707220" TEXT="globales Menü"/>
|
|
<node CREATED="1485454259637" ID="ID_432211008" MODIFIED="1557498707220" TEXT="globale Toolbar"/>
|
|
<node CREATED="1485454252789" ID="ID_310049457" MODIFIED="1557498707220" TEXT="globale Aktionen"/>
|
|
<node CREATED="1485454263876" ID="ID_543704434" MODIFIED="1557498707220" TEXT="globale Keybindings"/>
|
|
</node>
|
|
<node CREATED="1493768943479" ID="ID_374108201" MODIFIED="1557498707220" TEXT="Plan">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1493768946415" ID="ID_880915214" MODIFIED="1557498707220" TEXT="das ist die UI-Main-Klasse">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1493768959324" ID="ID_873679558" MODIFIED="1557498707220" TEXT="sollte dann...">
|
|
<node CREATED="1493768965036" ID="ID_1457175098" MODIFIED="1557498707220" TEXT="das erste Fenster öffnen"/>
|
|
<node CREATED="1493768972691" ID="ID_1810145809" MODIFIED="1557498707220" TEXT="die GTK-Loop starten">
|
|
<arrowlink COLOR="#8091a3" DESTINATION="ID_346412093" ENDARROW="Default" ENDINCLINATION="-205;193;" ID="Arrow_ID_824195065" STARTARROW="None" STARTINCLINATION="430;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1493768980361" ID="ID_1478388503" MODIFIED="1557498707220" TEXT="das UI herunnterfahren">
|
|
<arrowlink COLOR="#667e90" DESTINATION="ID_599315721" ENDARROW="None" ENDINCLINATION="41;328;" ID="Arrow_ID_1963473410" STARTARROW="Default" STARTINCLINATION="943;-58;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020429008" ID="ID_873763889" MODIFIED="1678461929265" TEXT="Delegate herausgelöst: UIStyle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
soll einmal der »StyleManager« werden
|
|
</li>
|
|
<li>
|
|
baut Stand 2019 auf bestehender Funktionalität von Joel Holdsworth auf...
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6179b8" DESTINATION="ID_8715605" ENDARROW="Default" ENDINCLINATION="-946;80;" ID="Arrow_ID_1659593372" STARTARROW="None" STARTINCLINATION="-1586;131;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020384655" ID="ID_1309805657" MODIFIED="1563020388552" TEXT="Aufgaben">
|
|
<node COLOR="#338800" CREATED="1678461987037" ID="ID_1506722948" MODIFIED="1678462126447" TEXT="verwaltet den »top-level-Kontext«">
|
|
<arrowlink COLOR="#47a98e" DESTINATION="ID_576215675" ENDARROW="Default" ENDINCLINATION="-431;-49;" ID="Arrow_ID_162897615" STARTARROW="None" STARTINCLINATION="-633;50;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1563020407852" ID="ID_1512492571" MODIFIED="1678462193702">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Style / CSS ⟶ delegiert an <b>UiStyle</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#454571" DESTINATION="ID_280366952" ENDARROW="Default" ENDINCLINATION="234;-533;" ID="Arrow_ID_1461427805" STARTARROW="None" STARTINCLINATION="748;60;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1489460861250" FOLDED="true" HGAP="91" ID="ID_771159819" MODIFIED="1679361759804" TEXT="globaler Kontext" VSHIFT="-26">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#a03232" CREATED="1485549049388" FOLDED="true" ID="ID_530209145" MODIFIED="1679087971773" TEXT="Problem: Aktionen binden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist ein gaaaanz großes Strategisches Thema; vor 2023 hatte ich schon mehrfach versucht, <i>es zu fassen</i> — <font color="#982e2e">das ist mir aber bisher nicht gelungen</font>, und deshalb wartet es.... ⌛
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_530209145" ENDARROW="Default" ENDINCLINATION="-17;-195;" ID="Arrow_ID_626063593" SOURCE="ID_1022779645" STARTARROW="None" STARTINCLINATION="9;270;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1485549075929" ID="ID_1887127861" MODIFIED="1518487921060" TEXT="spezifische Aktionen">
|
|
<node CREATED="1485549803366" ID="ID_1969698948" MODIFIED="1518487921060" TEXT="Fenster-Bindung">
|
|
<node CREATED="1485549810780" ID="ID_71301392" MODIFIED="1518487921060" TEXT="Pop-Ups brauchen ein Vater-Fenster"/>
|
|
<node CREATED="1485549828450" ID="ID_1089795419" MODIFIED="1518487921060">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eigentlich wollen wir <i>"das aktuelle"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#375a84" DESTINATION="ID_1041890737" ENDARROW="Default" ENDINCLINATION="177;-181;" ID="Arrow_ID_373431525" STARTARROW="None" STARTINCLINATION="245;-68;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485902627783" HGAP="42" ID="ID_88029282" MODIFIED="1561827464724" VSHIFT="-13">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösung: <i><font color="#27754d">schwebende Bindung</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1485902684454" ID="ID_1435239012" MODIFIED="1518487921060" TEXT="Eventgetriebene Oberfläche"/>
|
|
<node CREATED="1485902692556" ID="ID_1729615218" MODIFIED="1518487921060" TEXT="wird einmal verdrahtet"/>
|
|
<node CREATED="1485902722360" ID="ID_1003456982" MODIFIED="1518487921060">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
arbeitet dann <i>freischwebend</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1485902750053" ID="ID_34756513" MODIFIED="1518487921060" TEXT="zentrales Bindeglied">
|
|
<node CREATED="1485902762284" ID="ID_1542199290" MODIFIED="1518487921060" TEXT="kennt die Applikation"/>
|
|
<node CREATED="1485902774201" ID="ID_354078562" MODIFIED="1518487921060" TEXT="kennt den Windowmanager"/>
|
|
<node CREATED="1485902783201" ID="ID_609776597" MODIFIED="1518487921060" TEXT="kennt einen Operations-Controller"/>
|
|
<node CREATED="1485902809813" ID="ID_648457506" MODIFIED="1518487921060" TEXT="kennt den UI-Bus"/>
|
|
<node CREATED="1485902794479" ID="ID_1389010579" MODIFIED="1518487921060" TEXT="und ggffs weitere"/>
|
|
</node>
|
|
<node CREATED="1485902832698" HGAP="48" ID="ID_1440190469" MODIFIED="1518487921060" TEXT="genau dies ist der InteractionDirector" VSHIFT="14">
|
|
<arrowlink COLOR="#798eba" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-218;-590;" ID="Arrow_ID_757867749" STARTARROW="None" STARTINCLINATION="15;121;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485902945474" HGAP="-2" ID="ID_269152626" MODIFIED="1576282358134" TEXT="Lösungs-Detail: dynamisch koppeln" VSHIFT="19">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...meint:
|
|
</p>
|
|
<p>
|
|
wir müssen zur Aufrufzeit einer Aktion
|
|
</p>
|
|
<p>
|
|
an den aktuellen Kontext ankoppeln können.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das heißt, der UiManager muß im Stande sein,
|
|
</p>
|
|
<p>
|
|
diesen "aktuellen Kontext" irgendwo <i>aufzufischen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1485903041262" ID="ID_997327941" MODIFIED="1518487921060" TEXT="Fokus"/>
|
|
<node COLOR="#338800" CREATED="1485903046613" ID="ID_1041890737" MODIFIED="1518487921060" TEXT="aktuelles Fenster">
|
|
<linktarget COLOR="#375a84" DESTINATION="ID_1041890737" ENDARROW="Default" ENDINCLINATION="177;-181;" ID="Arrow_ID_373431525" SOURCE="ID_1089795419" STARTARROW="None" STARTINCLINATION="245;-68;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485903652236" ID="ID_1692258488" MODIFIED="1518487921060" TEXT="WindowLocator">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504368706988" ID="ID_362723210" MODIFIED="1518487921060" TEXT="hält Liste der Fenster"/>
|
|
<node CREATED="1485903658300" ID="ID_1048329186" MODIFIED="1518487921060" TEXT="durchsuchen..."/>
|
|
</node>
|
|
<node CREATED="1485904084947" ID="ID_64462533" MODIFIED="1518487921060" TEXT="Gtk::Window"/>
|
|
<node CREATED="1485904064949" ID="ID_313273027" MODIFIED="1518487921060" TEXT="property_has_focus">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1485904072812" ID="ID_829657223" MODIFIED="1518487921060" TEXT="property_is_active">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1487039156100" ID="ID_1966427611" MODIFIED="1518487921060" TEXT="implementiert durch den WindowLocator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487039170930" ID="ID_1408455006" MODIFIED="1518487921060" TEXT="Actions weiß, daß es dort implemieriert ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#6979a7" CREATED="1489460657437" HGAP="101" ID="ID_674641985" MODIFIED="1518487921060" TEXT="Einsicht: Problem verschiebt sich" VSHIFT="-20">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489460707774" ID="ID_1580714352" MODIFIED="1518487921060" TEXT="Actions wird ein reiner Binde-Kontext"/>
|
|
<node CREATED="1489460736370" ID="ID_794231700" MODIFIED="1518487921060" TEXT="delegiert wird an einen globalen controller"/>
|
|
<node CREATED="1489460756271" ID="ID_392157120" MODIFIED="1518487921060">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>dort </i>wird der Kontext aufgegriffen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485917582383" HGAP="163" ID="ID_394170572" MODIFIED="1518487921061" TEXT="Struktur" VSHIFT="-30">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485917587927" ID="ID_891876702" MODIFIED="1518487921061" TEXT="wohin kommen jetzt die Funktionen, die gebunden werden">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485917597429" ID="ID_713875638" MODIFIED="1518487921061" TEXT="auf welche Sub-Komponenten wird referenziert">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486063810921" ID="ID_719539281" MODIFIED="1518487921061" TEXT="Zweck">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1486063816320" ID="ID_151179000" MODIFIED="1518487921061" TEXT="ist ein Builder"/>
|
|
<node CREATED="1486063819992" ID="ID_445639565" MODIFIED="1518487921061" TEXT="ist eine Closure"/>
|
|
<node CREATED="1486063831790" ID="ID_328966967" MODIFIED="1518487921061" TEXT="muß bloß am Leben bleiben"/>
|
|
<node CREATED="1486063841293" ID="ID_1675242982" MODIFIED="1518487921061" TEXT="hat nach Init nichts mehr zu tun"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1486063858283" HGAP="42" ID="ID_130675776" MODIFIED="1561827464726" TEXT="ist Impl-Detail" VSHIFT="5">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1486063886407" ID="ID_1294385692" MODIFIED="1518487921061" TEXT="sollte aus den weitverbreiteten Header-Includes raus"/>
|
|
<node CREATED="1486063911188" ID="ID_1391435276" MODIFIED="1576282358134" TEXT="gegenwärtig Member im UiManager">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und der wird in der Tat an vielen Stellen includiert
|
|
</p>
|
|
<p>
|
|
und verwendet, und das ist auch gut so
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1486063950103" FOLDED="true" ID="ID_57649689" MODIFIED="1538871966591" TEXT="zwei Modelle">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1486063954062" ID="ID_1174765379" MODIFIED="1561827464726" TEXT="Actions wird insgesamt ein PImpl">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1486064137014" ID="ID_926465478" MODIFIED="1518487921061" TEXT="ist einfach umzusetzen"/>
|
|
<node CREATED="1486064142037" ID="ID_836065841" MODIFIED="1518487921061" TEXT="führt zu einer doppelten Indirektion"/>
|
|
<node CREATED="1486064289857" ID="ID_806073517" MODIFIED="1518487921061" TEXT="macht Registrierung der Aktionen einfach"/>
|
|
<node CREATED="1486064322909" ID="ID_89838152" MODIFIED="1518487921061" TEXT="vermischt die Themen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1486064333076" ID="ID_622214749" MODIFIED="1518487921061" TEXT="Aufbauen des Menüs"/>
|
|
<node CREATED="1486064337363" ID="ID_551504727" MODIFIED="1518487921061" TEXT="Closure für die Einzel-Aktionen"/>
|
|
</node>
|
|
<node CREATED="1486064454451" ID="ID_744832983" MODIFIED="1518487921061" TEXT="Aber genau diese Vermischun macht das Registrieren einfach"/>
|
|
</node>
|
|
<node CREATED="1486063968868" ID="ID_830826934" MODIFIED="1561827464728" TEXT="Actions hat einen ActionGroup-PImpl">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1486063991065" ID="ID_1575759747" MODIFIED="1518487921061" TEXT="man kann von ActionGroup erben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1486064395051" ID="ID_1668165644" MODIFIED="1518487921061" TEXT="Risiko: Umstellung auf Gio::Action">
|
|
<node CREATED="1486064404410" ID="ID_1844104863" MODIFIED="1518487921061" TEXT="zwingend erforderlich"/>
|
|
<node CREATED="1486064408841" ID="ID_630946690" MODIFIED="1518487921061" TEXT="in GTK-4 gibt es keine Gtk::Action mehr">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486063996776" ID="ID_784656430" MODIFIED="1518487921061" TEXT="ist zwar nicht vorgesehen...">
|
|
<node CREATED="1486064082093" ID="ID_1957105401" MODIFIED="1518487921061" TEXT="das ist eindeutig"/>
|
|
<node CREATED="1486064085605" ID="ID_614915424" MODIFIED="1518487921061" TEXT="es gibt eine statische create-Funktion"/>
|
|
<node CREATED="1486064099915" ID="ID_247043577" MODIFIED="1518487921061" TEXT="und die macht einen Gtk::ref_ptr"/>
|
|
<node CREATED="1486064111241" ID="ID_1562595756" MODIFIED="1518487921061" TEXT="AUTSCH: ich will einen unique_ptr"/>
|
|
</node>
|
|
<node CREATED="1486064004143" ID="ID_1825804537" MODIFIED="1518487921061" TEXT="....aber geht">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1486064188334" ID="ID_1128646481" MODIFIED="1518487921061" TEXT="theoretisch ja"/>
|
|
<node CREATED="1486064209092" ID="ID_340165076" MODIFIED="1518487921061" TEXT="aber am Ende will der UiManager einen ref_ptr ActionGroup"/>
|
|
<node CREATED="1486064221954" ID="ID_429209345" MODIFIED="1518487921061" TEXT="da sollte man sich besser raushalten">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486064237832" ID="ID_529050138" MODIFIED="1518487921061" TEXT="wäre schön aber nicht ratsam">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1486064478968" ID="ID_1610028838" MODIFIED="1679362063136" TEXT="Umbau">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1486064487215" ID="ID_195778340" MODIFIED="1518487921061" TEXT="Actions wird PImpl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1486064493614" ID="ID_566562539" MODIFIED="1518487921061" TEXT="Actions wird Header-only">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1486064503229" ID="ID_1200627448" MODIFIED="1518487921061" TEXT="alle wildcard-Includes weg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487039062273" ID="ID_956599122" MODIFIED="1679362063136" TEXT="Zuständigkeit">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1487039071039" ID="ID_1884426258" MODIFIED="1518487921061" TEXT="Herstellen des Hauptmenüs"/>
|
|
<node CREATED="1487039079759" ID="ID_471335369" MODIFIED="1518487921061" TEXT="Binden der Aktionen"/>
|
|
<node CREATED="1487039084285" ID="ID_555104373" MODIFIED="1518487921061" TEXT="Closure für die Aktionen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487039098836" ID="ID_199078620" MODIFIED="1518487921061" TEXT="ggfs: Exceptions fangen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487039113306" ID="ID_1405514231" MODIFIED="1679362063136" TEXT="Einbindung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1487039118001" ID="ID_244074852" MODIFIED="1518487921061" TEXT="globaler Kontext"/>
|
|
<node CREATED="1487039125984" ID="ID_622974182" MODIFIED="1518487921061" TEXT="weiß, welche Aktion wohin zu delegieren ist"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488422770096" FOLDED="true" HGAP="56" ID="ID_53463593" MODIFIED="1561827464731" TEXT="#1085 solve setup of top-level menu actions" VSHIFT="-17">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488423688763" ID="ID_1950800234" MODIFIED="1679362063136" TEXT="UI-Komponenten">
|
|
<node CREATED="1488423702977" ID="ID_292894978" MODIFIED="1575050390351" TEXT="TimelinePane">
|
|
<arrowlink COLOR="#a1543e" DESTINATION="ID_1753722831" ENDARROW="Default" ENDINCLINATION="1192;-274;" ID="Arrow_ID_912757548" STARTARROW="None" STARTINCLINATION="408;-90;"/>
|
|
</node>
|
|
<node CREATED="1488423705729" ID="ID_610872163" MODIFIED="1518487921061" TEXT="AssetPane"/>
|
|
<node CREATED="1488423709704" ID="ID_14713871" MODIFIED="1518487921061" TEXT="ViewerPane"/>
|
|
</node>
|
|
<node CREATED="1488423740012" ID="ID_874330545" MODIFIED="1679362063136" TEXT="Lifecycle-Aktionen">
|
|
<node CREATED="1488423747187" ID="ID_1351717245" MODIFIED="1679362063136" TEXT="UI schließen">
|
|
<node CREATED="1492965765319" ID="ID_581436031" MODIFIED="1518487921061" TEXT="wird schon geforwarded"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492965770197" ID="ID_1619347643" MODIFIED="1518487921061" TEXT="noch zu implementieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423714584" ID="ID_1439137871" MODIFIED="1679362063136" TEXT="Session-Aktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488423760105" ID="ID_1527724040" MODIFIED="1679362063136" TEXT="Speichern">
|
|
<node CREATED="1488492373919" ID="ID_1898515568" MODIFIED="1518487921061" TEXT="snapshot-Kommando an Session senden"/>
|
|
<node CREATED="1488494870418" ID="ID_1929432332" MODIFIED="1576282358133" TEXT="TODO: InvocationTrail">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Njet
|
|
</p>
|
|
<p>
|
|
InvocationTrail ist tot
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488566247742" ID="ID_254774965" MODIFIED="1518487921061" TEXT="muß doch die Architktur klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423763585" ID="ID_968726788" MODIFIED="1518487921061" TEXT="Schließen"/>
|
|
<node CREATED="1488494907118" ID="ID_1932633471" MODIFIED="1679362063136" TEXT="Speichern-Als">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1488494891600" ID="ID_1996245412" MODIFIED="1518487921061" TEXT="Session-Setup-UI schaffen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492965880399" ID="ID_1722391032" MODIFIED="1679362063136" TEXT="editSetup">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492965890037" ID="ID_1388211591" MODIFIED="1518487921061" TEXT="Konfigurations-UI schaffen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488492153109" ID="ID_1243726860" MODIFIED="1518487921061">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
generisches <i>Öffnen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1488423720319" FOLDED="true" ID="ID_1455353650" MODIFIED="1561827464734" TEXT="Sequence-Aktionen">
|
|
<linktarget COLOR="#58379a" DESTINATION="ID_1455353650" ENDARROW="Default" ENDINCLINATION="111;202;" ID="Arrow_ID_1092382782" SOURCE="ID_1392812297" STARTARROW="None" STARTINCLINATION="100;-9;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1489461756655" ID="ID_1625364312" MODIFIED="1679362063136" TEXT="neue Sequenz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1489461773213" ID="ID_344390825" MODIFIED="1576282358133" TEXT="als Treiber verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um die Entwicklung des Designs zu erzwingen
|
|
</p>
|
|
<p>
|
|
und den Teufelskreis zu durchbrechen!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1489461838228" ID="ID_283502486" MODIFIED="1518487921061" TEXT="im InteractionDirector">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1489461843747" ID="ID_1499714490" MODIFIED="1679362063136" TEXT="die Command-ID beziehen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1489461856042" ID="ID_1097689316" MODIFIED="1518487921061" TEXT="bedingt Command-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489461862937" ID="ID_1649764088" MODIFIED="1518487921061" TEXT="bedingt Command-Definition">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489544225984" ID="ID_1436775081" MODIFIED="1679362063136" TEXT="Triggern">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1489544261547" ID="ID_1624183619" MODIFIED="1679362063136" TEXT="wer">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544403984" ID="ID_1230750297" MODIFIED="1518487921062" TEXT=""ein UI-Element"">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1489544439187" ID="ID_1231587220" MODIFIED="1518487921062" TEXT="Beispiel: Toolbar-Button"/>
|
|
<node CREATED="1489544452034" ID="ID_745673239" MODIFIED="1518487921062" TEXT="Beispiel: Kontextmenü-Eintrag"/>
|
|
<node CREATED="1489544513577" ID="ID_128032926" MODIFIED="1518487921062" TEXT="Beispiel: Aktion per Keybinding"/>
|
|
<node CREATED="1489544524128" ID="ID_1668808893" MODIFIED="1518487921062" TEXT="Beispiel: Signal drag-n-drop"/>
|
|
</node>
|
|
<node CREATED="1489544268018" ID="ID_452323402" MODIFIED="1679362063136" TEXT="was">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544652414" ID="ID_1351449548" MODIFIED="1518487921062" TEXT="lokal bekannt"/>
|
|
<node CREATED="1489544640288" ID="ID_1518540017" MODIFIED="1518487921062" TEXT="fest verdrahtet"/>
|
|
<node CREATED="1489544659597" ID="ID_1444251202" MODIFIED="1518487921062" TEXT="ggfs. Auswahl aus kleiner Menge"/>
|
|
</node>
|
|
<node CREATED="1489544717333" ID="ID_1695877485" MODIFIED="1679362063136" TEXT="falls">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544722261" ID="ID_1263012116" MODIFIED="1518487921062" TEXT="ausführbar"/>
|
|
<node CREATED="1489544725860" ID="ID_1167910092" MODIFIED="1518487921062" TEXT="d.h. aktiviert"/>
|
|
<node CREATED="1489544826383" ID="ID_166753518" MODIFIED="1679362063136" TEXT="zwei verschiedene Effekte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489544836757" ID="ID_1543872004" MODIFIED="1576282358132" TEXT="Ausführung abweisen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...stattdessen einen Fehler-Indikator auslösen
|
|
</p>
|
|
<p>
|
|
(Beispiel "in-point fehlt")
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1489544910395" ID="ID_82086808" MODIFIED="1576282358132" TEXT="enable Action">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist eine Reaktion,
|
|
</p>
|
|
<p>
|
|
die von einem managing Ui-Element ausgeführt wird,
|
|
</p>
|
|
<p>
|
|
aber von einem externen State-Change getriggert wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492461164005" ID="ID_301986256" MODIFIED="1518487921062" TEXT="Argumente">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492461170141" ID="ID_740147771" MODIFIED="1518487921062" TEXT="der Anker">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1492965703927" ID="ID_1023878270" MODIFIED="1518487921062" TEXT="auf später vertagt">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1492965711791" ID="ID_965013716" MODIFIED="1518487921062" TEXT="InteractionControl">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492461179404" ID="ID_1843144262" MODIFIED="1518487921062" TEXT="die neue Sequenz">
|
|
<node CREATED="1492461186562" ID="ID_357158955" MODIFIED="1576282358131" TEXT="ID muß gesendet werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damit UNDO funktionieren kann,
|
|
</p>
|
|
<p>
|
|
müssen wir schon beim capture wissen,
|
|
</p>
|
|
<p>
|
|
welches Objekt (ID) hinzugefügt werden wird.
|
|
</p>
|
|
<p>
|
|
Denn sonst müßten wir uns den gegenwärtigen Inhalt speichern
|
|
</p>
|
|
<p>
|
|
und das wäre unsinnig.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492461260360" ID="ID_118202238" MODIFIED="1518487921062" TEXT="EntryID">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492965734610" ID="ID_17105090" MODIFIED="1518487921062" TEXT="neuer Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1489461946997" HGAP="-10" ID="ID_1526466868" MODIFIED="1576282358131" TEXT="direkt von den Lambdas aus delegieren" VSHIFT="7">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir können den größten Teil dieser Einzeiler-Funktionen loswerden,
|
|
</p>
|
|
<p>
|
|
da es nur darum geht, via globalCtx auf den passenden Controller zuzugreifen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485898796393" ID="ID_1217726538" MODIFIED="1561827464735" TEXT="#1069 how to refer to the current window">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1492965823743" ID="ID_729520839" MODIFIED="1518487921062" TEXT="grundsätzlich gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1492965830381" ID="ID_1556963629" MODIFIED="1518487921062" TEXT="globalCtx -> find active window">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1492965845115" ID="ID_1375700494" MODIFIED="1523752843329" TEXT="TODO Panel-Aktionen">
|
|
<arrowlink DESTINATION="ID_1176492517" ENDARROW="Default" ENDINCLINATION="-68;-316;" ID="Arrow_ID_1083220093" STARTARROW="None" STARTINCLINATION="550;-23;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492965914018" ID="ID_1134955241" MODIFIED="1518487921062" TEXT="UNIMPLEMENTED"/>
|
|
<node CREATED="1493852058451" ID="ID_1074189286" MODIFIED="1518487921062" TEXT="war schon seit 2009 deaktiviert"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1493852066930" ID="ID_715367457" MODIFIED="1518487921062" TEXT="das ganze Konzept muß überarbeitet werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485555902731" ID="ID_55451880" MODIFIED="1518487921062" TEXT="#1070 how to bind session commands into UI actions">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1489191725382" ID="ID_1332782754" MODIFIED="1518487921062" TEXT="größeres Thema">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1489191732869" ID="ID_1031180144" MODIFIED="1518487921062" TEXT="nicht sofort zu lösen"/>
|
|
<node CREATED="1489191744764" ID="ID_898481930" MODIFIED="1518487921062" TEXT="aber Grundlagen legen">
|
|
<arrowlink COLOR="#606d94" DESTINATION="ID_346158251" ENDARROW="Default" ENDINCLINATION="671;0;" ID="Arrow_ID_726918944" STARTARROW="None" STARTINCLINATION="1012;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1492461289101" ID="ID_1507239589" MODIFIED="1518487921062" TEXT="Frage: Objekt-Referenzen">
|
|
<arrowlink COLOR="#8e2a4d" DESTINATION="ID_1909730752" ENDARROW="Default" ENDINCLINATION="190;-96;" ID="Arrow_ID_1543429248" STARTARROW="None" STARTINCLINATION="-103;109;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1492461304231" ID="ID_1680959339" MODIFIED="1518487921062" TEXT="LuidH"/>
|
|
<node CREATED="1492461306898" ID="ID_94770054" MODIFIED="1518487921062" TEXT="EntryID"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492463479663" ID="ID_1909730752" MODIFIED="1518487921062" TEXT="#1096 passing object IDs">
|
|
<arrowlink COLOR="#8e2a4d" DESTINATION="ID_938886823" ENDARROW="Default" ENDINCLINATION="-367;31;" ID="Arrow_ID_265571961" STARTARROW="None" STARTINCLINATION="-367;31;"/>
|
|
<linktarget COLOR="#8e2a4d" DESTINATION="ID_1909730752" ENDARROW="Default" ENDINCLINATION="190;-96;" ID="Arrow_ID_1543429248" SOURCE="ID_1507239589" STARTARROW="None" STARTINCLINATION="-103;109;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1485549081728" FOLDED="true" ID="ID_1122969153" MODIFIED="1679087809377" TEXT="globale Aktionen">
|
|
<arrowlink COLOR="#824f68" DESTINATION="ID_826011549" ENDARROW="Default" ENDINCLINATION="-872;-1178;" ID="Arrow_ID_1373278707" STARTARROW="Default" STARTINCLINATION="911;271;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1488419973349" ID="ID_1855791702" MODIFIED="1518487921062" TEXT="brauche ein Konzept">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679087725579" ID="ID_1392812297" MODIFIED="1679087800628" TEXT="zunächst zurückgestellt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das können wir erst dann sinnvoll angehen, wenn die Application-Core weiter ausgereift ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#58379a" DESTINATION="ID_1455353650" ENDARROW="Default" ENDINCLINATION="111;202;" ID="Arrow_ID_1092382782" STARTARROW="None" STARTINCLINATION="100;-9;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1488419979868" ID="ID_474441211" MODIFIED="1518487921062" TEXT="InteractionDirector">
|
|
<arrowlink COLOR="#5e4463" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-57;-739;" ID="Arrow_ID_1847127764" STARTARROW="None" STARTINCLINATION="73;95;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1488419993090" ID="ID_1039124749" MODIFIED="1518487921062" TEXT="wird Dreh- und Angelpunkt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1488420003752" ID="ID_1927319278" MODIFIED="1518487921062" TEXT="löst auch das Model-Root-Problem">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1488420014959" ID="ID_1816556929" MODIFIED="1518487921062" TEXT="war insofern sinnvoller Umweg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1485909456513" HGAP="55" ID="ID_576215675" MODIFIED="1678459579082" TEXT="top-level-Verdrahtung" VSHIFT="1">
|
|
<arrowlink COLOR="#8c95b2" DESTINATION="ID_36527267" ENDARROW="Default" ENDINCLINATION="138;-548;" ID="Arrow_ID_1284182756" STARTARROW="None" STARTINCLINATION="883;143;"/>
|
|
<linktarget COLOR="#47a98e" DESTINATION="ID_576215675" ENDARROW="Default" ENDINCLINATION="-431;-49;" ID="Arrow_ID_162897615" SOURCE="ID_1506722948" STARTARROW="None" STARTINCLINATION="-633;50;"/>
|
|
<linktarget COLOR="#23d63e" DESTINATION="ID_576215675" ENDARROW="Default" ENDINCLINATION="-930;90;" ID="Arrow_ID_638247395" SOURCE="ID_546190730" STARTARROW="None" STARTINCLINATION="801;59;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1485909560027" ID="ID_1949656657" MODIFIED="1518487921062" TEXT="baut den UI-Rahen auf"/>
|
|
<node CREATED="1485909491412" ID="ID_1205077540" MODIFIED="1518487921062" TEXT="macht die Applikation betriebsbereit">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1486942467620" FOLDED="true" HGAP="151" ID="ID_1761000392" MODIFIED="1518487921062" TEXT="Alternativen" VSHIFT="14">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1486942493208" ID="ID_805305597" MODIFIED="1561827464738" TEXT="alles via InteractionDirector">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1486944032334" ID="ID_1959218653" MODIFIED="1518487921062" TEXT="er macht ohnehin fast alles">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1486944056595" ID="ID_423413011" MODIFIED="1518487921062" TEXT="Actions wird eine leere Hülle">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1486944064506" ID="ID_712470482" MODIFIED="1518487921062" TEXT="baut das Menü"/>
|
|
<node CREATED="1486944068985" ID="ID_1074291755" MODIFIED="1518487921062" TEXT="stellt die Closures bereit"/>
|
|
<node CREATED="1486944075456" ID="ID_1851635277" MODIFIED="1518487921062" TEXT="könnte Exceptions fangen"/>
|
|
<node CREATED="1486944081143" ID="ID_310163833" MODIFIED="1518487921062" TEXT="...ist das wirklich so schlecht?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487034056153" ID="ID_1455538166" MODIFIED="1518487921062" TEXT="Rein aus dem Bauch heraus....">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1487034063408" ID="ID_1251347399" MODIFIED="1518487921062">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das <i>verschiebt</i> das Problem nur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1487034078974" ID="ID_796487731" MODIFIED="1518487921062" TEXT="verletzt das single responsibility pattern"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486942523724" ID="ID_843953045" MODIFIED="1561827464741" TEXT="globalen Kontext einführen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1486942614400" ID="ID_872912875" MODIFIED="1518487921062" TEXT="Action-Definition "weiß" wer das konkret machen kann"/>
|
|
<node CREATED="1486943522965" ID="ID_244569580" MODIFIED="1518487921062" TEXT="konkret...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1486943529763" ID="ID_186058004" MODIFIED="1518487921062" TEXT="WindowLocator">
|
|
<node CREATED="1486943536354" ID="ID_1414688651" MODIFIED="1518487921062" TEXT="neues Fenster"/>
|
|
<node CREATED="1486943539809" ID="ID_443462243" MODIFIED="1518487921062" TEXT="Fenster schließen"/>
|
|
<node CREATED="1486943765530" ID="ID_1741627821" MODIFIED="1518487921062" TEXT="show Panel xyz"/>
|
|
<node CREATED="1486943555279" ID="ID_1864984187" MODIFIED="1518487921062" TEXT="möglicherweise: gehe zu"/>
|
|
</node>
|
|
<node CREATED="1486943607120" ID="ID_372751802" MODIFIED="1518487921062" TEXT="InteractionDirector">
|
|
<node CREATED="1486943922541" ID="ID_1681514542" MODIFIED="1518487921062" TEXT="Quit Lumiera"/>
|
|
<node CREATED="1486943614039" ID="ID_1857002831" MODIFIED="1518487921062" TEXT="Session schließen/öffnen/speichern"/>
|
|
<node CREATED="1486943634229" ID="ID_423286018" MODIFIED="1518487921062" TEXT="Einstieg in...">
|
|
<node CREATED="1486943640004" ID="ID_1474901789" MODIFIED="1518487921062" TEXT="Preferences"/>
|
|
<node CREATED="1486943643179" ID="ID_1263689486" MODIFIED="1518487921062" TEXT="Assets"/>
|
|
<node CREATED="1486943645554" ID="ID_357680575" MODIFIED="1518487921062" TEXT="Timeline"/>
|
|
</node>
|
|
<node CREATED="1486943674287" ID="ID_1380296040" MODIFIED="1518487921062" TEXT="kontextabhängig">
|
|
<node CREATED="1486943681046" ID="ID_1415550100" MODIFIED="1518487921062" TEXT="Render"/>
|
|
<node CREATED="1486943683198" ID="ID_510577218" MODIFIED="1518487921062" TEXT="add Sequence"/>
|
|
<node CREATED="1486943691228" ID="ID_684917844" MODIFIED="1518487921062" TEXT="add Track"/>
|
|
<node CREATED="1486943854214" ID="ID_382166589" MODIFIED="1518487921062" TEXT="new Viewer"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486943969999" ID="ID_499822898" MODIFIED="1518487921063" TEXT="Meta-Belange">
|
|
<node CREATED="1486943974590" ID="ID_233678784" MODIFIED="1518487921063" TEXT="Hilfe"/>
|
|
<node CREATED="1486944977005" ID="ID_1548991554" MODIFIED="1518487921063" TEXT="Wizzards"/>
|
|
<node CREATED="1533687508760" ID="ID_1331912107" MODIFIED="1533687523000" TEXT="Fehlerlog (notification display)"/>
|
|
<node CREATED="1486943976942" ID="ID_1215823743" MODIFIED="1518487921063" TEXT="Navigation">
|
|
<node CREATED="1486944958215" ID="ID_175734210" MODIFIED="1518487921063" TEXT="ist wohl ein eigener Controller"/>
|
|
<node CREATED="1486944947297" ID="ID_572583322" MODIFIED="1518487921063" TEXT="hängt aber mit InteractionDirector zusammen"/>
|
|
<node CREATED="1486944966679" ID="ID_185137660" MODIFIED="1518487921063" TEXT="könnte ein Kind von diesem sein...."/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486942533939" ID="ID_1309437882" MODIFIED="1518487921063" TEXT="einzelne Closures explizit">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1486942574333" ID="ID_189848820" MODIFIED="1518487921063" TEXT="das läuft auf ein Delegate hinaus"/>
|
|
<node CREATED="1486942583053" ID="ID_1367249768" MODIFIED="1518487921063" TEXT="...und das wäre der InteractionDirector"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487034156380" HGAP="29" ID="ID_1632778987" MODIFIED="1518487921063" TEXT="globaler Kontext" VSHIFT="11">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1487034162275" ID="ID_28375182" MODIFIED="1518487921063" TEXT="wenige, eng zusammenarbeitende Objekte"/>
|
|
<node CREATED="1487034172393" ID="ID_1167812745" MODIFIED="1518487921063" TEXT="...von denen doch jedes seine Aufgabe hat"/>
|
|
<node CREATED="1487034180712" ID="ID_1371598611" MODIFIED="1518487921063" TEXT="und jedes genau weiß, was die andern können"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1504393149140" FOLDED="true" HGAP="38" ID="ID_48107354" MODIFIED="1561827464745" TEXT="Addressierung" VSHIFT="55">
|
|
<arrowlink COLOR="#4f5d91" DESTINATION="ID_974158229" ENDARROW="Default" ENDINCLINATION="383;-2505;" ID="Arrow_ID_1832380552" STARTARROW="None" STARTINCLINATION="-730;103;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1504393160466" ID="ID_450547493" MODIFIED="1541547317746" TEXT="globales Addreß-Schema">
|
|
<node CREATED="1504393168946" ID="ID_390425361" MODIFIED="1518487921063" TEXT="Model-Typen"/>
|
|
<node CREATED="1504393177712" ID="ID_1686403667" MODIFIED="1518487921063" TEXT="View-Deskriptor">
|
|
<node CREATED="1504393184608" ID="ID_792210197" MODIFIED="1518487921063" TEXT="Strategy"/>
|
|
<node CREATED="1504834023671" ID="ID_1906244318" MODIFIED="1518487921063" TEXT="konfiguriert">
|
|
<node CREATED="1504834102408" ID="ID_1248837242" MODIFIED="1518487921063" TEXT="Layout/Verhalten"/>
|
|
<node CREATED="1504393188615" ID="ID_1397553997" MODIFIED="1518487921063" TEXT="Verhaltensmuster für Component-Views">
|
|
<arrowlink COLOR="#5e819b" DESTINATION="ID_686917529" ENDARROW="Default" ENDINCLINATION="-89;-122;" ID="Arrow_ID_1067086551" STARTARROW="None" STARTINCLINATION="-322;62;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833678189" ID="ID_173722644" MODIFIED="1518487921063" TEXT="Einstiegspunkt">
|
|
<arrowlink COLOR="#717686" DESTINATION="ID_65709251" ENDARROW="Default" ENDINCLINATION="-8;-209;" ID="Arrow_ID_1510990213" STARTARROW="None" STARTINCLINATION="92;95;"/>
|
|
<node CREATED="1504833683333" ID="ID_583036636" MODIFIED="1544329029063" TEXT="Component View">
|
|
<arrowlink COLOR="#92a9df" DESTINATION="ID_1717772756" ENDARROW="Default" ENDINCLINATION="-1346;-3359;" ID="Arrow_ID_1986148222" STARTARROW="None" STARTINCLINATION="385;845;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1504833695107" ID="ID_1686159038" MODIFIED="1518487921063" TEXT="in einem Panel zu finden"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519356802243" HGAP="67" ID="ID_1415516084" MODIFIED="1538871866274" TEXT="Komponenten-Zugriff" VSHIFT="12">
|
|
<node CREATED="1504393221051" ID="ID_938886823" MODIFIED="1518487921063" TEXT="wie bekommt man eine Objekt-ID?">
|
|
<linktarget COLOR="#8e2a4d" DESTINATION="ID_938886823" ENDARROW="Default" ENDINCLINATION="-367;31;" ID="Arrow_ID_265571961" SOURCE="ID_1909730752" STARTARROW="None" STARTINCLINATION="-367;31;"/>
|
|
</node>
|
|
<node CREATED="1519356887367" ID="ID_1139603062" MODIFIED="1519356897033" TEXT="wie findet man den Ort einer Komponente?"/>
|
|
<node CREATED="1519356901933" ID="ID_596521684" MODIFIED="1519356913407" TEXT="Verhältnis ID / Ort">
|
|
<node CREATED="1519356920083" ID="ID_723456910" MODIFIED="1519356926342" TEXT="sind orthogonale Schemata">
|
|
<node CREATED="1519357047993" ID="ID_1706134856" MODIFIED="1541547248389" TEXT="ID = globale Identität">
|
|
<arrowlink COLOR="#6b83a8" DESTINATION="ID_1585676322" ENDARROW="Default" ENDINCLINATION="828;-65;" ID="Arrow_ID_174361092" STARTARROW="None" STARTINCLINATION="1067;-74;"/>
|
|
</node>
|
|
<node CREATED="1519357060599" ID="ID_975802429" MODIFIED="1519357070810" TEXT="Ort = Topologie + Typ">
|
|
<node CREATED="1519357081868" ID="ID_1484266304" MODIFIED="1519357090975" TEXT="Ortsnamen sind generisch"/>
|
|
<node CREATED="1519357091795" ID="ID_68008128" MODIFIED="1519357096374" TEXT="sie werden lokal verstanden"/>
|
|
<node CREATED="1519357097154" ID="ID_377787861" MODIFIED="1519357212192" TEXT="lokal als Typangaben interpretiert">
|
|
<arrowlink COLOR="#2b4283" DESTINATION="ID_778018274" ENDARROW="Default" ENDINCLINATION="-1752;0;" ID="Arrow_ID_1022345699" STARTARROW="None" STARTINCLINATION="795;544;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519356955358" ID="ID_1568727351" MODIFIED="1519356966058" TEXT="ID wird in den Ort eingepflantzt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519357006055" ID="ID_1652172363" MODIFIED="1519357017238" TEXT="Rückauflösung ID -> Ort">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506175115772" FOLDED="true" HGAP="318" ID="ID_1448696607" MODIFIED="1561827464751" VSHIFT="64">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>UI-Koordinaten </b>(UICoord)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<cloud COLOR="#e7d6c4"/>
|
|
<linktarget COLOR="#535189" DESTINATION="ID_1448696607" ENDARROW="Default" ENDINCLINATION="-391;179;" ID="Arrow_ID_1194909838" SOURCE="ID_342577636" STARTARROW="None" STARTINCLINATION="691;-200;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1506175332288" ID="ID_1487048178" MODIFIED="1506175335441" TEXT="immutable"/>
|
|
<node CREATED="1506175325136" ID="ID_569191479" MODIFIED="1506175331436" TEXT="kopierbare Werte"/>
|
|
<node CREATED="1506175344846" ID="ID_1787806028" MODIFIED="1506175357976" TEXT="Tupel von Literalen"/>
|
|
<node CREATED="1506175395879" ID="ID_1249891322" MODIFIED="1506175400362" TEXT="Bedeutungs-Varianten">
|
|
<node CREATED="1506175488451" ID="ID_134646571" MODIFIED="1506175559083" TEXT="Anker"/>
|
|
<node CREATED="1506175405502" ID="ID_468711419" MODIFIED="1506175417680" TEXT="explizit / wildcard"/>
|
|
<node CREATED="1506175444505" ID="ID_971546375" MODIFIED="1506175448772" TEXT="bekannt / unbekannt"/>
|
|
<node CREATED="1506175493954" ID="ID_1571215800" MODIFIED="1506175949153" TEXT="gedeckt / möglich / unmöglich"/>
|
|
</node>
|
|
<node CREATED="1506175969603" HGAP="58" ID="ID_1322989755" MODIFIED="1506181196817" TEXT="Auswertung" VSHIFT="43">
|
|
<node CREATED="1506175980946" ID="ID_1635470067" MODIFIED="1506175983965" TEXT="stateless">
|
|
<node CREATED="1506176104177" ID="ID_379934022" MODIFIED="1506176107452" TEXT="Traversierung"/>
|
|
<node CREATED="1506176108473" ID="ID_241520424" MODIFIED="1506176114467" TEXT="Interpretation"/>
|
|
<node CREATED="1506176114984" ID="ID_332155493" MODIFIED="1506176117235" TEXT="Abgleich"/>
|
|
</node>
|
|
<node CREATED="1506175984577" HGAP="25" ID="ID_610939878" MODIFIED="1506957372981" TEXT="im Resolver" VSHIFT="-1">
|
|
<arrowlink COLOR="#65759f" DESTINATION="ID_1878859300" ENDARROW="Default" ENDINCLINATION="-439;-594;" ID="Arrow_ID_68163828" STARTARROW="None" STARTINCLINATION="307;351;"/>
|
|
<node CREATED="1506176010590" ID="ID_901285927" MODIFIED="1506176067906" TEXT="Kontext-Infos">
|
|
<node CREATED="1506176024596" ID="ID_1050302466" MODIFIED="1506176028175" TEXT="Aktuelles Fenster"/>
|
|
<node CREATED="1506176028787" ID="ID_1768321192" MODIFIED="1506176037158" TEXT="existierende">
|
|
<node CREATED="1506176038098" ID="ID_543075741" MODIFIED="1506176039621" TEXT="Fenster"/>
|
|
<node CREATED="1506176040161" ID="ID_685895986" MODIFIED="1506176041845" TEXT="Panels"/>
|
|
<node CREATED="1506176043073" ID="ID_670302946" MODIFIED="1506176044853" TEXT="Views"/>
|
|
<node CREATED="1506176045465" ID="ID_6996325" MODIFIED="1506176046820" TEXT="Tabs"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506176077269" ID="ID_1123330267" MODIFIED="1506176086486" TEXT="Kontext ist zu kapseln">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506180744136" HGAP="-8" ID="ID_1053983304" MODIFIED="1506180750564" TEXT="Operationen" VSHIFT="34">
|
|
<node CREATED="1506180752094" ID="ID_532619019" MODIFIED="1506181105657" TEXT="Query">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1506180752094" ID="ID_509982542" MODIFIED="1506180752094" TEXT="locally decidable">
|
|
<node CREATED="1506180752095" ID="ID_1152353258" MODIFIED="1506180752095" TEXT="explicitness"/>
|
|
<node CREATED="1506180752095" ID="ID_482556645" MODIFIED="1506180752095" TEXT="presence"/>
|
|
</node>
|
|
<node CREATED="1506180752096" ID="ID_320263447" MODIFIED="1506180752096" TEXT="contextual predications">
|
|
<node CREATED="1506180752096" ID="ID_837824348" MODIFIED="1506180752096" TEXT="anchorage">
|
|
<node CREATED="1506180752097" ID="ID_456798717" MODIFIED="1576282358130" TEXT="explicitly anchored">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...and this anchorage can be covered and backed by the currently existing UI configuration
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1506180752098" ID="ID_1971122985" MODIFIED="1576282358130" TEXT="can be a anchored">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...by interpolation of some wildcards
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1506180752099" ID="ID_1588059901" MODIFIED="1576282358129" TEXT="incomplete">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...need to be extended to allow anchoring
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1506180752099" ID="ID_1331064451" MODIFIED="1506180752099" TEXT="impossible to anchor"/>
|
|
</node>
|
|
<node CREATED="1506180752099" ID="ID_1327313624" MODIFIED="1506180752099" TEXT="coverage">
|
|
<node CREATED="1506180752099" ID="ID_1861096545" MODIFIED="1533608413554" TEXT="Prereq: need to anchored">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1506180752099" ID="ID_1260046910" MODIFIED="1506180752099" TEXT="explicitly"/>
|
|
<node CREATED="1506180752100" ID="ID_1853688132" MODIFIED="1506180752100" TEXT="by interpolation"/>
|
|
<node CREATED="1506180752100" ID="ID_1093737813" MODIFIED="1506180752100" TEXT="by extension of incomplete"/>
|
|
</node>
|
|
<node CREATED="1506180752100" ID="ID_1925372021" MODIFIED="1506180752100" TEXT="completely covered"/>
|
|
<node CREATED="1506180752100" ID="ID_1969020445" MODIFIED="1533608413555" TEXT="partially covered">
|
|
<node CREATED="1506180752100" ID="ID_1998116592" MODIFIED="1506180752100" TEXT="test only"/>
|
|
<node CREATED="1506180752101" ID="ID_1458219980" MODIFIED="1506180752101" TEXT="yield uncovered extension part"/>
|
|
</node>
|
|
<node CREATED="1506180752101" ID="ID_398264250" MODIFIED="1506180752101" TEXT="possible to cover completely"/>
|
|
<node CREATED="1506180752101" ID="ID_622219519" MODIFIED="1506180752101" TEXT="impossible to cover"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506180752101" ID="ID_346716510" MODIFIED="1506181115210" TEXT="Mutate">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1506180752101" ID="ID_1235660281" MODIFIED="1506180752101" TEXT="anchoring">
|
|
<node CREATED="1506180752101" ID="ID_888532646" MODIFIED="1506180752101" TEXT="by interpolating the given spec"/>
|
|
<node CREATED="1506180752102" ID="ID_1762786822" MODIFIED="1506180752102" TEXT="by interpolation and extension of the given spec"/>
|
|
</node>
|
|
<node CREATED="1506180752102" ID="ID_478035492" MODIFIED="1576282358129" TEXT="covering">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
we may construct the covered part of a given spec, including automatic anchoring.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1506180752102" ID="ID_1444275949" MODIFIED="1506180752102" TEXT="navigating">
|
|
<node CREATED="1506180752102" ID="ID_1839478635" MODIFIED="1506181147267" TEXT="Prereq">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1506180752103" ID="ID_183872472" MODIFIED="1506180752103" TEXT="needs to be anchored"/>
|
|
<node CREATED="1506180752103" ID="ID_238142563" MODIFIED="1506180752103" TEXT="needs to be completely covered"/>
|
|
</node>
|
|
<node CREATED="1506180752103" ID="ID_1985524064" MODIFIED="1576282358128" TEXT="starting point">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
navigate to the real UI component
|
|
</p>
|
|
<p>
|
|
designated by the given coordinate spec
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1506180752103" ID="ID_1926205805" MODIFIED="1506180752103" TEXT="ascend"/>
|
|
<node CREATED="1506180752103" ID="ID_1087218713" MODIFIED="1533608413555" TEXT="descend to an existing child">
|
|
<node CREATED="1506180752103" ID="ID_908880124" MODIFIED="1506180752103" TEXT="by matching name"/>
|
|
<node CREATED="1506180752104" ID="ID_1484420566" MODIFIED="1506180752104" TEXT="by index number"/>
|
|
</node>
|
|
<node CREATED="1506180752104" ID="ID_534962278" MODIFIED="1506180752104" TEXT="extend the path by ...creates uncovered extension sequence"/>
|
|
<node CREATED="1506180752104" ID="ID_552405160" MODIFIED="1576282358128" TEXT="create suitable children">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...halten wir besser raus aus diesem Design.
|
|
</p>
|
|
<p>
|
|
Denn es würde stärkere Annahmen über die "Zielelemente" erforderlich machen,
|
|
</p>
|
|
<p>
|
|
und diese dann doch wieder in ein Korsett zwängen. Im Moment (10/17) habe ich
|
|
</p>
|
|
<p>
|
|
stark den Verdacht, daß wir das nur in wenigen Spezialfällen brauchen werden,
|
|
</p>
|
|
<p>
|
|
und dann kann man es auch extern belassen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504393295097" ID="ID_65709251" MODIFIED="1561827464760" TEXT="wie erreicht man einen ComponentView?">
|
|
<arrowlink COLOR="#524f7b" DESTINATION="ID_385011645" ENDARROW="Default" ENDINCLINATION="353;-22;" ID="Arrow_ID_186523581" STARTARROW="None" STARTINCLINATION="1270;350;"/>
|
|
<linktarget COLOR="#717686" DESTINATION="ID_65709251" ENDARROW="Default" ENDINCLINATION="-8;-209;" ID="Arrow_ID_1510990213" SOURCE="ID_173722644" STARTARROW="None" STARTINCLINATION="92;95;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1522939988823" ID="ID_727558614" MODIFIED="1522939999257" TEXT="Antwort...">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1522940008276" ID="ID_1983743908" MODIFIED="1522940013511" TEXT="über den ViewLocator"/>
|
|
<node CREATED="1522940014267" ID="ID_707843808" MODIFIED="1522940023254" TEXT="der bietet eine Zugriffs-Funktion pro Type"/>
|
|
<node CREATED="1522940023865" ID="ID_1335645863" MODIFIED="1522940040003" TEXT="und was diese macht, ist per ViewSpec-DSL definiert"/>
|
|
</node>
|
|
<node CREATED="1504457221429" ID="ID_7304477" MODIFIED="1518487921063" TEXT="Problem: Kopplung">
|
|
<node CREATED="1504457233178" ID="ID_999730208" MODIFIED="1518487921063" TEXT="ViewLocator an PanelLocator"/>
|
|
<node CREATED="1504457251520" ID="ID_799090381" MODIFIED="1518487921063" TEXT="leaks out into the Strategy"/>
|
|
</node>
|
|
<node CREATED="1504458201898" FOLDED="true" ID="ID_486407658" MODIFIED="1518487921063" TEXT="Lösungen">
|
|
<node CREATED="1504458207889" ID="ID_287209177" MODIFIED="1522939882022" TEXT="lokal definierte Zugriffsfunktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522939868519" ID="ID_574994725" MODIFIED="1522939885468" TEXT="in eine DSL eingebettet">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1504458229743" ID="ID_1174387567" MODIFIED="1522939863979" TEXT="ENUM und lokaler Switch">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504458255403" FOLDED="true" HGAP="41" ID="ID_246632028" MODIFIED="1576282358127" TEXT="Fälle" VSHIFT="9">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was für verschiedene Arten von Zugriff
|
|
</p>
|
|
<p>
|
|
sind denkbar und müssen in der Strategy konfigurierbar sein?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504458488876" ID="ID_800753364" MODIFIED="1518487921063" TEXT="Ort">
|
|
<node CREATED="1504458802042" ID="ID_300193794" MODIFIED="1518487921063" TEXT="expliziter Ort (global)"/>
|
|
<node CREATED="1504458809745" ID="ID_142530354" MODIFIED="1518487921063" TEXT="bestimtes Panel (pro Fenster)"/>
|
|
<node CREATED="1504458863986" ID="ID_1423034932" MODIFIED="1518487921063" TEXT="aktuelle Gruppe"/>
|
|
</node>
|
|
<node CREATED="1504458495043" ID="ID_1488124165" MODIFIED="1518487921063" TEXT="Zahl">
|
|
<node CREATED="1504458543877" ID="ID_1146489911" MODIFIED="1518487921063" TEXT="nur einer">
|
|
<node CREATED="1504458550796" ID="ID_193440091" MODIFIED="1518487921063" TEXT="global (alle Fenster)"/>
|
|
<node CREATED="1504458558307" ID="ID_1626706609" MODIFIED="1518487921063" TEXT="pro Fenster"/>
|
|
</node>
|
|
<node CREATED="1504458603213" ID="ID_1266508735" MODIFIED="1518487921063" TEXT="viele">
|
|
<node CREATED="1504458606052" ID="ID_1545836853" MODIFIED="1518487921063" TEXT="begrenzte Zahl">
|
|
<node CREATED="1504458697520" ID="ID_1784843227" MODIFIED="1518487921063" TEXT="immer pro Gruppe"/>
|
|
<node CREATED="1504479134100" ID="ID_631162736" MODIFIED="1518487921063" TEXT="Limit an die Gruppe gebunden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504458702640" ID="ID_943045771" MODIFIED="1518487921063" TEXT="unlimitiert"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504459120824" ID="ID_342577636" MODIFIED="1518487921063" TEXT="UI-Koordinaten">
|
|
<arrowlink COLOR="#535189" DESTINATION="ID_1448696607" ENDARROW="Default" ENDINCLINATION="-391;179;" ID="Arrow_ID_1194909838" STARTARROW="None" STARTINCLINATION="691;-200;"/>
|
|
<node CREATED="1504479456449" ID="ID_959239388" MODIFIED="1518487921063">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mögliche
|
|
</p>
|
|
<p>
|
|
Komponenten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1504462874221" ID="ID_437025243" MODIFIED="1518487921063" TEXT="[optional] top-level Fenster"/>
|
|
<node CREATED="1504462888107" ID="ID_121049221" MODIFIED="1518487921063" TEXT="[optional] Perspektive"/>
|
|
<node CREATED="1504462891394" ID="ID_1138854843" MODIFIED="1518487921063" TEXT="Panel"/>
|
|
<node CREATED="1504463020913" ID="ID_808284638" MODIFIED="1518487921063" TEXT="[optional] Gruppe"/>
|
|
<node CREATED="1504463028384" ID="ID_1928250888" MODIFIED="1518487921063" TEXT="View-ID"/>
|
|
</node>
|
|
<node CREATED="1504479185405" HGAP="50" ID="ID_50865654" MODIFIED="1575131533888" TEXT="abgeleitet aus Fokus-Koordinaten" VSHIFT="15">
|
|
<arrowlink COLOR="#a9a5cd" DESTINATION="ID_150523428" ENDARROW="Default" ENDINCLINATION="1417;-3062;" ID="Arrow_ID_1485937133" STARTARROW="None" STARTINCLINATION="1030;-46;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506175078553" FOLDED="true" HGAP="97" ID="ID_1154523344" MODIFIED="1561827464775" TEXT="Implementierung" VSHIFT="29">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1506262853956" HGAP="-86" ID="ID_652224508" MODIFIED="1679362063135" TEXT="Design-Fragen" VSHIFT="-3">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1506262880944" ID="ID_1951800292" MODIFIED="1518487921063" TEXT="Mutability">
|
|
<node CREATED="1506262901774" ID="ID_732818888" MODIFIED="1518487921063" TEXT="immutable == gut?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1506262939753" ID="ID_1096602096" MODIFIED="1518487921063" TEXT="sind 8 Zeiger "schwergewichtig"?"/>
|
|
<node CREATED="1506262985930" ID="ID_1947259139" MODIFIED="1518487921063" TEXT="was konkret will man verhindern?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506263520707" ID="ID_1446434847" MODIFIED="1518487921063" TEXT="wozu Ändern?">
|
|
<node CREATED="1506263529922" ID="ID_1129266280" MODIFIED="1518487921063" TEXT="Definition zusammenstellen"/>
|
|
<node CREATED="1506263537721" ID="ID_1617312199" MODIFIED="1518487921063" TEXT="Pfad-Navigation">
|
|
<arrowlink COLOR="#726f7d" DESTINATION="ID_1755700140" ENDARROW="Default" ENDINCLINATION="15;-43;" ID="Arrow_ID_1791940371" STARTARROW="None" STARTINCLINATION="-110;6;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506263379070" HGAP="34" ID="ID_1755700140" MODIFIED="1518487921063" VSHIFT="28">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie funktioniert
|
|
</p>
|
|
<p>
|
|
Pfad-Navigation?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#726f7d" DESTINATION="ID_1755700140" ENDARROW="Default" ENDINCLINATION="15;-43;" ID="Arrow_ID_1791940371" SOURCE="ID_1617312199" STARTARROW="None" STARTINCLINATION="-110;6;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1506263421552" ID="ID_1410083594" MODIFIED="1518487921063" TEXT="Idee: Wrapper">
|
|
<node CREATED="1506263427287" ID="ID_190906360" MODIFIED="1518487921063" TEXT="»path navigator«"/>
|
|
<node CREATED="1506263442430" ID="ID_126065663" MODIFIED="1518487921063" TEXT="friend oder Subklasse"/>
|
|
</node>
|
|
<node CREATED="1506263465075" ID="ID_1873282209" MODIFIED="1518487921063" TEXT="Problem: Kontext">
|
|
<node CREATED="1506263472658" ID="ID_557885064" MODIFIED="1518487921063" TEXT="Navigation ist nicht beliebig"/>
|
|
<node CREATED="1506263486160" ID="ID_643453258" MODIFIED="1518487921063" TEXT="muß für jeden Schritt Kontext abfragen"/>
|
|
<node CREATED="1507923810917" ID="ID_1300680611" MODIFIED="1518487921063" TEXT="Delegations-API">
|
|
<node CREATED="1507923825938" ID="ID_248121468" MODIFIED="1518487921063" TEXT="Kontext-Anfragen"/>
|
|
<node CREATED="1507923832289" ID="ID_1141152218" MODIFIED="1518487921063" TEXT="vom konkreten UI implementiert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1507939232775" FOLDED="true" ID="ID_314635923" MODIFIED="1518487921063" TEXT="Problem: Binden auf den Kontext">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1507939270618" ID="ID_1505797299" MODIFIED="1518487921063" TEXT="abstrakte Struktur -> konkrete Widgets"/>
|
|
<node CREATED="1507939279761" ID="ID_250590373" MODIFIED="1518487921063" TEXT="keine natürliche Introspektion gegeben"/>
|
|
<node CREATED="1507939312860" HGAP="78" ID="ID_444535530" MODIFIED="1576282358127" TEXT="Analyse" VSHIFT="7">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habe diese Analyse 2017/2018 ein Stück weit vorangetrieben.
|
|
</p>
|
|
<p>
|
|
Ergebnis war die Schaffung von UI-Koordinaten und die ViewSpec-DSL
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Damit ist das Thema aber bei Weitem noch nicht ausgeschöpft,
|
|
</p>
|
|
<p>
|
|
jedoch genügend aufgeschlossen, um die konkrete Implementierung fortzusetzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1507939326250" ID="ID_1890759249" MODIFIED="1518487921063" TEXT="Aufgaben">
|
|
<node CREATED="1507939400248" ID="ID_1464418318" MODIFIED="1518487921063" TEXT="einem Pfad folgen">
|
|
<arrowlink COLOR="#7d375a" DESTINATION="ID_721718509" ENDARROW="Default" ENDINCLINATION="166;0;" ID="Arrow_ID_1170204247" STARTARROW="None" STARTINCLINATION="96;-13;"/>
|
|
<arrowlink COLOR="#7d375a" DESTINATION="ID_235303811" ENDARROW="Default" ENDINCLINATION="155;0;" ID="Arrow_ID_1900802893" STARTARROW="None" STARTINCLINATION="155;0;"/>
|
|
</node>
|
|
<node CREATED="1507939407943" ID="ID_721718509" MODIFIED="1518487921063" TEXT="eine Position konstituieren">
|
|
<linktarget COLOR="#7d375a" DESTINATION="ID_721718509" ENDARROW="Default" ENDINCLINATION="166;0;" ID="Arrow_ID_1170204247" SOURCE="ID_1464418318" STARTARROW="None" STARTINCLINATION="96;-13;"/>
|
|
</node>
|
|
<node CREATED="1507939427445" ID="ID_235303811" MODIFIED="1518487921064" TEXT="Kinder finden">
|
|
<linktarget COLOR="#7d375a" DESTINATION="ID_235303811" ENDARROW="Default" ENDINCLINATION="155;0;" ID="Arrow_ID_1900802893" SOURCE="ID_1464418318" STARTARROW="None" STARTINCLINATION="155;0;"/>
|
|
</node>
|
|
<node CREATED="1507939433916" ID="ID_1018540556" MODIFIED="1533608413556" TEXT="Kinder erzeugen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1508109233808" ID="ID_816587529" MODIFIED="1518487921064" TEXT="erfordert gemeinsames Interface"/>
|
|
<node CREATED="1508109252574" ID="ID_1185099286" MODIFIED="1518487921064">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
betrachte ich als <i>ungesund</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1507939846405" ID="ID_789410975" MODIFIED="1518487921064" TEXT="konkrete Probleme">
|
|
<node CREATED="1507939859100" ID="ID_860523933" MODIFIED="1533608413557" TEXT="wer bin "ich"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1507939956606" ID="ID_406843936" MODIFIED="1561827464791" TEXT="was ist gegeben?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1508017024459" ID="ID_604601896" MODIFIED="1518487921064" TEXT="stets ein kompletter Zugangs-Pfad">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1507939970349" ID="ID_714349147" MODIFIED="1561827464791" TEXT="in welcher Form ist es gegeben?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1508016915761" ID="ID_1202508530" MODIFIED="1518487921064" TEXT="konkretes Objekt"/>
|
|
<node CREATED="1508016919857" ID="ID_437710115" MODIFIED="1518487921064" TEXT="UI-Koordinaten per Lookup"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1507939869906" ID="ID_223198097" MODIFIED="1533608413572" STYLE="fork" TEXT="wo bin "ich"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1507940000057" ID="ID_1526112208" MODIFIED="1518487921064">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eine <i>reverse resolution</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1508016549578" ID="ID_526260275" MODIFIED="1518487921064">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>zentrales</b> Problem
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1508016569551" ID="ID_250033067" MODIFIED="1561827464791" TEXT="zwei Lösungsansätze">
|
|
<node CREATED="1508016575359" FOLDED="true" ID="ID_1494737189" MODIFIED="1561827483825" TEXT="Ort ist bekannt">
|
|
<node CREATED="1508016623480" ID="ID_66450805" MODIFIED="1518487921064" TEXT="Element speichert seine UICoord"/>
|
|
<node CREATED="1508016658684" ID="ID_116864327" MODIFIED="1518487921064" TEXT="globaler Index beim Erstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...der beim Erstellen des Elements
|
|
</p>
|
|
<p>
|
|
mit den zu diesem Zeitpunkt bekannten UI-Korrdinaten bestückt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508016602867" FOLDED="true" ID="ID_1861393889" MODIFIED="1561827483825" TEXT="Ort kann entdeckt werden">
|
|
<node CREATED="1508016710621" ID="ID_194767769" MODIFIED="1518487921064" TEXT="Element kennt seinen Vater"/>
|
|
<node CREATED="1508016741377" ID="ID_1796475231" MODIFIED="1518487921064" TEXT="(GObject) Introspektion"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1507939914076" ID="ID_109277608" MODIFIED="1533608413577" TEXT="was gilt als "Kind"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1507940046234" ID="ID_577613088" MODIFIED="1561827464792">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf welche Eigenschaften
|
|
</p>
|
|
<p>
|
|
stützen wir uns?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1508017106368" FOLDED="true" ID="ID_896661508" MODIFIED="1561827483825" TEXT="UI-Element">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1508017111959" ID="ID_484448099" MODIFIED="1518487921064" TEXT="nein"/>
|
|
<node CREATED="1508017121582" ID="ID_1052512660" MODIFIED="1518487921064" TEXT="denn: Fenster, Panels,..."/>
|
|
</node>
|
|
<node CREATED="1508017134709" FOLDED="true" ID="ID_881948528" MODIFIED="1561827483826" TEXT="Navigierbarkeit">
|
|
<node CREATED="1508017225544" ID="ID_1003735159" MODIFIED="1518487921064" TEXT="abstrakt">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1508017228080" ID="ID_1185322365" MODIFIED="1518487921064" TEXT="per Interface">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508017200476" FOLDED="true" ID="ID_1519289713" MODIFIED="1561827483826" TEXT="gar keine">
|
|
<node CREATED="1508017203419" ID="ID_1168589916" MODIFIED="1518487921064" TEXT="generische Programmierung!">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508017409096" ID="ID_1088456751" MODIFIED="1561827464793" TEXT="was ist hier ein "Element"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1508017614565" ID="ID_825986555" MODIFIED="1518487921064" TEXT="bleibt abstrakt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1508017621148" ID="ID_945496558" MODIFIED="1518487921064" TEXT="man kann etwas damit machen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1507939927035" ID="ID_461225915" MODIFIED="1533608413581">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wer bestimmt,
|
|
</p>
|
|
<p>
|
|
was "Kind" ist?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1507940112890" ID="ID_1195951242" MODIFIED="1518487921064" TEXT="der Bedarf??"/>
|
|
<node CREATED="1507940120425" ID="ID_338582582" MODIFIED="1518487921064" TEXT="der Erzeuger??"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508016417180" ID="ID_1611707918" MODIFIED="1518487921064" TEXT="use cases">
|
|
<node CREATED="1508016430306" ID="ID_192114274" MODIFIED="1533608413582" TEXT="ViewSpec">
|
|
<node CREATED="1508018634766" ID="ID_749934346" MODIFIED="1518487921064" TEXT="View allozieren"/>
|
|
<node CREATED="1508018640309" ID="ID_1078510800" MODIFIED="1518487921064" TEXT="View-Instanz per Gattung"/>
|
|
</node>
|
|
<node CREATED="1508016469685" ID="ID_115506070" MODIFIED="1533608413582" TEXT="change WorkSite">
|
|
<node CREATED="1508018713267" ID="ID_778872885" MODIFIED="1518487921064" TEXT="WorkSite verlagern / mitführen"/>
|
|
<node CREATED="1508018720562" ID="ID_187314256" MODIFIED="1518487921064" TEXT="zu anderer WorkSite gehen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508020233586" HGAP="41" ID="ID_1791370781" MODIFIED="1518487921064" TEXT="Fazit" VSHIFT="16">
|
|
<node CREATED="1508020253223" ID="ID_1259200744" MODIFIED="1518487921064" TEXT="Problem zerlegen">
|
|
<node CREATED="1508020258670" ID="ID_95147852" MODIFIED="1518487921064" TEXT="reverse resolution"/>
|
|
<node CREATED="1508020270709" ID="ID_1200125105" MODIFIED="1533608413583" TEXT="Kinder finden">
|
|
<node CREATED="1508020280683" ID="ID_646056653" MODIFIED="1518487921064" TEXT="fest verdrahtet für top-level"/>
|
|
<node CREATED="1508020286443" ID="ID_515525549" MODIFIED="1518487921064" TEXT="Interface für lokal"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508020411538" ID="ID_544888156" MODIFIED="1518487921064" TEXT="Navigation">
|
|
<node CREATED="1508020417633" ID="ID_1963411977" MODIFIED="1518487921064" TEXT="arbeitet nur auf UI-Koordinaten"/>
|
|
<node CREATED="1508020433719" ID="ID_1645971492" MODIFIED="1518487921064" TEXT="die dahinterliegenden Strukturen bleiben opaque"/>
|
|
<node CREATED="1508020450445" ID="ID_1822545447" MODIFIED="1533608413584" TEXT="mit dem Ergebnis">
|
|
<node CREATED="1508020465443" ID="ID_1921466133" MODIFIED="1518487921064" TEXT="kann man dann einen View erzeugen"/>
|
|
<node CREATED="1508020489583" ID="ID_1140824323" MODIFIED="1518487921064" TEXT="oder ein Element (bekannten Typs) bekommen"/>
|
|
<node CREATED="1508020551095" ID="ID_798942495" MODIFIED="1518487921064">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oder den <b>Spot</b> verschieben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1508020731399" HGAP="9" ID="ID_1043748115" MODIFIED="1518487921064" VSHIFT="49">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verbleibende
|
|
</p>
|
|
<p>
|
|
Probleme
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1508020782977" ID="ID_825574354" MODIFIED="1518487921064" TEXT="konkretes Element -> WorkSite"/>
|
|
<node CREATED="1508020790888" ID="ID_774784602" MODIFIED="1518487921064" TEXT="»reveal yourself«"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181068556" ID="ID_749871444" MODIFIED="1561827464797" TEXT="UICoord">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506181721910" ID="ID_1680105436" MODIFIED="1515555740881" TEXT="Folge von Symbolen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1506263953722" ID="ID_1293486815" MODIFIED="1506831482410" TEXT="Basis-Abstraktion">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506263960121" ID="ID_381874562" MODIFIED="1506831498373" TEXT="PathArray">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1506301404246" ID="ID_458341734" MODIFIED="1506301409177" TEXT="Impl-Layout">
|
|
<node CREATED="1506301410525" ID="ID_176098837" MODIFIED="1506301414840" TEXT="Rekursiv"/>
|
|
<node CREATED="1506301415548" ID="ID_212757263" MODIFIED="1506301419912" TEXT="chunk-wise"/>
|
|
</node>
|
|
<node CREATED="1506301421612" FOLDED="true" ID="ID_572376877" MODIFIED="1506301426568" TEXT="Meta-Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1506301428698" ID="ID_1290675306" MODIFIED="1533608413585" TEXT="Parameter-Pack zerlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1506301435826" ID="ID_1852582857" MODIFIED="1506301447508" TEXT="ersten Teil in ein std::array"/>
|
|
<node CREATED="1506301448288" ID="ID_1083459556" MODIFIED="1506301457058" TEXT="zweiten Teil rekursiv..."/>
|
|
</node>
|
|
<node CREATED="1506301468830" ID="ID_291609200" MODIFIED="1533608413586" TEXT="Lösungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1506301476836" ID="ID_1339982909" MODIFIED="1561827464797" TEXT="Stackoverflow">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1506301629128" ID="ID_1265747852" LINK="https://stackoverflow.com/questions/14261183/how-to-make-generic-computations-over-heterogeneous-argument-packs-of-a-variadic" MODIFIED="1506301640408" TEXT="Param-Pack-Library"/>
|
|
<node CREATED="1506301658388" ID="ID_284261237" LINK="https://stackoverflow.com/users/1932150/andy-prowl" MODIFIED="1506301669997" TEXT="von Andy Prowl"/>
|
|
<node CREATED="1506302060966" ID="ID_37516099" LINK="https://stackoverflow.com/questions/16821654/splitting-argpack-in-half/16980937#16980937" MODIFIED="1506302137771" TEXT="einfache Lösung: split Pack in half"/>
|
|
<node CREATED="1506302079276" ID="ID_539701222" LINK="https://stackoverflow.com/users/2361316/joe" MODIFIED="1506302087043" TEXT="von User Joe"/>
|
|
<node CREATED="1506303631812" ID="ID_1461128808" LINK="https://stackoverflow.com/questions/5484930/split-variadic-template-arguments/20814644#20814644" MODIFIED="1506303806992" TEXT="direkt initializer_list verwenden"/>
|
|
<node CREATED="1506303644395" ID="ID_1907242246" LINK="https://stackoverflow.com/users/2684539/jarod42" MODIFIED="1506303675990" TEXT="von user Jarod42 12/2013"/>
|
|
</node>
|
|
<node CREATED="1506301674594" ID="ID_573792630" MODIFIED="1561827464798" TEXT="Boost.fusion verwenden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1506301681345" ID="ID_1364627462" MODIFIED="1506301687084" TEXT="Param-Pack in Tupel"/>
|
|
<node CREATED="1506301687720" ID="ID_1178221359" MODIFIED="1506301696419" TEXT="Tupel mit Boost.fustion manipulieren"/>
|
|
<node CREATED="1506301696911" FOLDED="true" ID="ID_1626810109" MODIFIED="1561827483826" TEXT="Compiler optimiert Tupel weg">
|
|
<node CREATED="1506301725107" ID="ID_1409951481" MODIFIED="1506301731668" TEXT="Tupel von Referenzen"/>
|
|
<node CREATED="1506301713285" ID="ID_703461640" MODIFIED="1506301719136" TEXT="GCC und Clang"/>
|
|
<node CREATED="1506301719660" ID="ID_1581101665" MODIFIED="1506301722999" TEXT="in Release-Builds"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506301773341" ID="ID_515001314" MODIFIED="1561827464799" TEXT="Entscheidung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1506301780644" FOLDED="true" ID="ID_143930610" MODIFIED="1561827483826" TEXT="Boost.fustion abgelehnt">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1506301789546" ID="ID_322419894" MODIFIED="1506301792558" TEXT="verwendet MPL"/>
|
|
<node CREATED="1506301793130" ID="ID_1764621800" MODIFIED="1506301797158" TEXT="verwendet Boost.tuple"/>
|
|
<node CREATED="1506301797721" ID="ID_1580459971" MODIFIED="1506301801941" TEXT="generell undurchsichtig"/>
|
|
<node CREATED="1506301802865" ID="ID_1127036077" MODIFIED="1506301816915" TEXT="erfordert hohes Abstraktionsniveau"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506301834493" FOLDED="true" ID="ID_52512330" MODIFIED="1561827483826" TEXT="selber schreiben anhand Beispiel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1506723689710" ID="ID_454128552" MODIFIED="1506723762301" TEXT="Mini-Framework">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1506723694704" ID="ID_649123940" MODIFIED="1506723759877" TEXT="meta::pickArg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1506723699774" ID="ID_748812841" MODIFIED="1506723757331" TEXT="meta::pickInit">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1506723746120" ID="ID_154958112" MODIFIED="1506723790105" TEXT="unit-test dazu">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
VariadicArgumentPicker_test
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506831455771" ID="ID_1302634711" MODIFIED="1506831476337" TEXT="Normalisierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506831461738" ID="ID_1629539998" MODIFIED="1506831477640" TEXT="Unit-Test der Grenzfälle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506887647152" ID="ID_1069521621" MODIFIED="1506887654873" TEXT="String representation">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506906671372" ID="ID_458222870" MODIFIED="1506919618620" TEXT="Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506906657270" ID="ID_1234040290" MODIFIED="1506906687339" TEXT="builder functions">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506906664501" ID="ID_1257993809" MODIFIED="1506919612697" TEXT="mutator functions">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181727069" ID="ID_467120404" MODIFIED="1506984539619" TEXT="lokale Prädikate">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506181744939" ID="ID_1731446951" MODIFIED="1506984286100" TEXT="present">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181747466" ID="ID_1522805946" MODIFIED="1506984288444" TEXT="wildcard">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181783173" ID="ID_306479120" MODIFIED="1506984294555" TEXT="explicit">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984533458" ID="ID_373226509" MODIFIED="1506984536986" TEXT="complete">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181770783" ID="ID_295392903" MODIFIED="1506984530019" TEXT="incomplete">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181073556" ID="ID_1878859300" MODIFIED="1561827464810" TEXT="Resolver">
|
|
<linktarget COLOR="#65759f" DESTINATION="ID_1878859300" ENDARROW="Default" ENDINCLINATION="-439;-594;" ID="Arrow_ID_68163828" SOURCE="ID_610939878" STARTARROW="None" STARTINCLINATION="307;351;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506181794428" ID="ID_333406817" MODIFIED="1518487921064" TEXT="Setup">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506181800067" ID="ID_196802981" MODIFIED="1518487921065" TEXT="Wiring">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1515209567856" ID="ID_1008245035" MODIFIED="1518487921065" TEXT="warten auf reales UI..."/>
|
|
<node COLOR="#338800" CREATED="1515891216245" ID="ID_1439162441" MODIFIED="1518487921065" TEXT="Verhältnis von ViewLocator und Navigator klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515891241785" ID="ID_1731852581" MODIFIED="1522939281894" TEXT="Komponenten-Zugriffe in ViewLocator">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515891256616" ID="ID_1103868933" MODIFIED="1522939298316" TEXT="Baum-Abstraktion im Navigator">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508494036" ID="ID_490078637" MODIFIED="1522937686153" TEXT="LocationSolver integrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181802699" ID="ID_582767851" MODIFIED="1518487921065" TEXT="Test-Setup">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508537003861" FOLDED="true" ID="ID_846599209" MODIFIED="1531584013547" TEXT="Semantik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508537010868" ID="ID_484491629" MODIFIED="1508537050161">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
welche Operationen
|
|
</p>
|
|
<p>
|
|
sind wirklich notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1508537057661" ID="ID_1582824657" MODIFIED="1561827464811" TEXT="was heißt "covern"?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508538092061" ID="ID_731131821" MODIFIED="1508538096663" TEXT="komplett/partiell?"/>
|
|
<node CREATED="1508538108338" ID="ID_1403158284" MODIFIED="1508625730742" TEXT="so gut wie möglich">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1508625742468" ID="ID_511236910" MODIFIED="1508625745864" TEXT="kann partiell sein"/>
|
|
<node CREATED="1508625746667" ID="ID_1562464707" MODIFIED="1508625757806" TEXT="endet aber stets mit einem expliziten Element"/>
|
|
</node>
|
|
<node CREATED="1508538113098" ID="ID_415701605" MODIFIED="1508625772283" TEXT="eine Covfefe ermitteln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509323422183" FOLDED="true" ID="ID_1262448971" MODIFIED="1561827464815" TEXT="feine Punkte...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1509323432989" ID="ID_1373680102" MODIFIED="1509323467821" TEXT="per default nur bei expliziten Pfaden">
|
|
<node CREATED="1509323478248" ID="ID_101102957" MODIFIED="1509323487630" TEXT="vollständig (fängt mit Window an)"/>
|
|
<node CREATED="1509323473576" ID="ID_193021518" MODIFIED="1509323477588" TEXT="keine Wildcards"/>
|
|
<node CREATED="1509323560821" ID="ID_294426477" MODIFIED="1509323871911" TEXT="in dem Fall ist anchern und covern äquivalent">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1509323573047" ID="ID_263907664" MODIFIED="1529076269308" TEXT="covern: meint total">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509323496205" ID="ID_231710474" MODIFIED="1509323516558" TEXT="möglich">
|
|
<node CREATED="1509323517362" ID="ID_1758863955" MODIFIED="1509323518982" TEXT="ankern"/>
|
|
<node CREATED="1509323520018" ID="ID_895622034" MODIFIED="1533608413593" TEXT="covern">
|
|
<node CREATED="1514747986164" ID="ID_825407732" MODIFIED="1514747988957" TEXT="total"/>
|
|
<node CREATED="1514747959935" ID="ID_1468731328" MODIFIED="1514747964178" TEXT="partiell"/>
|
|
<node CREATED="1514747965047" ID="ID_662883062" MODIFIED="1514747969250" TEXT="maximal partiell"/>
|
|
<node CREATED="1514747970239" ID="ID_1657718025" MODIFIED="1514747982281" TEXT="partiell lokal maximal"/>
|
|
</node>
|
|
<node CREATED="1509323523193" ID="ID_1088301010" MODIFIED="1533608413593" TEXT="ist nicht das gleiche">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1509323532816" ID="ID_1206148872" MODIFIED="1576282358126" TEXT="covern kann scheitern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir verlangen, daß wir nach dem Interpolieren über eine Lücke
|
|
</p>
|
|
<p>
|
|
immer noch <i>mindestens ein explizt gegebenes</i> Element im Pfad haben,
|
|
</p>
|
|
<p>
|
|
welches auch von der UI-Topologie bestätigt wird.
|
|
</p>
|
|
<p>
|
|
Grund: wir wollen vermeiden, abschließende Wildcards <i>bloß irgendwie</i> zu binden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509323537479" ID="ID_1638614197" MODIFIED="1576282358126" TEXT="und trotzedm einen Anker finden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich wenn der Pfad mit einem explizit gegebenen Präfix anfängt,
|
|
</p>
|
|
<p>
|
|
dann aber Wildcards enthält, die nicht nach den verschärften Bedingungen gecovert werden können.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509323760466" ID="ID_446881733" MODIFIED="1576282358125" TEXT="oder eben doch komplett im Widerspruch zum UI stehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beispielsweise
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wenn schon das Präfix nicht paßt
|
|
</li>
|
|
<li>
|
|
wenn das erste Element nach dem Gap nirgends im realen UI in der tiefe existiert
|
|
</li>
|
|
<li>
|
|
wenn mehr Wildcards da sind, als restliche Tiefe zum Matchen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514748024287" ID="ID_85844536" MODIFIED="1533608413595" TEXT="ist partielle Covfefe sinnvoll">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1514748049396" ID="ID_844123386" MODIFIED="1514748079005" TEXT="schön/herausfordernd zu implementieren">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1514748059827" ID="ID_494930397" MODIFIED="1514748074221" TEXT="aber: ist das jemals eine praktische Fragestellung?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1515209459887" ID="ID_1673897385" MODIFIED="1515209521230">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
letzten Endes war es nahezu gleich schwer zu implementieren,
|
|
</p>
|
|
<p>
|
|
aber von der Aufruf-Logik her einfacher, stets nach partieller zu suchen
|
|
</p>
|
|
<p>
|
|
und totale Coverage nur nachträglich durch Längenvergleich festzustellen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514748348924" ID="ID_1348653545" MODIFIED="1514748355135" TEXT="zustandsbehafted">
|
|
<node CREATED="1514748356627" ID="ID_1208345503" MODIFIED="1514748364398" TEXT="Resolver hält letzte Coverage"/>
|
|
<node CREATED="1514748365274" ID="ID_576090166" MODIFIED="1514748371885" TEXT="diese kann partiell oder total sein"/>
|
|
<node COLOR="#990000" CREATED="1514748372690" ID="ID_1144080891" MODIFIED="1515209444769" TEXT="es kann mehrere Lösungen geben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508537087378" ID="ID_548549576" MODIFIED="1561827464817" TEXT="Wildcards interpolieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514328942052" ID="ID_638910432" MODIFIED="1514328949331" TEXT="»pathResolution«"/>
|
|
<node CREATED="1514328906513" ID="ID_627709808" MODIFIED="1514328914500" TEXT="Matching-Algo mit Backtracking"/>
|
|
<node CREATED="1514328993397" ID="ID_593456636" MODIFIED="1514329001856" TEXT="Bedeutung">
|
|
<node CREATED="1514329005195" ID="ID_1796584977" MODIFIED="1533608413596" TEXT="firstWindow">
|
|
<node CREATED="1514329012442" ID="ID_1189771196" MODIFIED="1514329021597" TEXT="das formal erste Fenster"/>
|
|
<node CREATED="1514329025856" ID="ID_1596613154" MODIFIED="1514329034363" TEXT="typischerweise das zuerst geöffnete"/>
|
|
</node>
|
|
<node CREATED="1514329036159" ID="ID_1686905211" MODIFIED="1533608413597" TEXT="currentWindow">
|
|
<node CREATED="1514329041046" ID="ID_880415056" MODIFIED="1514329055544" TEXT="das Fenster mit Fokus"/>
|
|
<node CREATED="1514329066515" ID="ID_1719764918" MODIFIED="1514329080026">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wo der <i>Spot</i> ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514329081745" ID="ID_1158924252" MODIFIED="1533608413598" TEXT="'*'">
|
|
<node CREATED="1514329106294" ID="ID_1601049546" MODIFIED="1514329116032" TEXT="innere Elemente in einer UICorrd-spec"/>
|
|
<node CREATED="1514329119084" ID="ID_898086495" MODIFIED="1514329219306" TEXT="match gegen existierende UI-Elemente..."/>
|
|
<node CREATED="1514329219990" ID="ID_490418392" MODIFIED="1514329226489" TEXT="so daß sich maximale Coverage ergibt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1508538286962" ID="ID_500149908" MODIFIED="1508538294950" TEXT="eine gemeinsame Basis-Operation">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539139418" FOLDED="true" ID="ID_1665843572" MODIFIED="1518487921065" TEXT="Operationen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1508540055241" ID="ID_565736574" MODIFIED="1522937702499" TEXT="Konventionen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1508540093004" ID="ID_277252077" MODIFIED="1576282358124" TEXT="Kinder-IDs sind eindeutig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Innerhalb einer Kinder-Folge gibt es keine duplikaten IDs.
|
|
</p>
|
|
<p>
|
|
Das heißt, es genügt, den ersten Match zu nehmen.
|
|
</p>
|
|
<p>
|
|
<b>Warnung</b>: diese Konvention ist besonders tückisch,
|
|
</p>
|
|
<p>
|
|
denn eine Verletzung kann weithin unbemerkt bleiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1508540106274" ID="ID_1727085652" MODIFIED="1576282358124" TEXT="ID-Literale existeren dauerhaft">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Resolver macht kein Memory-Management,
|
|
</p>
|
|
<p>
|
|
sondern speichert einfach Zeiger.
|
|
</p>
|
|
<p>
|
|
Es wird erwartet, daß diese gültig bleiben,
|
|
</p>
|
|
<p>
|
|
solange irgend jemand auf den Resolver oder den
|
|
</p>
|
|
<p>
|
|
daraus resultierenden Pfad zugreift
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1508540153564" ID="ID_165161640" MODIFIED="1576282358123" TEXT="UI stabil während der Auswertung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Topologie, aber auch der Fokus-Zustand
|
|
</p>
|
|
<p>
|
|
ändern sich nicht während der <i>aktiven Lebensdauer</i> eines Resolvers
|
|
</p>
|
|
<p>
|
|
Hierbei ist <i>aktive Lebensdauer</i> wie bei einem Iterator zu verstehen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1508540198326" ID="ID_720643889" MODIFIED="1576282358123" TEXT="Konventionen werden nicht verifiziert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber es gibt Konsistenzchecks + Exceptions
|
|
</p>
|
|
<p>
|
|
wenn die Auswertung aufgrund einer gebrochenen Konvention entgleist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539143849" ID="ID_1632791283" MODIFIED="1561827464818" TEXT="path-resolution">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1508539152568" ID="ID_153711822" MODIFIED="1515120963483" TEXT="Beschreibung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508539226014" ID="ID_1714773115" MODIFIED="1576282358122" TEXT="informell...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Tiefensuche über die reale UI-Topologie
|
|
</p>
|
|
<p>
|
|
Ziel ist, den Pfad <i>bestmöglich</i> zu covern
|
|
</p>
|
|
<p>
|
|
Es gilt die erste maximal abdeckende Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1508539330312" ID="ID_67492497" MODIFIED="1508539911843" TEXT="bewegt nur Suchmarken">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1508539350382" ID="ID_585593926" MODIFIED="1533608413598" TEXT="Ergebnis">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1508539582959" ID="ID_54646462" MODIFIED="1515120947568" TEXT="Anchor == Literal">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1508539633800" ID="ID_471699110" MODIFIED="1576282358122" TEXT="coverDepth (Zahl)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Tiefe, bis zu der dieser Pfad gedeckt ist.
|
|
</p>
|
|
<p>
|
|
Sofern der Pfad bereits explizit ist, genügt diese Info allein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1508539644775" ID="ID_186144507" MODIFIED="1576282358121" TEXT="[optional] explizite Coverage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
heap-allozierter expliziter Pfad.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wird notwendig, wenn *this wildcards enthält
|
|
</li>
|
|
<li>
|
|
Lösung wird unter Alternativen ausgewählt (nach maximaler Tiefe)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539156879" ID="ID_1086207992" MODIFIED="1515037663165" TEXT="Layered Evaluation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1508539857115" ID="ID_1186310701" MODIFIED="1514330270783" TEXT="state: Lösungs-Cache">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539879600" ID="ID_1527439493" MODIFIED="1515037657130" TEXT="Auswertungs-Frame (TreeExplorer)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514748701222" ID="ID_1571444662" MODIFIED="1515037660962" TEXT="Varianten partiell/total">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539166878" ID="ID_1751192686" MODIFIED="1515209410401" TEXT="Testfälle">
|
|
<arrowlink COLOR="#715b79" DESTINATION="ID_1362494392" ENDARROW="Default" ENDINCLINATION="-578;-16;" ID="Arrow_ID_1072715196" STARTARROW="None" STARTINCLINATION="477;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539191283" ID="ID_1571889765" MODIFIED="1561827464819" TEXT="anchor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1508540643163" ID="ID_600567923" MODIFIED="1515287569776" TEXT="trivial: Anker-Literal setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508540736254" ID="ID_531471348" MODIFIED="1515287568184" TEXT="incomplete: path-resolution machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508540764667" ID="ID_772420189" MODIFIED="1515287566905" TEXT="scheitert: Anchor == bottom">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508540811196" ID="ID_841748634" MODIFIED="1515287563969" TEXT="Ergebnis: Window-Komponente setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515287545795" ID="ID_1277908675" MODIFIED="1515287556163" TEXT="aber nur wenn ankerbar">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287557121" ID="ID_610935487" MODIFIED="1515287561833" TEXT="sonst: kein Effekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539195258" ID="ID_1044429952" MODIFIED="1525124214766" TEXT="cover">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1508540823475" ID="ID_793410656" MODIFIED="1561827464824" TEXT="path-resolution ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1509475490890" ID="ID_1616720086" MODIFIED="1518487921065" TEXT="rekursiv"/>
|
|
<node CREATED="1509475495057" ID="ID_27489504" MODIFIED="1518487921065" TEXT="Aufruf mit ResolutionState"/>
|
|
<node CREATED="1509475548066" ID="ID_1051318433" MODIFIED="1518487921065" TEXT="jede gefundene Lösung "abwerfen""/>
|
|
<node CREATED="1509475609338" ID="ID_142146721" MODIFIED="1518487921065" TEXT="erweitere Variante von drillDown()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1509475823750" FOLDED="true" ID="ID_1076784903" MODIFIED="1533608413600" TEXT="Problem: LocationQuery verwenden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1509475849931" ID="ID_313015724" MODIFIED="1518487921065" TEXT="der Baum ist nicht direkt zugänglich"/>
|
|
<node CREATED="1509475856514" ID="ID_759555189" MODIFIED="1518487921065" TEXT="geht dann überhaupt eine rekursive impl?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1509475946414" ID="ID_815740043" MODIFIED="1518487921065" TEXT="muß die Child-Iteratoren nutzen"/>
|
|
<node CREATED="1509475966459" ID="ID_1480938627" MODIFIED="1518487921065" TEXT="ineffizient; steigt jedesmal neu von der Wurzel ab"/>
|
|
<node CREATED="1509476108672" ID="ID_609074970" MODIFIED="1561827464825" TEXT="Kern des Problems">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1509476118647" ID="ID_1491799749" MODIFIED="1518487921065" TEXT="habe Auswertungs-Zustand"/>
|
|
<node CREATED="1509476126793" ID="ID_1463784807" MODIFIED="1518487921065" TEXT="ist mit dem Baum verwoben"/>
|
|
<node CREATED="1509476133741" ID="ID_1273043633" MODIFIED="1518487921065" TEXT="der Baum ist aber Implementierungs-Detail"/>
|
|
</node>
|
|
<node CREATED="1509476154258" ID="ID_930376282" MODIFIED="1535891788152" TEXT="mögliche Lösungen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1509476160585" ID="ID_171588117" MODIFIED="1509476184594" TEXT="Zustand opaque verpacken"/>
|
|
<node CREATED="1509476185182" ID="ID_613038974" MODIFIED="1509476196153" TEXT="Callback über den Baum transportieren"/>
|
|
<node CREATED="1509476197413" ID="ID_768936647" MODIFIED="1514328778025">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ha! das ist eine <b>Monade</b>!!!!!1!11!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1509481823391" FOLDED="true" ID="ID_1204466073" MODIFIED="1561827483826" TEXT="IterExplorer nutzen?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1509481841493" FOLDED="true" ID="ID_125946562" MODIFIED="1561827482909" TEXT="depthFirst">
|
|
<node CREATED="1509481848292" ID="ID_9233559" MODIFIED="1509481858671" TEXT="verwendet selber einen IterStack"/>
|
|
<node CREATED="1509481859522" ID="ID_828467130" MODIFIED="1509481866022" TEXT="packt die Quellsequenz dorthin um"/>
|
|
</node>
|
|
<node CREATED="1509481873976" FOLDED="true" ID="ID_1335669968" MODIFIED="1561827482909" TEXT="RecursiveExhaustingEvaluation">
|
|
<node CREATED="1509481895254" ID="ID_205898550" MODIFIED="1509481900897" TEXT="mit eigenem Buffer-Template"/>
|
|
<node CREATED="1509481901461" ID="ID_1119216150" MODIFIED="1509481908384" TEXT="mit eigener explorer-Funktion"/>
|
|
</node>
|
|
<node CREATED="1509481972452" FOLDED="true" ID="ID_1796930306" MODIFIED="1561827482909" TEXT="RecursiveSelfIntegration">
|
|
<node CREATED="1509481981834" ID="ID_312626846" MODIFIED="1509481990157" TEXT="muß dann eigenen Sequenz-Typ verwenden"/>
|
|
<node CREATED="1509481991033" ID="ID_321192742" MODIFIED="1509482002172" TEXT="dieser implementiert die re-Integration selber"/>
|
|
</node>
|
|
<node CREATED="1509482005743" FOLDED="true" ID="ID_156318392" MODIFIED="1561827482910" TEXT="eigenen Combinator">
|
|
<node CREATED="1509482018302" ID="ID_1911533794" MODIFIED="1509482027640" TEXT="d.h. IterExplorer selber nutzen"/>
|
|
<node CREATED="1509482028205" ID="ID_1589522162" MODIFIED="1509482039271" TEXT="die Logik steckt im eigenen Combinator"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535891975603" ID="ID_1860662881" MODIFIED="1535892401183" TEXT="neuer Anlauf: nochmal ein IterExplorer-Design">
|
|
<arrowlink COLOR="#27998e" DESTINATION="ID_137835978" ENDARROW="Default" ENDINCLINATION="-521;-801;" ID="Arrow_ID_1873000120" STARTARROW="None" STARTINCLINATION="-1866;98;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509495634766" ID="ID_422767906" MODIFIED="1561827464836" TEXT="Zusammenspiel">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1509491594115" FOLDED="true" ID="ID_214903834" MODIFIED="1561827483826" TEXT="was trägt LocationQuery bei?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509491778083" ID="ID_1393727273" MODIFIED="1509491782470" TEXT="den Ort im Baum"/>
|
|
<node CREATED="1509491783058" ID="ID_885705202" MODIFIED="1509491786782" TEXT="dort Kinder finden"/>
|
|
</node>
|
|
<node CREATED="1509495646276" FOLDED="true" ID="ID_167277646" MODIFIED="1561827483826" TEXT="was trägt der Resolver bei?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509495661042" ID="ID_653601777" MODIFIED="1509495669717" TEXT="den zu interpolierenden Pfad"/>
|
|
<node CREATED="1509495680255" ID="ID_280205397" MODIFIED="1509495708216" TEXT="die Entscheidung, einem Zweig zu folgen"/>
|
|
</node>
|
|
<node CREATED="1509500182205" FOLDED="true" ID="ID_265529571" MODIFIED="1561827483826" TEXT="wie wird die Lösung gebildet?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509500778214" FOLDED="true" ID="ID_205493443" MODIFIED="1561827482910" TEXT="immer wenn ein Zweig ausgeschöpft ist">
|
|
<node CREATED="1509500789749" ID="ID_900618811" MODIFIED="1509500797807" TEXT="keine Kind-Knoten mehr"/>
|
|
<node CREATED="1509500798284" ID="ID_1913555098" MODIFIED="1509500806342" TEXT="der leitende Pfad ist am Ende"/>
|
|
<node CREATED="1509500810530" ID="ID_429187382" MODIFIED="1509500819205" TEXT="und wir haben einen Match"/>
|
|
</node>
|
|
<node CREATED="1509500824008" ID="ID_131979876" MODIFIED="1509500843970" TEXT="dann den aktuellen Pfad von der Wurzel "abwerfen""/>
|
|
</node>
|
|
<node CREATED="1509500882017" FOLDED="true" ID="ID_1192819328" MODIFIED="1561827483826" TEXT="Problem: Backtracking">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1509500892895" ID="ID_1418393701" MODIFIED="1509500898746" TEXT="ein Problem der Repräsentation"/>
|
|
<node CREATED="1509500905589" ID="ID_583193934" MODIFIED="1509500921375" TEXT="muß zu einem früheren, partiell gebildeten Pfad zurückkehren"/>
|
|
<node CREATED="1509500998401" FOLDED="true" ID="ID_566603059" MODIFIED="1561827482910" TEXT="Pfade sind vorwärts verlinkt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1509501075699" ID="ID_41890562" MODIFIED="1509501075699">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber im Moment der Lösung brauche ich den Pfad aufwärts.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509501086314" ID="ID_1462237553" MODIFIED="1509501086314">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das heißt, wir müssen ihn bereits im Aufrufkontext bereit liegen haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509579787378" ID="ID_1598679407" MODIFIED="1509579802379" TEXT="...oder ihn aus diesem Kontext rekonstruieren können">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1509580020810" ID="ID_602529711" MODIFIED="1509580027551" TEXT="COW">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509581231027" FOLDED="true" HGAP="73" ID="ID_1779465547" MODIFIED="1561827483827" TEXT="möglicher Ablauf" VSHIFT="18">
|
|
<node CREATED="1509581241161" ID="ID_1629692107" MODIFIED="1509915202592" TEXT="UICoordResolver pullt Ergebnis(se)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#b4d1df" CREATED="1509581679727" FOLDED="true" HGAP="39" ID="ID_501629316" MODIFIED="1561827482910" STYLE="bubble" TEXT="für alle Kinder" VSHIFT="7">
|
|
<arrowlink COLOR="#00ff9c" DESTINATION="ID_1294975373" ENDARROW="Default" ENDINCLINATION="8;66;" ID="Arrow_ID_1807409316" STARTARROW="None" STARTINCLINATION="93;38;"/>
|
|
<linktarget COLOR="#acf267" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="60;-81;" ID="Arrow_ID_1837883373" SOURCE="ID_1856901364" STARTARROW="None" STARTINCLINATION="126;-77;"/>
|
|
<linktarget COLOR="#17dde7" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="98;-46;" ID="Arrow_ID_1045905988" SOURCE="ID_574087782" STARTARROW="None" STARTINCLINATION="108;-138;"/>
|
|
<linktarget COLOR="#172fd9" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="25;50;" ID="Arrow_ID_901660904" SOURCE="ID_1687957458" STARTARROW="None" STARTINCLINATION="8;-10;"/>
|
|
<node BACKGROUND_COLOR="#e1e1b6" CREATED="1509581375103" FOLDED="true" ID="ID_1294975373" MODIFIED="1561827469147" TEXT="(node, depth) -> match?">
|
|
<linktarget COLOR="#00ff9c" DESTINATION="ID_1294975373" ENDARROW="Default" ENDINCLINATION="8;66;" ID="Arrow_ID_1807409316" SOURCE="ID_501629316" STARTARROW="None" STARTINCLINATION="93;38;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509581419506" FOLDED="true" ID="ID_956022061" MODIFIED="1561827469126" TEXT="ja">
|
|
<node CREATED="1509581675560" ID="ID_17975640" MODIFIED="1514742893143" TEXT="depth+1">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e1e1b6" CREATED="1509581999829" FOLDED="true" ID="ID_195154621" MODIFIED="1525124214781" TEXT="Rekursion?">
|
|
<icon BUILTIN="full-2"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509582024610" ID="ID_1856901364" MODIFIED="1509834445909" TEXT="ja">
|
|
<arrowlink COLOR="#acf267" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="60;-81;" ID="Arrow_ID_1837883373" STARTARROW="None" STARTINCLINATION="126;-77;"/>
|
|
</node>
|
|
<node CREATED="1509582031809" FOLDED="true" ID="ID_1594605893" MODIFIED="1525124214781" TEXT="nein">
|
|
<node CREATED="1509582078939" HGAP="23" ID="ID_171156109" MODIFIED="1514742898612" TEXT="Abwurf" VSHIFT="-5">
|
|
<arrowlink COLOR="#2648cc" DESTINATION="ID_1359435447" ENDARROW="Default" ENDINCLINATION="273;37;" ID="Arrow_ID_1082519062" STARTARROW="None" STARTINCLINATION="361;48;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#b4d1df" CREATED="1509582092777" HGAP="29" ID="ID_574087782" MODIFIED="1514743247011" TEXT="Backtracking" VSHIFT="2">
|
|
<arrowlink COLOR="#17dde7" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="98;-46;" ID="Arrow_ID_1045905988" STARTARROW="None" STARTINCLINATION="108;-138;"/>
|
|
<linktarget COLOR="#0199e1" DESTINATION="ID_574087782" ENDARROW="Default" ENDINCLINATION="-11;18;" ID="Arrow_ID_514933005" SOURCE="ID_1742427454" STARTARROW="None" STARTINCLINATION="115;15;"/>
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509581428177" FOLDED="true" ID="ID_593473991" MODIFIED="1561827469126" TEXT="nein">
|
|
<node CREATED="1509582401976" ID="ID_1742427454" MODIFIED="1514743247011" TEXT="Zweig widerlegt">
|
|
<arrowlink COLOR="#0199e1" DESTINATION="ID_574087782" ENDARROW="Default" ENDINCLINATION="-11;18;" ID="Arrow_ID_514933005" STARTARROW="None" STARTINCLINATION="115;15;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509582914509" ID="ID_1359435447" MODIFIED="1509915433218" TEXT="yield">
|
|
<linktarget COLOR="#2648cc" DESTINATION="ID_1359435447" ENDARROW="Default" ENDINCLINATION="273;37;" ID="Arrow_ID_1082519062" SOURCE="ID_171156109" STARTARROW="None" STARTINCLINATION="361;48;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1509582922140" ID="ID_1687957458" MODIFIED="1510272742518">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Puffer ab Tiefe
|
|
</p>
|
|
<p>
|
|
vom Pfad initialisieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#172fd9" DESTINATION="ID_501629316" ENDARROW="Default" ENDINCLINATION="25;50;" ID="Arrow_ID_901660904" STARTARROW="None" STARTINCLINATION="8;-10;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509583164196" FOLDED="true" HGAP="45" ID="ID_1054378844" MODIFIED="1561827483827" VSHIFT="18">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
monadische Lösung
|
|
</p>
|
|
<p>
|
|
möglich?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1509583603442" FOLDED="true" ID="ID_1654046432" MODIFIED="1561827482910" TEXT="Aufgabe">
|
|
<node CREATED="1509583606241" ID="ID_1229235682" MODIFIED="1509583612828" TEXT="brauche explore-Funktion"/>
|
|
<node CREATED="1509583629367" ID="ID_911265983" MODIFIED="1509583641832" TEXT="element -> zu betrachtende Kinder"/>
|
|
<node CREATED="1509583710276" FOLDED="true" ID="ID_76982043" MODIFIED="1561827469147" TEXT="Teilaufgaben">
|
|
<node CREATED="1509583754350" ID="ID_304891578" MODIFIED="1509583763832" TEXT="element -> match?"/>
|
|
<node CREATED="1509583855993" ID="ID_1587235171" MODIFIED="1509583889120" TEXT="ja! -> mögliche Kinder"/>
|
|
</node>
|
|
<node CREATED="1509583973681" FOLDED="true" ID="ID_1318889619" MODIFIED="1561827469147" TEXT="Problem: ternäre Antwort">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1509583985008" ID="ID_396388554" MODIFIED="1509583991099" TEXT="akzeptiert"/>
|
|
<node CREATED="1509583991903" ID="ID_236836502" MODIFIED="1509583994178" TEXT="widerlegt"/>
|
|
<node CREATED="1509583994814" ID="ID_1069105045" MODIFIED="1509583998658" TEXT="unentschieden"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510266814301" FOLDED="true" ID="ID_1831665335" MODIFIED="1561827482911" TEXT="Ansatz">
|
|
<node CREATED="1510266817500" FOLDED="true" ID="ID_1438980093" MODIFIED="1561827469147" TEXT="3 Layer verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1510266845712" FOLDED="true" ID="ID_1058798631" MODIFIED="1561827469126" TEXT="depthFirstExpandable">
|
|
<node CREATED="1510340746785" ID="ID_1049791542" MODIFIED="1510340774700">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>echte</i> Expand-Funktion notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1510340942183" ID="ID_1468499222" MODIFIED="1510340946922" TEXT="tree expansion"/>
|
|
<node CREATED="1510340919370" ID="ID_1835064492" MODIFIED="1510340941074" TEXT="hidden state"/>
|
|
</node>
|
|
<node CREATED="1510267240714" FOLDED="true" ID="ID_1928917413" MODIFIED="1561827469127" TEXT="pathMatcher">
|
|
<node CREATED="1510340991536" ID="ID_551863450" MODIFIED="1510341006225" TEXT="Zustands-Tupel -> Zustands-Tupel"/>
|
|
<node CREATED="1510341122678" ID="ID_628465315" MODIFIED="1510341137973" TEXT="Mehrwert durch Abstraktion">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1510341114343" ID="ID_1967053947" MODIFIED="1510341117354" TEXT="Zustandsmaschine"/>
|
|
</node>
|
|
<node CREATED="1510267258015" FOLDED="true" ID="ID_858567040" MODIFIED="1561827469127" TEXT="solutionIter">
|
|
<node CREATED="1510341147323" ID="ID_224167359" MODIFIED="1510341162916" TEXT="Filter-Iterator"/>
|
|
<node CREATED="1510341163528" ID="ID_1640768302" MODIFIED="1510341167036" TEXT="fischt nach Lösungen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510341362957" FOLDED="true" ID="ID_1499495468" MODIFIED="1561827469147" TEXT="wirklich monadisch?">
|
|
<linktarget COLOR="#80c6b3" DESTINATION="ID_1499495468" ENDARROW="Default" ENDINCLINATION="-1812;12745;" ID="Arrow_ID_673178727" SOURCE="ID_1502143527" STARTARROW="None" STARTINCLINATION="4133;-10665;"/>
|
|
<node CREATED="1510341374332" ID="ID_483481416" MODIFIED="1511572072346" TEXT="naja...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mathematische Monaden sind viel mehr...
|
|
</p>
|
|
<p>
|
|
Im Besonderen sind es Typen höherer Ordnung,
|
|
</p>
|
|
<p>
|
|
also mehr als bloß parametrisierte Typen (Templates)!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1510341461168" ID="ID_862729714" MODIFIED="1510341472426" TEXT="Insofern Iterator == Monade"/>
|
|
<node CREATED="1510342283759" FOLDED="true" ID="ID_196604339" MODIFIED="1561827469127" TEXT="als Pipeline realisieren?">
|
|
<node CREATED="1510342309372" ID="ID_1423589544" MODIFIED="1510342448222" TEXT="M a >>= (a -> M b) >>= (b -> M c)">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1510342375691" FOLDED="true" ID="ID_433622803" MODIFIED="1525124214795" TEXT="hier wäre dann...">
|
|
<node CREATED="1510342421653" ID="ID_864357466" MODIFIED="1510342428524" TEXT="M der IterExplorer"/>
|
|
<node CREATED="1510342385970" ID="ID_1170551187" MODIFIED="1510342397060" TEXT="a eine treePositon"/>
|
|
<node CREATED="1510342397768" ID="ID_297412873" MODIFIED="1510342405283" TEXT="b das Zustands-Tupel"/>
|
|
<node CREATED="1510342405871" ID="ID_302307398" MODIFIED="1510342408770" TEXT="c eine Lösung"/>
|
|
</node>
|
|
<node CREATED="1510342662644" FOLDED="true" ID="ID_1670214510" MODIFIED="1525124214795" TEXT="geht nur wenn....">
|
|
<node CREATED="1510342668115" ID="ID_858941678" MODIFIED="1511572072407">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alles mit <i>einer</i> Form des IterExplorer machbar ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da IterExplorer einen Template-Template-Parameter nimmt,
|
|
</p>
|
|
<p>
|
|
ist er eigentlich ein Meta-Template, und es gibt diverse
|
|
</p>
|
|
<p>
|
|
Ausprägungen, die alle subtile Seiteneffekte ausnutzen....
|
|
</p>
|
|
<p>
|
|
...was nicht grade zur Verständlichkeit des Ganzen beiträgt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1510342763622" ID="ID_1851343313" MODIFIED="1510357653178">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das <i>Fortschreiten der Berechnung</i> dargestellt werden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1510357676862" FOLDED="true" ID="ID_1057287927" MODIFIED="1512926193412" TEXT="das heißt...">
|
|
<node CREATED="1510357692028" ID="ID_42511341" MODIFIED="1510357698567" TEXT="wie werden aus einem a mehrere b?"/>
|
|
<node CREATED="1510357699299" ID="ID_1428784920" MODIFIED="1510357734578" TEXT="wie kann ein b ein expandiertes a erzeugen?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510365403358" FOLDED="true" ID="ID_672047484" MODIFIED="1525124214796" TEXT="klingt machbar.....">
|
|
<node CREATED="1510365427291" FOLDED="true" ID="ID_176946796" MODIFIED="1512926193412" TEXT="RecursiveSelfIntegration verwenden?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1510365513975" ID="ID_355146506" MODIFIED="1510365524666" TEXT="Problem: keine klassische Monade"/>
|
|
<node CREATED="1510365525470" ID="ID_1084258268" MODIFIED="1510365538264" TEXT="ResultIter -> ResultIter"/>
|
|
<node CREATED="1510427098600" ID="ID_576903384" MODIFIED="1510438602569" TEXT="Layering nicht Teil des Schemas"/>
|
|
<node CREATED="1510427352926" ID="ID_805227666" MODIFIED="1510427370156">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: Layer sind <i>verkoppelt</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510365437834" FOLDED="true" ID="ID_134006075" MODIFIED="1512926193412" TEXT="Default-combinator verwenden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1510365447736" ID="ID_268132850" MODIFIED="1510365460367">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dann aber als <b>State Monad</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1510365950652" FOLDED="true" ID="ID_978128618" MODIFIED="1512926193407" TEXT="State Monad">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1510365961732" ID="ID_1589378310" MODIFIED="1510365980084" TEXT="return x = \s -> (x, s) "/>
|
|
<node CREATED="1510365961733" FOLDED="true" ID="ID_188006936" MODIFIED="1512926191735">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
m >>= f = \r -> let (x, s) = m r
|
|
</p>
|
|
<p>
|
|
                            in (f x) s
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1510366044023" ID="ID_72536689" MODIFIED="1510366073855" TEXT="Argument: ein State r"/>
|
|
<node CREATED="1510366074110" ID="ID_689602412" MODIFIED="1510366201735" TEXT="wende Basis-Monade auf r an">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1510366106215" ID="ID_1509841383" MODIFIED="1510366206135" TEXT="wende f auf den Ergebnis-Wert x an">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1510366161399" ID="ID_854251162" MODIFIED="1510366222663">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wende die resultierende State-Monade
|
|
</p>
|
|
<p>
|
|
auf den Zwischenzustand x aus (1) an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510438509930" ID="ID_895147065" MODIFIED="1510438624934" TEXT="Problem: State Monad ist Funktor, kein Iterator">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510940573235" ID="ID_953854216" MODIFIED="1510940586348" TEXT="IterExploer paßt nicht so recht">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1510446221317" HGAP="52" ID="ID_1590483406" MODIFIED="1535892751360" VSHIFT="42">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sind Monaden
|
|
</p>
|
|
<p>
|
|
wirklich hilfreich?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b26c7a" DESTINATION="ID_1955430588" ENDARROW="Default" ENDINCLINATION="-343;-748;" ID="Arrow_ID_920121069" STARTARROW="None" STARTINCLINATION="-38;43;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1510446985581" FOLDED="true" HGAP="7" ID="ID_1266495962" MODIFIED="1561827469127" VSHIFT="44">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alternatives
|
|
</p>
|
|
<p>
|
|
Ziel
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1510446995819" ID="ID_23846908" MODIFIED="1510447602718" TEXT="Baukasten-System">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1510447001691" FOLDED="true" ID="ID_139960047" MODIFIED="1525124214796" TEXT="von den Monaden">
|
|
<node CREATED="1510447022711" ID="ID_261759287" MODIFIED="1510447030010" TEXT="Idee der Pipeline"/>
|
|
<node CREATED="1510447582219" ID="ID_776956172" MODIFIED="1510447592222" TEXT="beliebige Kombinierbarkeit"/>
|
|
<node CREATED="1510447030766" ID="ID_1117150634" MODIFIED="1510447044624" TEXT="eigentliche Operation parametrisierbar"/>
|
|
</node>
|
|
<node CREATED="1510447061138" FOLDED="true" ID="ID_1016093231" MODIFIED="1525124214796" TEXT="Basis: State-Iterator">
|
|
<node CREATED="1510447071969" ID="ID_509550363" MODIFIED="1510447075852" TEXT="ist opaque"/>
|
|
<node CREATED="1510447076776" ID="ID_1106188456" MODIFIED="1510447096209" TEXT="yield -> Wert oder Marker"/>
|
|
<node CREATED="1510447097509" ID="ID_1527567894" MODIFIED="1510447108696" TEXT="iterate -> Prozeß-Schritt"/>
|
|
</node>
|
|
<node CREATED="1510447482473" FOLDED="true" ID="ID_232445241" MODIFIED="1525124214797" TEXT="Aufgaben">
|
|
<node CREATED="1510447488864" ID="ID_585404918" MODIFIED="1510447497779" TEXT="wie die "Operation" integrieren"/>
|
|
<node CREATED="1510447506901" ID="ID_1653596769" MODIFIED="1510447517655" TEXT="Unterschied Explore / Transform"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1510540265979" FOLDED="true" HGAP="17" ID="ID_1160853986" MODIFIED="1561827469147" VSHIFT="26">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Fazit:
|
|
</p>
|
|
<p>
|
|
brauche...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#406878" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-88;-61;" ID="Arrow_ID_409690433" STARTARROW="None" STARTINCLINATION="-374;6;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1510540282280" FOLDED="true" ID="ID_304955672" MODIFIED="1561827469127" STYLE="fork" TEXT="Baum-Explorer">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1510540409159" ID="ID_1790409069" MODIFIED="1512797263191" TEXT="wiederverwendbarer Baustein"/>
|
|
<node CREATED="1510540682809" FOLDED="true" ID="ID_1860662906" MODIFIED="1525124214797" TEXT="konfiguriert mit">
|
|
<node CREATED="1510540689329" ID="ID_678279547" MODIFIED="1512797263191" TEXT="expand-Funktion"/>
|
|
<node CREATED="1510540693760" ID="ID_137650742" MODIFIED="1512797263191" TEXT="transform-Funktion"/>
|
|
</node>
|
|
<node CREATED="1510540500403" FOLDED="true" ID="ID_494812399" MODIFIED="1525124214797" TEXT="expandierbar">
|
|
<node CREATED="1510540735386" ID="ID_94152805" MODIFIED="1512797263191" TEXT="zusätzliche API-Operation"/>
|
|
<node CREATED="1510540740977" ID="ID_1864011655" MODIFIED="1512797263191" TEXT="ersetzt aktuellen Knoten durch seine Kinder"/>
|
|
<node CREATED="1510939295181" ID="ID_454143909" MODIFIED="1512797263191">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das impliziert <i>grundsätzlich</i> einen <b>Stack</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510540417614" FOLDED="true" ID="ID_169601267" MODIFIED="1525124214797" TEXT="iterierbar">
|
|
<node CREATED="1510541064485" ID="ID_15321736" MODIFIED="1512797263192" TEXT="jedes Element geht durch den Transformer"/>
|
|
<node CREATED="1510541092114" ID="ID_1514360017" MODIFIED="1512797263192" TEXT="das ist die neue Einsicht">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510939495862" FOLDED="true" ID="ID_1918069733" MODIFIED="1525124214797" TEXT="Monade?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1510939532689" FOLDED="true" ID="ID_608280633" MODIFIED="1512926193412" TEXT="konventionelle Lösung">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1510939567867" ID="ID_1799788775" MODIFIED="1512797263192" TEXT="expand: S -> S"/>
|
|
<node CREATED="1510939642250" ID="ID_456598029" MODIFIED="1512797263192" TEXT="S = opaque state"/>
|
|
<node CREATED="1510939675821" ID="ID_71307720" MODIFIED="1512797263192" TEXT="eigentliche Erweiterung ist in S implementiert"/>
|
|
<node CREATED="1510939688075" ID="ID_872154531" MODIFIED="1512797263192" TEXT="expand() reicht also nur einen Aufruf weiter"/>
|
|
<node CREATED="1510939702170" ID="ID_699246805" MODIFIED="1512797263192" TEXT="Implementierung erfordert Seiteneffekt auf S"/>
|
|
<node CREATED="1510939778231" ID="ID_763925317" MODIFIED="1512797263192" TEXT="S muß auf die Verwendung im Baum-Explorer vorbereitet sein"/>
|
|
<node CREATED="1510940187687" ID="ID_349334428" MODIFIED="1512797263192" TEXT="triviale Implementierung kan sehr effizient sein"/>
|
|
</node>
|
|
<node CREATED="1510939552942" FOLDED="true" ID="ID_510344823" MODIFIED="1512926193412" TEXT="modadische Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1510939598175" ID="ID_1272498716" MODIFIED="1512797263192" TEXT="expand: S -> BaumExplorer<S>"/>
|
|
<node CREATED="1510939845662" ID="ID_581825327" MODIFIED="1512797263192" TEXT="S = opaque State"/>
|
|
<node CREATED="1510939856845" ID="ID_1492383135" MODIFIED="1512797263192" TEXT="Erweiterungs-Mechanismus im Baum-Explorer implementiert"/>
|
|
<node CREATED="1510939940275" ID="ID_767766017" MODIFIED="1512797263192">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
expand() ruft eine vorbereitete Parametrisierung
|
|
</p>
|
|
<p>
|
|
 für diesen Expand-Mechanismus auf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1510940053626" ID="ID_865181855" MODIFIED="1512797263192" TEXT="S kann Wertsemantik (aber auch Referenz-Semantik) haben"/>
|
|
<node CREATED="1510940088149" ID="ID_791410014" MODIFIED="1512797263192" TEXT="S muß nicht speziell vorbereitet sein (nur konstruierbar)"/>
|
|
<node CREATED="1510940199342" ID="ID_1423687617" MODIFIED="1512797263192" TEXT="man zahlt immer den Overhead für den Stack im Baum-Explorer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...selbst wenn man ihn für eine triviale Implementierung
|
|
</p>
|
|
<p>
|
|
eigentlich überhaupt nicht braucht.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das kann zwar zu einem gewissen Grad abgemildert werden,
|
|
</p>
|
|
<p>
|
|
indem man einen speziellen <i>Inline-Stack mit Heap-Overflow</i> nutzt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1510939517499" ID="ID_1100296394" MODIFIED="1512797263192" TEXT="das ist eine Weichenstellung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510540333481" FOLDED="true" ID="ID_1605100271" MODIFIED="1561827469127" TEXT="Rekursive Zustandsauswertung">
|
|
<node CREATED="1510541206810" ID="ID_1795866831" MODIFIED="1510541211885" TEXT="bindet Schritt-Funktion"/>
|
|
<node CREATED="1510970252162" ID="ID_1591961626" MODIFIED="1510970261786" TEXT="Layered Iterator Evaluation"/>
|
|
<node CREATED="1510970268485" ID="ID_1500401518" MODIFIED="1510970288103" TEXT="möglicherweise fest vorkonfigurierbarer Builder hierfür">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1510540399304" FOLDED="true" ID="ID_300971395" MODIFIED="1561827469127" TEXT="Filter">
|
|
<node CREATED="1510541335201" ID="ID_1717169058" MODIFIED="1510541339780" TEXT="fischt nach Lösungen"/>
|
|
<node CREATED="1513473625110" ID="ID_267118379" MODIFIED="1513473632137" TEXT="kann die Auswertung treiben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941382478" FOLDED="true" ID="ID_667413818" MODIFIED="1561827483827" TEXT="generische Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1510941425200" FOLDED="true" ID="ID_1773303405" MODIFIED="1561827482911" TEXT="Vorgabe">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1510941397907" ID="ID_993148577" MODIFIED="1512955809672" TEXT="zunächst als abstrakter Baustein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1510941406978" ID="ID_1048232110" MODIFIED="1512955812834" TEXT="später mit IterExplorer verschmelzen">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941455667" FOLDED="true" ID="ID_1945607867" MODIFIED="1561827482911" TEXT="Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511054840038" FOLDED="true" ID="ID_18464349" MODIFIED="1561827469147" TEXT="brauch ich am Ende überhaupt einen builder">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512955693493" ID="ID_622618029" MODIFIED="1512955706852">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>ich </i>brauche ihn nicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512955707636" ID="ID_398975798" MODIFIED="1512955789085" TEXT="aber bestehendes Verhalten ist gefährlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Builder-Operationen moven den bisherigen Iterator-compound weg.
|
|
</p>
|
|
<p>
|
|
<i>Ich könnte mir vorstellen, </i>daß das einen naiven User ziemlich schockiert....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Lösung wäre, das Iterator-API erst nach einem expliziten terminalen Aufruf freizuschalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1512955715434" ID="ID_1973548871" MODIFIED="1512955720444" TEXT="also: spätermal">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512278433500" FOLDED="true" ID="ID_1806674229" MODIFIED="1561827469148" TEXT="TreeExplorer fungiert als Builder">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512278445042" ID="ID_205794467" MODIFIED="1512278456012" TEXT="wird jeweils on top darübergebaut"/>
|
|
<node CREATED="1512278456672" ID="ID_488770369" MODIFIED="1512278462388" TEXT="wird in jedem Schritt gestrippt"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941463562" FOLDED="true" ID="ID_845080696" MODIFIED="1561827482911" TEXT="TreeExplorer">
|
|
<linktarget COLOR="#406878" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-88;-61;" ID="Arrow_ID_409690433" SOURCE="ID_1160853986" STARTARROW="None" STARTINCLINATION="-374;6;"/>
|
|
<linktarget COLOR="#585e9d" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-23;161;" ID="Arrow_ID_402051988" SOURCE="ID_1359727169" STARTARROW="None" STARTINCLINATION="138;6;"/>
|
|
<linktarget COLOR="#83dfc7" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-1109;3887;" ID="Arrow_ID_1645152965" SOURCE="ID_30857289" STARTARROW="None" STARTINCLINATION="2051;-176;"/>
|
|
<linktarget COLOR="#8ad3a5" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-230;134;" ID="Arrow_ID_253437970" SOURCE="ID_137835978" STARTARROW="None" STARTINCLINATION="-387;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511571446467" FOLDED="true" ID="ID_1778455053" MODIFIED="1561827469148" TEXT="expand-Operation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511227813712" FOLDED="true" ID="ID_1961708112" MODIFIED="1561827469128" TEXT="Fall-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511227821087" ID="ID_143800006" MODIFIED="1511227823932" TEXT="monadisch"/>
|
|
<node CREATED="1511227824495" ID="ID_669725928" MODIFIED="1511227836441" TEXT="Val -> Iter(Val)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511227861867" FOLDED="true" ID="ID_1021264891" MODIFIED="1561827469128" TEXT="Fall-2 ">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511227870346" ID="ID_707253800" MODIFIED="1511228200055" TEXT="verzahnte Implementierung"/>
|
|
<node CREATED="1511227975028" FOLDED="true" ID="ID_1383529442" MODIFIED="1525124214806" TEXT="Sub-Fälle">
|
|
<node CREATED="1511227902005" ID="ID_867168618" MODIFIED="1511228200056" TEXT="Core -> Iter(Val)"/>
|
|
<node CREATED="1511227917971" ID="ID_1274261467" MODIFIED="1511228200056" TEXT="Core -> Core"/>
|
|
<node CREATED="1511227925202" ID="ID_211547168" MODIFIED="1511228200056" TEXT="Iter(Val) -> Iter(Val)"/>
|
|
<node CREATED="1511227944392" ID="ID_1244265850" MODIFIED="1511228200056" TEXT="Iter(Val) -> Core"/>
|
|
</node>
|
|
<node CREATED="1511227985314" FOLDED="true" ID="ID_723642910" MODIFIED="1525124214806" TEXT="Problem">
|
|
<node CREATED="1511227994153" ID="ID_1055820971" MODIFIED="1511228200056" TEXT="nicht jede Kombi ist valide"/>
|
|
<node CREATED="1511228014599" ID="ID_817679403" MODIFIED="1511572072623" TEXT=""Zugriff auf Core" kann nicht abstrahiert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
sich zwar die Logik syntaktisch anschreiben läßt
|
|
</li>
|
|
<li>
|
|
aber beide Zweige u.U nicht auf den gleichen Typ hinauslaufen
|
|
</li>
|
|
<li>
|
|
und erst in der Anwendung dieses Ausdruckes werden die Typen gleichgestellt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1511827033449" ID="ID_1528489344" MODIFIED="1511827073310" TEXT="Lösung: Funktions-Komposition mit getemplatetem operator()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1511228184223" FOLDED="true" HGAP="26" ID="ID_1701796180" MODIFIED="1561827469128" TEXT="Vereinigung" VSHIFT="23">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1511228210268" ID="ID_268486334" MODIFIED="1511228224230" TEXT="im Fall-1 müssen wir operator* anwenden"/>
|
|
<node CREATED="1511228226946" FOLDED="true" ID="ID_1853550246" MODIFIED="1525124214806" TEXT="im Fall-2 müssen wir einen Core-Typ konstruieren">
|
|
<node CREATED="1511228291778" ID="ID_1396258052" MODIFIED="1511228302748" TEXT="und zwar einen, den die Funktion nehmen kann"/>
|
|
<node CREATED="1511228303552" ID="ID_833606136" MODIFIED="1511228313746" TEXT="Vorsicht, kann auch eine Referenz sein!">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1511228361960" ID="ID_757059750" MODIFIED="1511402807191" TEXT="wie bringt man das syntaktisch auf eine einzige Linie??">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1511402785895" FOLDED="true" ID="ID_1409331699" MODIFIED="1525124214806" TEXT="Lösungsidee: generisches Lambda">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1511402832809" ID="ID_844588469" MODIFIED="1511402843611" TEXT="wird einmal auf der initialen Quelle aufgerufen"/>
|
|
<node CREATED="1511402844151" ID="ID_504070749" MODIFIED="1511402854442" TEXT="oder dann auf einem der Sub-Iteratoren auf dem Stack"/>
|
|
<node CREATED="1511402855174" ID="ID_386377958" MODIFIED="1511402861001" TEXT="beides können unterschiedliche Typen sein"/>
|
|
<node CREATED="1511402861613" ID="ID_1536434222" MODIFIED="1511402872072" TEXT="solange der expandFunktor beide akzeptiert...."/>
|
|
</node>
|
|
<node CREATED="1511455454190" FOLDED="true" ID="ID_1384978479" MODIFIED="1525124214806" TEXT="Problem: kein generischer Expand-Functor">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1511455484027" ID="ID_548359395" MODIFIED="1511572072779" TEXT="unmittelbare Folge davon, daß wir den Typ des Expand-Funktors analysieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
_fun<FUN>::Sig scheitert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1511455502648" ID="ID_1704619802" MODIFIED="1511455566686">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist aber <i>unpraktisch</i>....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1511455513119" ID="ID_128446946" MODIFIED="1511572072789" TEXT="denn grade Iterator-Typen kennt der Benutzer typischerweise nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....also ist es gradezu natürlich,
|
|
</p>
|
|
<p>
|
|
einen Expand-Funktor als generisches Lambda zu schreiben!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1511455607914" FOLDED="true" HGAP="56" ID="ID_1866082603" MODIFIED="1512926193412" TEXT="Untersuchung" VSHIFT="39">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1511455644829" FOLDED="true" ID="ID_1545300823" MODIFIED="1512926193407" TEXT="ist generisches Labmda detektierbar?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1511482195487" ID="ID_954120351" MODIFIED="1511482198474" TEXT="jein"/>
|
|
<node CREATED="1511482200510" ID="ID_714363558" MODIFIED="1511482216359" TEXT="man kann nur einen Funktionsoperator erkennen"/>
|
|
<node CREATED="1511482216971" ID="ID_1806534330" MODIFIED="1511482240548" TEXT="nicht aber, wenn ein Solcher mehrere Overloads hat oder ein Template ist"/>
|
|
</node>
|
|
<node CREATED="1511455664043" FOLDED="true" ID="ID_1966980711" MODIFIED="1512926193407" TEXT="kann man Fallback-Mechanismus bauen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1511455698398" FOLDED="true" ID="ID_91244603" MODIFIED="1512926191747" TEXT="wenn generisch...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1511455705149" ID="ID_1094783485" MODIFIED="1511455710889" TEXT="dann versuche"/>
|
|
<node CREATED="1511455711525" ID="ID_1584168712" MODIFIED="1511455721127" TEXT="(a) mit dem Value-Type ins Argument"/>
|
|
<node CREATED="1511455721907" ID="ID_312038081" MODIFIED="1511455730558" TEXT="(b) mit dem Iterator-Typ ins Argument"/>
|
|
</node>
|
|
<node CREATED="1511482247535" FOLDED="true" ID="ID_487969118" MODIFIED="1512926191747" TEXT="geht nicht">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1511482254927" ID="ID_1687625403" MODIFIED="1511482263673" TEXT="zwar funktionieren die Positiv-Fälle"/>
|
|
<node CREATED="1511482264405" ID="ID_1003171577" MODIFIED="1511482304307">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber eine falsche Template-Instantiierung
|
|
</p>
|
|
<p>
|
|
ist ein <i>Compile</i>-Fehler, kein <i>Substitutions</i>-Fehler
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1511482367184" FOLDED="true" ID="ID_1569720883" MODIFIED="1512926193413" TEXT="bleibt nur...">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1511482374415" FOLDED="true" ID="ID_554184880" MODIFIED="1512926193408" TEXT="maximal ein Versuch">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1511482446317" ID="ID_951810826" MODIFIED="1511482457247" TEXT="entweder der Typ der Funktion ist bestimmbar"/>
|
|
<node CREATED="1511482457978" ID="ID_564239157" MODIFIED="1511482493455">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oder man fällt auf <i>eine</i> mögliche Substitution zurück
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1511482495719" ID="ID_327135583" MODIFIED="1511482510962">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und wenn die Scheitert, ist das ein <b>compile</b>-Fehler
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1511482393172" ID="ID_1538766965" MODIFIED="1511572072839" TEXT="das wäre dann: den Iterator zu verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn das ist der sinnvollste Fall für ein generisches Lambda
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1511571955951" FOLDED="true" HGAP="-20" ID="ID_189622415" MODIFIED="1561827469128" TEXT="zOMG: saukomplex" VSHIFT="13">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1511572016775" ID="ID_664087042" MODIFIED="1511572067881" TEXT="selbst beim Schreiben steig ich nicht mehr durch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und das ist alarmierend,
|
|
</p>
|
|
<p>
|
|
denn Debugging ist mindestens doppelt so schwer...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511578305427" ID="ID_1738957205" MODIFIED="1511578318339" TEXT="alle technischen Details in die Traits">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511578319810" ID="ID_1918720180" MODIFIED="1511578585730" TEXT="unterstützte Varianten dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1511578330448" ID="ID_1808038526" MODIFIED="1512955467937" TEXT="alle unterstützten Varianten im Test abdecken">
|
|
<arrowlink COLOR="#5d68b6" DESTINATION="ID_1298407683" ENDARROW="Default" ENDINCLINATION="-53;-200;" ID="Arrow_ID_1214344498" STARTARROW="None" STARTINCLINATION="-292;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511827103749" FOLDED="true" ID="ID_1699316886" MODIFIED="1561827469148" TEXT="transform-Operation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511827249561" ID="ID_794510302" MODIFIED="1511827265634" TEXT="strikt nach Dekorator-Pattern"/>
|
|
<node CREATED="1511827337686" FOLDED="true" ID="ID_1214119488" MODIFIED="1561827469128" TEXT="bestehendern TransformIter verwenden?">
|
|
<node CREATED="1511827584523" ID="ID_1921395634" MODIFIED="1511827600541" TEXT="nein: wir müssen von der Core erben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1511827606968" ID="ID_732051224" MODIFIED="1511827652784" TEXT="aber das Konzept mit dem Result-Holder wiederverwenden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1511827717353" FOLDED="true" ID="ID_244629150" MODIFIED="1561827469128" TEXT="Frage: kann man mit ADL überlagern?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1511827732399" ID="ID_1358685038" MODIFIED="1511827746408" TEXT="wenn ja: dann müßte man nur yield neu implementieren"/>
|
|
<node CREATED="1511831100013" FOLDED="true" ID="ID_446486349" MODIFIED="1525124214811" TEXT="ich denke ja...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1511831114987" ID="ID_371812401" LINK="http://en.cppreference.com/w/cpp/language/adl" MODIFIED="1511831149604" TEXT="ADL findet diverse Kandidaten"/>
|
|
<node CREATED="1511831122138" ID="ID_237063151" LINK="http://en.cppreference.com/w/cpp/language/overload_resolution" MODIFIED="1511831139496" TEXT="die Kandidaten werden geRANKt, u.A. nach Vererbung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1511831658137" FOLDED="true" ID="ID_295934398" MODIFIED="1561827469128" TEXT="Dekorator-Ansatz">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1512262147649" FOLDED="true" ID="ID_1592901896" MODIFIED="1525124214812" TEXT="Dekorator auf Core">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512262162366" ID="ID_1471773970" MODIFIED="1512262276131" TEXT="kann direkt Core -> Core verarbeiten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1511831681334" FOLDED="true" ID="ID_1182010965" MODIFIED="1512926193413" TEXT="Unterscheidung nach Parent (per Trait)">
|
|
<node CREATED="1511831718105" FOLDED="true" ID="ID_758057732" MODIFIED="1512926193408" TEXT="Parent == state-core">
|
|
<node CREATED="1511831731159" ID="ID_1581545445" MODIFIED="1511831735258" TEXT="direkt verwenden"/>
|
|
<node CREATED="1511831735870" ID="ID_461566244" MODIFIED="1511831743057" TEXT="bietet bereits die Extension points"/>
|
|
</node>
|
|
<node CREATED="1511831745237" FOLDED="true" ID="ID_1286724784" MODIFIED="1512926193408" TEXT="Parent == IterableDecorator<Core>">
|
|
<node CREATED="1511831773833" ID="ID_1367782989" MODIFIED="1511831783948" TEXT="IterableDecorator wegstrippen"/>
|
|
<node CREATED="1511831784823" ID="ID_764863277" MODIFIED="1511831794354" TEXT="Core direkt verwenden (slicing move)"/>
|
|
</node>
|
|
<node CREATED="1511831840336" FOLDED="true" ID="ID_1853594905" MODIFIED="1512926193408" TEXT="Parent == Lumiera Iterator ">
|
|
<node CREATED="1511831893369" ID="ID_1403568713" MODIFIED="1511837159071" TEXT="WrappedIteratorCore dazwischenschieben"/>
|
|
</node>
|
|
<node CREATED="1511831940346" FOLDED="true" ID="ID_441709942" MODIFIED="1512926193408" TEXT="Resultat: Parent ist stets state-core">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1512259489938" ID="ID_1357405758" MODIFIED="1512259684029" TEXT="Zweifelhalft">
|
|
<linktarget COLOR="#fe2e57" DESTINATION="ID_1357405758" ENDARROW="Default" ENDINCLINATION="1323;-81;" ID="Arrow_ID_550770884" SOURCE="ID_1503180090" STARTARROW="None" STARTINCLINATION="-1297;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512259502594" ID="ID_1761695302" MODIFIED="1512259525410" TEXT="sieht nach unnötig verkompliziertem Design aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512262200009" FOLDED="true" ID="ID_1921211925" MODIFIED="1512926193413" TEXT="führt zu unnötig komplexem Design">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512262213016" ID="ID_1547313420" MODIFIED="1512262221626" TEXT="wir haben jetzt "zwei Schienen""/>
|
|
<node CREATED="1512262222470" ID="ID_589647672" MODIFIED="1512262236880" TEXT="und es ist nicht mehr klar, was die Quelle ist"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512262251706" FOLDED="true" ID="ID_1480384220" MODIFIED="1525124214812" TEXT="Dekorator auf Iterator">
|
|
<node CREATED="1512262291085" FOLDED="true" ID="ID_1532344112" MODIFIED="1512926193413" TEXT="für jeden Layer">
|
|
<node CREATED="1512262299476" ID="ID_102544445" MODIFIED="1512262325001">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TreeExplorer per <i>slicing move</i> entfernen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512262331008" ID="ID_287760536" MODIFIED="1512262346625" TEXT="enthaltenen SrcIter dekorieren -> Core"/>
|
|
<node CREATED="1512262347637" ID="ID_1683477051" MODIFIED="1512262371854" TEXT="erneut einen TreeExplorer darüber adaptieren"/>
|
|
</node>
|
|
<node CREATED="1512262480339" FOLDED="true" ID="ID_62641165" MODIFIED="1512926193413" TEXT="Problem: Parent-Auswahl">
|
|
<node CREATED="1512262491362" ID="ID_1646804403" MODIFIED="1512262505036" TEXT="wir können beliebig verschachteln"/>
|
|
<node CREATED="1512262505760" ID="ID_534073442" MODIFIED="1512262514890" TEXT="der Trait könnte eine tiefere Schicht greifen"/>
|
|
<node CREATED="1512262516143" FOLDED="true" ID="ID_1514197178" MODIFIED="1512926193408" TEXT="Lösung">
|
|
<node CREATED="1512262521070" ID="ID_1457239407" MODIFIED="1512262528041" TEXT="geht nur in diesem limitierten Kontext"/>
|
|
<node CREATED="1512262528836" ID="ID_879672594" MODIFIED="1512262550733" TEXT="Core bekommt Vorfahrt"/>
|
|
<node CREATED="1512262584301" ID="ID_387075989" MODIFIED="1512262598534" TEXT="Folge: Alle Layer müssen neue Core produzieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511918986936" FOLDED="true" ID="ID_667088953" MODIFIED="1561827469128" TEXT="Konstrukt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511919003054" FOLDED="true" ID="ID_1728459315" MODIFIED="1525124214812" TEXT="Aufsetz-Punkt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511919032171" FOLDED="true" ID="ID_737737817" MODIFIED="1512926193413" TEXT="Problem Parent::Iterator">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511919050960" ID="ID_1621131204" MODIFIED="1512256810082" TEXT="grundsätzliches Problem jedes Iterator-Dekorators">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir haben bisher viel zu naiv angenommen,
|
|
</p>
|
|
<p>
|
|
daß der parent-Iterator immer auch ein TreeExploer ist.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dem ist nicht so, ab dem Moment, wo wir mehrere Decorator-Layer haben!!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1511920447698" ID="ID_1780310210" MODIFIED="1511920468027" TEXT="gesucht: der Iterator, von dem wir Werte beziehen"/>
|
|
<node CREATED="1512010545747" ID="ID_1907550" MODIFIED="1512010612995" TEXT="Idee: das ist genau das, was _TreeExplorerTraits leistet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512010566105" ID="ID_1750414732" MODIFIED="1512010610681" TEXT="Umbenennung: _DecoratorTraits">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512010575367" FOLDED="true" ID="ID_736035875" MODIFIED="1512926193408" TEXT="soll künftig zwei Fälle unterstützen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512010586173" ID="ID_1016627565" MODIFIED="1512010597616" TEXT="Finde parent-Iterator"/>
|
|
<node CREATED="1512010598540" FOLDED="true" ID="ID_771604715" MODIFIED="1512926191759" TEXT="Finde parent-Core">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512271542268" ID="ID_1668978885" MODIFIED="1512271546128" TEXT="war keine gute Idee"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512271554250" FOLDED="true" ID="ID_6017634" MODIFIED="1512926193408" TEXT="gelöst durch stets regelmäßigen Aufbau der Dekorator-Kette">
|
|
<node CREATED="1512271577423" ID="ID_1273633642" MODIFIED="1512271590865" TEXT="TreeExplorer wird gestrippt"/>
|
|
<node CREATED="1512271591477" ID="ID_1932230950" MODIFIED="1512271605470" TEXT="Konsequenz: unmittelbare Src == Lumiera Iterator stets">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511837060201" FOLDED="true" ID="ID_88038793" MODIFIED="1512926193413" TEXT="brauche WrappedIteratorCore">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512010365276" ID="ID_956716570" MODIFIED="1512010370631" TEXT="verpackt einen Iterator"/>
|
|
<node CREATED="1512010371291" ID="ID_563900951" MODIFIED="1512010383805" TEXT="bietet die ExtensionPoints einer State-Core"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511837027405" FOLDED="true" ID="ID_233806852" MODIFIED="1525124214812" TEXT="Argument-Detektor-Magie">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511837039180" ID="ID_1296099637" MODIFIED="1512278401909" TEXT="ganz analog zur expand-Operation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1511837047810" FOLDED="true" ID="ID_684902103" MODIFIED="1512926193414" TEXT="kann man die Traits wiederverwenden?">
|
|
<node CREATED="1512179380102" ID="ID_657845891" MODIFIED="1512179382618" TEXT="schaut gut aus"/>
|
|
<node CREATED="1512182255367" FOLDED="true" ID="ID_1818058437" MODIFIED="1512926193409" TEXT="Funktor-Argument">
|
|
<node CREATED="1512182288514" ID="ID_1838064094" MODIFIED="1512182295010" TEXT="bestehende Impl verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512182296169" ID="ID_770503153" MODIFIED="1512182333744" TEXT="muß Info aus dem Funktor gewinnen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512182308255" FOLDED="true" ID="ID_215116122" MODIFIED="1512271761209" TEXT="komme mit generischem Lambda in den Value-Zweig">
|
|
<linktarget COLOR="#a83e54" DESTINATION="ID_215116122" ENDARROW="Default" ENDINCLINATION="351;347;" ID="Arrow_ID_891457048" SOURCE="ID_23118252" STARTARROW="None" STARTINCLINATION="683;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512182336428" ID="ID_1075031476" MODIFIED="1512271631969" TEXT="WTF??">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512182366016" FOLDED="true" ID="ID_146727217" MODIFIED="1512926191761">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aufrufpunkt: <b>invokeTransformation</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
In instantiation of 'lib::{anonymous}::_ExpansionTraits<FUN, SRC>::Res lib::{anonymous}::_ExpansionTraits<FUN, SRC>::Functor::operator()(ARG&) [with ARG = long int; FUN = lib::test::IterTreeExplorer_test::verify_transformOperation()::<lambda(auto:2)>&; SRC = lib::iter_explorer::IterableDecorator<long int, lib::iter_explorer::WrappedIteratorCore<lib::TreeExplorer<lib::iter_explorer::StlRange<std::vector<long int>&> > > >; lib::{anonymous}::_ExpansionTraits<FUN, SRC>::Res = std::basic_string<char>]':
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
src/lib/iter-tree-explorer.hpp:426:50: error: no match for call to '(std::function<std::basic_string<char>(lib::iter_explorer::IterableDecorator<long int, lib::iter_explorer::WrappedIteratorCore<lib::TreeExplorer<lib::iter_explorer::StlRange<std::vector<long int>&> > > >&)>) (long int&)'
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1512182627492" FOLDED="true" ID="ID_900469807" MODIFIED="1512926191761" TEXT="ARG = long">
|
|
<node CREATED="1512182636875" ID="ID_995259969" MODIFIED="1512182643174" TEXT="muß von yield stammen"/>
|
|
<node CREATED="1512183058625" ID="ID_1212399223" MODIFIED="1512183084458" TEXT="wir stehen in Transformer<COR..."/>
|
|
<node CREATED="1512183107627" ID="ID_1096980589" MODIFIED="1512183113342" TEXT="with COR = lib::iter_explorer::WrappedIteratorCore<lib::TreeExplorer..."/>
|
|
<node CREATED="1512183054810" ID="ID_1399207561" MODIFIED="1512183133267" TEXT="typename IT::reference yield(WrappedIteratorCore const&)"/>
|
|
<node CREATED="1512183140886" ID="ID_549090759" MODIFIED="1512183150825" TEXT="IT = TreeExplorer"/>
|
|
<node CREATED="1512183151693" ID="ID_621724350" MODIFIED="1512183166319" TEXT="IT::reference == long&"/>
|
|
</node>
|
|
<node CREATED="1512182644930" FOLDED="true" ID="ID_772628629" MODIFIED="1512926191761" TEXT="was ist SRC?">
|
|
<node CREATED="1512182682149" ID="ID_1240670384" MODIFIED="1512182695423" TEXT="IterableDecorator<long, WrappedIteratorCore<...."/>
|
|
<node CREATED="1512182696579" ID="ID_1928279872" MODIFIED="1512182724615">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also IterableDecorator aufgesetzt auf die Core <i>im</i> Transformer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512182741053" FOLDED="true" ID="ID_142258086" MODIFIED="1512926191761" TEXT="Vermutung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512182747492" FOLDED="true" ID="ID_1749262679" MODIFIED="1512926191761" TEXT="SRC ist korrekt">
|
|
<node COLOR="#338800" CREATED="1512182891904" ID="ID_391517148" MODIFIED="1512182895697" TEXT="bestätigt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512182897327" ID="ID_131392784" MODIFIED="1512182918440" TEXT="_ExpansionTraits haben den vorhandenen SrcIterator genommen"/>
|
|
<node CREATED="1512182919148" ID="ID_1915639648" MODIFIED="1512182927165" TEXT="genauso wie sie sollen!">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512182752899" ID="ID_1075110241" MODIFIED="1512182940147" TEXT="wir sind im Iterator-Zweig, da generisches Lambda">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512182770497" ID="ID_301580428" MODIFIED="1512182786929" TEXT="also ist das ARG das Problem">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512183184560" FOLDED="true" ID="ID_1174618775" MODIFIED="1512926191762" TEXT="Anpassungs-Logik fehlt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512183196119" ID="ID_1543276489" MODIFIED="1512183210239" TEXT="hatte nur den Sonnenschein-Fall gecodet">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1512183218675" FOLDED="true" ID="ID_293046899" MODIFIED="1512271754033" TEXT="brauche Adapter um yield">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512183306032" ID="ID_710747972" MODIFIED="1512183310819" TEXT="normalerweise 1:1"/>
|
|
<node CREATED="1512183311551" FOLDED="true" ID="ID_783747294" MODIFIED="1512926191761" TEXT="aber je nach Funktion...">
|
|
<node CREATED="1512183380565" ID="ID_1649641461" MODIFIED="1512183407885" TEXT="auf Core heben"/>
|
|
<node CREATED="1512183408546" ID="ID_1438983384" MODIFIED="1512183418596" TEXT="oder sogar auf SrcIter heben"/>
|
|
</node>
|
|
<node CREATED="1512250716674" ID="ID_1607046573" MODIFIED="1512250752714" TEXT="nein, das würde das ganze System aufdoppeln">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512250754085" FOLDED="true" ID="ID_1665621288" MODIFIED="1512926191762" TEXT="warum überhaupt zwei Systeme?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512250771874" ID="ID_59094155" MODIFIED="1512250776853" TEXT="theoretisch könnte man...."/>
|
|
<node CREATED="1512250778322" ID="ID_52171581" MODIFIED="1512250802562" TEXT="immer wieder in einen WrappedIteratorCore einpacken"/>
|
|
<node CREATED="1512250807318" FOLDED="true" ID="ID_1268505006" MODIFIED="1512926191761" TEXT="das wären zwei Indirektionen pro Layer....">
|
|
<node CREATED="1512250866126" ID="ID_739491519" MODIFIED="1512250917460" TEXT="zwar optimierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir gehen davon aus,
|
|
</p>
|
|
<p>
|
|
daß der Optimizer solche inline-Accessor-Funktionen
|
|
</p>
|
|
<p>
|
|
ohnehin restlos wegoptimieren wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512250874420" ID="ID_407939641" MODIFIED="1512250969766" TEXT="aber zusätzlicher Code-Aufwand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar in dem Moment, wo man die Layer zusammensetzt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512250977247" FOLDED="true" ID="ID_363861413" MODIFIED="1512926191762" TEXT="letztlich egal, also automatisch Konverter einfügen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512259544994" ID="ID_702123443" MODIFIED="1512259564650" TEXT="Problem: muß auf Iterator hochkasten">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1512259576702" ID="ID_1668053426" MODIFIED="1512259606959" TEXT="Problem: Fehl-Match auf tiefer liegende Core">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1512259608498" ID="ID_1503180090" MODIFIED="1512259684029" TEXT="versautes Design">
|
|
<arrowlink COLOR="#fe2e57" DESTINATION="ID_1357405758" ENDARROW="Default" ENDINCLINATION="1323;-81;" ID="Arrow_ID_550770884" STARTARROW="None" STARTINCLINATION="-1297;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="17"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512262620480" ID="ID_967757075" MODIFIED="1512262626861" TEXT="Design aufgegeben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512183706657" FOLDED="true" ID="ID_1135345978" MODIFIED="1512271747585" TEXT="oder: dritter Zweig in ArgAcessor?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512251027232" ID="ID_755375196" MODIFIED="1512251042682" TEXT="soll also universell die Fälle adaptieren können"/>
|
|
<node CREATED="1512251172916" FOLDED="true" ID="ID_378084629" MODIFIED="1512926191762" TEXT="Entscheidung: StateCore wird bevorzugt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512251214046" ID="ID_1353274464" MODIFIED="1512251270499" TEXT="Konsequenz: alle Layer müssen StateCore sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wenn mal ein Layer "nur" Iterator wäre,
|
|
</p>
|
|
<p>
|
|
dann könnte es eine Kombination geben, die einen solchen Layer übersrpingt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512251276054" ID="ID_236669144" MODIFIED="1512251283329" TEXT="Kurzschluß Core -> Core"/>
|
|
</node>
|
|
<node CREATED="1512251305810" ID="ID_737982099" MODIFIED="1512271742802" TEXT="Iterator nur, wenn Quelle keine Core ist">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512271698231" ID="ID_1260885042" MODIFIED="1512271712854" TEXT="gelöst durch Bereinigung des Design">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512007357412" FOLDED="true" ID="ID_1659237225" MODIFIED="1512926193414" TEXT="was bedeutet ein generisches Lambda?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512010394800" ID="ID_930446802" MODIFIED="1512010402763" TEXT="analog zu expand handhaben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512010405199" ID="ID_810102842" MODIFIED="1512010424574" TEXT="Konsequenz: auch Transform kann auf Iteratoren arbeiten">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512179383254" FOLDED="true" ID="ID_1554412479" MODIFIED="1525124214812" TEXT="muß value_type from Funktor gewinnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512181398331" ID="ID_1715550480" MODIFIED="1512181407142" TEXT="value_type rebinden"/>
|
|
<node CREATED="1512181407778" ID="ID_782984508" MODIFIED="1512181425706" TEXT="generischen Helper von IterAdapter">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512181416881" ID="ID_229445720" MODIFIED="1512181423185" TEXT="verallgemeinern, rund machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512183524170" FOLDED="true" ID="ID_1697656461" MODIFIED="1512926193414" TEXT="TODO: isStringLike in meta/traits.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512183546319" ID="ID_1699019563" MODIFIED="1512183561888" TEXT="warum geht "basically" bis auf den Pointer?"/>
|
|
<node CREATED="1512183562621" ID="ID_57742709" MODIFIED="1512183571160" TEXT="logisch wäre nur bis zur Referenz"/>
|
|
<node CREATED="1512183572244" ID="ID_1399145205" MODIFIED="1512183587645" TEXT="denn: string* ist nix String-artiges!!!"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511837279715" FOLDED="true" ID="ID_1694539348" MODIFIED="1561827469148" TEXT="filter-Operation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511837285306" FOLDED="true" ID="ID_928417859" MODIFIED="1561827469128" TEXT="der Vollständigkeit halber">
|
|
<node CREATED="1511837296921" ID="ID_151298846" MODIFIED="1511837304547" TEXT="ist zwar redundant zu den Itertools"/>
|
|
<node CREATED="1511837305410" ID="ID_1979322634" MODIFIED="1511837324464" TEXT="treeExplorer könnte Itertools ablösen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511837329140" FOLDED="true" ID="ID_1963360740" MODIFIED="1561827469129" TEXT="billige Implementierung nach Schema-F">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511837338643" ID="ID_1734683995" MODIFIED="1511837344590" TEXT="bestehende Dekorator-Technik"/>
|
|
<node CREATED="1511837345226" ID="ID_991593174" MODIFIED="1511837351797" TEXT="bestehende Funktor-Argument-Traits"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512523892775" FOLDED="true" ID="ID_673112014" MODIFIED="1561827469129" TEXT="Knackpunkt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512523897422" ID="ID_1007287631" MODIFIED="1512606862773" TEXT="pullFilter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512523905005" ID="ID_1286045611" MODIFIED="1512523921543" TEXT="wie "ausgewertet" merken?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1512606810364" FOLDED="true" ID="ID_1956085441" MODIFIED="1525124214814" STYLE="fork" TEXT="garnicht">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512606816571" ID="ID_1603234787" MODIFIED="1512606853200" TEXT="mit INVARIANTE arbeiten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512606823682" ID="ID_1935971404" MODIFIED="1512606853200" TEXT="erfordert vorauseilendes Pullen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514747001446" FOLDED="true" ID="ID_127783087" MODIFIED="1561827469148" TEXT="scheduled-expand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514747011989" ID="ID_108671176" MODIFIED="1514827156021" TEXT="neuer Layer">
|
|
<linktarget COLOR="#455b75" DESTINATION="ID_108671176" ENDARROW="Default" ENDINCLINATION="-973;135;" ID="Arrow_ID_1758556486" SOURCE="ID_836777766" STARTARROW="None" STARTINCLINATION="959;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514747015924" ID="ID_174806510" MODIFIED="1514827157932" TEXT="bool-flag">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514747019740" ID="ID_1271277454" MODIFIED="1514827160424" TEXT="klinkt sich in iterNext ein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514747033674" FOLDED="true" ID="ID_690243302" MODIFIED="1561827469129" TEXT="auf API herausführen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1514827186488" ID="ID_43343693" MODIFIED="1514827189500" TEXT="nicht notwendig"/>
|
|
<node CREATED="1514827202646" ID="ID_981896608" MODIFIED="1514827218316" TEXT="hijacked the existing expandChildren()">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363846804" FOLDED="true" ID="ID_1346062807" MODIFIED="1561827469148" TEXT="auto-expand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512844658352" ID="ID_1411659026" MODIFIED="1512844688077" TEXT="einfache Ausprägung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nur was billig ist,
|
|
</p>
|
|
<p>
|
|
denn im Moment brauchen wir das überhaupt nicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512844696922" FOLDED="true" ID="ID_396632754" MODIFIED="1561827469129" TEXT="zusätzlicher Dekorator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...setzt eigentliche Expand-Operation darunter voraus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512861383695" ID="ID_837026008" MODIFIED="1512861394833" TEXT="setzt direkt auf drunterliegender State Core auf"/>
|
|
<node CREATED="1512861401133" ID="ID_930964397" MODIFIED="1512861421774" TEXT="ersetzt nur eine der State-Core-Operationen"/>
|
|
<node CREATED="1512861424976" ID="ID_1203553918" MODIFIED="1512861431277" TEXT="sehr einfach, da Typ gleich bleibt"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512844727150" FOLDED="true" ID="ID_706634236" MODIFIED="1561827469129" TEXT="expandAll">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512844742788" ID="ID_1270260953" MODIFIED="1512844748479" TEXT="expandChildren verzögert"/>
|
|
<node CREATED="1512844749235" ID="ID_1344028360" MODIFIED="1512844759661" TEXT="ausgelöst durch Iteration"/>
|
|
<node CREATED="1512861437832" ID="ID_922141164" MODIFIED="1512861464189" TEXT="iterate() durch expandChildren() ersetzt">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512844733549" FOLDED="true" ID="ID_1055588501" MODIFIED="1561827469129" TEXT="expandLeaf">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512844769176" ID="ID_1306087014" MODIFIED="1512844774891" TEXT="expandChildren eager"/>
|
|
<node CREATED="1512844775893" ID="ID_781402390" MODIFIED="1512844784866" TEXT="sofort erstes Kind liefern"/>
|
|
<node CREATED="1512844785526" ID="ID_244222856" MODIFIED="1512844788897" TEXT="rekursiv"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512872529062" FOLDED="true" ID="ID_1993110543" MODIFIED="1525124214817" TEXT="geht nicht einfach">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1512872546187" FOLDED="true" ID="ID_633024773" MODIFIED="1512926193414" TEXT="Problem: Blatt erkennen">
|
|
<node CREATED="1512872574000" ID="ID_262264527" MODIFIED="1512872587090" TEXT="müßte auf dem letzten Ergebnis stehen bleiben"/>
|
|
<node CREATED="1512872560761" ID="ID_1013659640" MODIFIED="1512872573339" TEXT="expandChildren() geht einfach weiter"/>
|
|
</node>
|
|
<node CREATED="1512872618801" FOLDED="true" ID="ID_1769639916" MODIFIED="1512926193414" TEXT="nur in Expander selber implementierbar">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512872646574" ID="ID_419478495" MODIFIED="1512872658944" TEXT="eager feed"/>
|
|
<node CREATED="1512872676162" ID="ID_1452543628" MODIFIED="1512872683205" TEXT="sofort weiter expanden"/>
|
|
<node CREATED="1512872684337" ID="ID_90684575" MODIFIED="1512872695451" TEXT="aber am Ende nicht weiterschalten"/>
|
|
</node>
|
|
<node CREATED="1512875104589" FOLDED="true" ID="ID_477086316" MODIFIED="1512926193414" TEXT="Frage: sinnvoll?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1512875141521" ID="ID_152225336" MODIFIED="1512875149513" TEXT="versuchshalber mal eingebaut">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1512875161638" ID="ID_681111567" MODIFIED="1512875181807" TEXT="ist es die zusätzliche Komplexität wert?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512951786574" FOLDED="true" ID="ID_1699122692" MODIFIED="1525124214817" TEXT="erfordert Umbau des Expanders">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1512951797493" ID="ID_1560754078" MODIFIED="1512951806384" TEXT="brauche verschiedene Auswertungs-Strategien"/>
|
|
<node CREATED="1512951807371" ID="ID_1239289160" MODIFIED="1512951840907" TEXT="muß für diesen Fall selbständig terminieren"/>
|
|
<node CREATED="1512951841703" ID="ID_815720383" MODIFIED="1512951903322" TEXT=""komplett entfaltet" wird zur Invariante">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...also Programmierung analog zum Filter
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
sofort aus dem Konstruktor heraus die Invariante etablieren
|
|
</li>
|
|
<li>
|
|
nach jedem Iterations-Schritt die Invariante erneut wiederherstellen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512951913398" FOLDED="true" ID="ID_488089119" MODIFIED="1525124214817" TEXT="Komplexität im Moment nicht gerechtfertigt">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512951939794" ID="ID_516260277" MODIFIED="1512951952752" TEXT="Monaden sind gefährlich">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1512951955616" ID="ID_529939230" MODIFIED="1512951965123" TEXT="sie verleiten zu Glasperlen-Spielen"/>
|
|
<node CREATED="1512951978101" ID="ID_489027143" MODIFIED="1512952012416" TEXT="Leitlinie für gutes Design">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Natur der Dinge folgen,
|
|
</p>
|
|
<p>
|
|
nicht den technischen Möglichkeiten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363286920" FOLDED="true" ID="ID_1420123769" MODIFIED="1561827469149" TEXT="Zusammenspiel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512844805995" FOLDED="true" ID="ID_927486947" MODIFIED="1561827469129" TEXT="single-val">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512844821609" ID="ID_478047650" MODIFIED="1512844824644" TEXT="man könnte...."/>
|
|
<node CREATED="1512844825280" ID="ID_1599364674" MODIFIED="1512844833243" TEXT="einzelne Werte in einen Iterator "heben""/>
|
|
<node CREATED="1512844833952" ID="ID_1979934919" MODIFIED="1512844840138" TEXT="sinnvoll nur in der Expand-Funktion"/>
|
|
<node CREATED="1512951745988" ID="ID_1788253058" MODIFIED="1512951758010" TEXT="vorerst nicht weiterverfolgt">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363297486" FOLDED="true" ID="ID_531127457" MODIFIED="1561827469129" TEXT="re-evaluate">
|
|
<linktarget COLOR="#5a92a2" DESTINATION="ID_531127457" ENDARROW="Default" ENDINCLINATION="385;167;" ID="Arrow_ID_556443427" SOURCE="ID_579206895" STARTARROW="None" STARTINCLINATION="844;55;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1512363369036" FOLDED="true" ID="ID_134602126" MODIFIED="1525124214820" TEXT="Problem Quell-Änderung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1512363380411" ID="ID_1008917631" MODIFIED="1512363473668" TEXT="expandChildren ändert aktuellen Gehalt der Quelle">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363397897" ID="ID_1178182932" MODIFIED="1512521936459" TEXT="aber downstream reagiert (bisher) nur auf iterate()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512363421797" ID="ID_1732504592" MODIFIED="1512521966101" TEXT="Folge: geCacheter Wert aus Transformer überdeckt">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512363518944" FOLDED="true" HGAP="38" ID="ID_1189860266" MODIFIED="1525124214820" TEXT="Lösungsidee" VSHIFT="11">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512363525815" ID="ID_108313040" MODIFIED="1512363819912" TEXT="Hook, auf den alle reagieren">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1512439571337" FOLDED="true" ID="ID_1930899435" MODIFIED="1512926193414" TEXT="Analyse">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1512363586327" FOLDED="true" ID="ID_594917391" MODIFIED="1512926193409" TEXT="TreeExplorer wird Update-Manager">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512439586771" ID="ID_1378758194" MODIFIED="1512439588983" TEXT="geht nicht"/>
|
|
<node CREATED="1512439589594" ID="ID_1211811605" MODIFIED="1512439628493" TEXT="Transformer rufen sich wechselseitig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und dann könnten diese Transformer in der Kette
|
|
</p>
|
|
<p>
|
|
nicht mehr die expandChildren aufrufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512439636532" FOLDED="true" ID="ID_443920458" MODIFIED="1512926193409" TEXT="refresh()-Call im internen API">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512439680078" ID="ID_795639412" MODIFIED="1512439682641" TEXT="geht nicht"/>
|
|
<node CREATED="1512439683710" ID="ID_82602719" MODIFIED="1512439807833" TEXT="ohne VTable können wir niemals von Parent -> Subklasse aufrufen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, es ist nicht möglich,
|
|
</p>
|
|
<p>
|
|
daß ein Layer irgendwo in der Mitte einen solchen generischen Hook aufruft.
|
|
</p>
|
|
<p>
|
|
Es sei denn, man speichert einen Funktion-Pointer in der Basis,
|
|
</p>
|
|
<p>
|
|
oder nimmt eben gleich eine virtuelle Funktion.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das ist aber hier aus grundsätzlichen Überlegungen heraus keine Option
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512439832865" FOLDED="true" ID="ID_1782781235" MODIFIED="1512926193409" TEXT="anderes Iterator-API">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512439845112" ID="ID_751119405" MODIFIED="1512439849499" TEXT="geht nicht"/>
|
|
<node CREATED="1512439850087" ID="ID_1018141727" MODIFIED="1512440143615">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das IterStateWrapper-API ist <i>optimal</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unter der Annahme, daß wir beim <b>Lumiera Forward Iterator</b> - Konzept bleiben
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
-- das heißt, beliebig oft yield, und Iterations-Ende per bool()-Test
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Unter dieser Annahme kommt yield stets vor iterNext (wenn überhaupt).
|
|
</p>
|
|
<p>
|
|
Und yield muß (a) einen Status liefern, (b) einen Wert liefern.
|
|
</p>
|
|
<p>
|
|
Einziger Ausweg wäre, wie das IterAdapter macht, einen Pointer rauszugeben.
|
|
</p>
|
|
<p>
|
|
Das ist eigentlich keine gute Lösung, weil die Implementierung dann sehr tricky wird.
|
|
</p>
|
|
<p>
|
|
Siehe IterAdapter als abstoßendes Beispiel.
|
|
</p>
|
|
<p>
|
|
Und als weitere Alternative bleibt nur die Einführung von State, und das bedeutet,
|
|
</p>
|
|
<p>
|
|
sich im Iterator oder in der Implementierung irgendwo noch eine zusätzliche bool-Flag zu speichern.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512440148015" FOLDED="true" ID="ID_1475512070" MODIFIED="1512926193409" TEXT="Einzige Lösung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512440158486" ID="ID_1167307993" MODIFIED="1512440175103" TEXT="alle Layer, die darauf angewiesen sind...."/>
|
|
<node CREATED="1512440175931" ID="ID_808598503" MODIFIED="1512440193040">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
implementieren ebenfalls <b>expandChildren</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512440216070" FOLDED="true" ID="ID_1808232294" MODIFIED="1525124214820" TEXT="Konsequenz der Analyse">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512440223221" ID="ID_741091948" MODIFIED="1512512823480" TEXT="warum verwenden wir überhaupt ADL-Funktionen??">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512440238859" ID="ID_1975957673" MODIFIED="1512440262159" TEXT="wir brauchen hier gar keinen "Extension Point"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ganz anders als bei IterAdapter, wo das Sinn macht...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512440263551" ID="ID_1524108340" MODIFIED="1512440285896" TEXT="Dagegen könnte die "state core" sehr wohl genau dieses API exponieren."/>
|
|
<node CREATED="1512440286772" FOLDED="true" ID="ID_535994508" MODIFIED="1512926193414" TEXT="wir brauchen deshalb nicht gleich ein Interface einführen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512440307185" ID="ID_1513737160" MODIFIED="1512440431319" TEXT="weil das doch nicht gecheckt werden kann">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ohne daß die Funktionen auch virtuell sind,
|
|
</p>
|
|
<p>
|
|
können wir nicht sicherstellen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
daß die hereingereichte Implementierung die Funktionen überschreibt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512440341573" ID="ID_1804763032" MODIFIED="1512440348845" TEXT="wir können bis 2020 warten...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1512440360194" ID="ID_1554793680" MODIFIED="1512440375486" TEXT="es ist nämlich ein Concept"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512516448421" ID="ID_980580862" MODIFIED="1512516469297" TEXT="Umstellen aller bestehenden IterstateWrapper">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512516493271" FOLDED="true" HGAP="14" ID="ID_1713522306" MODIFIED="1525124214820" TEXT="Implementierung" VSHIFT="7">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512516499478" ID="ID_1331925282" MODIFIED="1512516507112" TEXT="führe Base-Layer ein"/>
|
|
<node CREATED="1512516508341" ID="ID_1894692287" MODIFIED="1512516517207" TEXT="dieser konsumiert die nach unten durchtereichten Aufrufe"/>
|
|
<node CREATED="1512516517915" ID="ID_1224748245" MODIFIED="1512516534101" TEXT="einzelne Layer könne bei Bedarf ebenfalls diese Ketten-Aufrufe implementieren"/>
|
|
<node CREATED="1512516534761" FOLDED="true" ID="ID_111530510" MODIFIED="1512926193414" TEXT="speziell expandChildren()">
|
|
<node CREATED="1512516543648" ID="ID_1021495966" MODIFIED="1512516558578" TEXT="transformer muß daraufhin seinen Cache wegwerfen"/>
|
|
<node CREATED="1512516567076" ID="ID_647647031" MODIFIED="1512516587342" TEXT="filter muß daraufhin erneut filter-pull ausführen"/>
|
|
</node>
|
|
<node CREATED="1512516613614" FOLDED="true" ID="ID_1415224184" MODIFIED="1512926193415">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konzept funktioniert nicht
|
|
</p>
|
|
<p>
|
|
aus processing-Function
|
|
</p>
|
|
<p>
|
|
innen heraus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1512516629180" ID="ID_1157813472" MODIFIED="1512516672998" TEXT="oh wie traurig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
will sagen, das ist ja auch eine durchgeknallte Idee....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1512516682701" ID="ID_1471867999" MODIFIED="1512516706422">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn eine Funktion <i>in</i> einem Layer expanded
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512516708649" ID="ID_474656011" MODIFIED="1512516797884" TEXT="dann muß sie sich zwischen Vater oder 1.Kind entscheiden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h, entweder man gibt aus dem Functor das zurück,
|
|
</p>
|
|
<p>
|
|
was <i>vor</i> dem expand anstand (=der Vater), oder man verwirft diesen
|
|
</p>
|
|
<p>
|
|
und liefert das, was nach dem expand erscheind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512516799653" ID="ID_589615050" MODIFIED="1512516811504" TEXT="nicht als Fehler bewertet">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1512516814507" ID="ID_347481974" MODIFIED="1512516819130" TEXT="eigentlich logisch">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512794157617" FOLDED="true" ID="ID_1639627950" MODIFIED="1512926193415" TEXT="Problem mit IterSource">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1512794166904" ID="ID_614780435" LINK="http://issues.lumiera.org/ticket/1125" MODIFIED="1512794180867" TEXT="Design-Mismatch">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1512794183629" ID="ID_783686672" MODIFIED="1512794297194" TEXT="inzwischen ein Workaround">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
asIterSource() verwendet ein eigenes Interface, um diesen call an die Implementierung durchzureichen
|
|
</li>
|
|
<li>
|
|
in dieses Interface habe ich nun einen Rückgabewert eingebaut
|
|
</li>
|
|
<li>
|
|
damit kann ich das IterSource-Front-End refreshen
|
|
</li>
|
|
<li>
|
|
trotzdem hässlich...
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513293471929" FOLDED="true" ID="ID_1115016372" MODIFIED="1561827469130" TEXT="chained expansion">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513293488863" FOLDED="true" ID="ID_263549307" MODIFIED="1525124214820" TEXT="logisches Problem mit layered expansion">
|
|
<linktarget COLOR="#9c5265" DESTINATION="ID_263549307" ENDARROW="Default" ENDINCLINATION="189;145;" ID="Arrow_ID_1920033917" SOURCE="ID_1013175212" STARTARROW="None" STARTINCLINATION="1219;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1513293497774" ID="ID_115807287" MODIFIED="1513293568808" TEXT="der unterste Expander nivelliert die Baumstruktur"/>
|
|
<node CREATED="1513293570748" ID="ID_34081800" MODIFIED="1513293626048" TEXT="darüber gesetzte Expander bekommen das Schließen des nested scope nicht mit"/>
|
|
<node CREATED="1513293655896" ID="ID_1685869664" MODIFIED="1513293665067" TEXT="dies konterkariert das Bestreben nach Abstraktion"/>
|
|
</node>
|
|
<node CREATED="1513293768322" FOLDED="true" ID="ID_1803494848" MODIFIED="1525124214820" TEXT="Idee: slave Expander">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513293775257" ID="ID_1165347300" MODIFIED="1513293781468" TEXT="registriert sich als Listener"/>
|
|
<node CREATED="1513293782224" ID="ID_1860640469" MODIFIED="1513293845843" TEXT="geht mit expand / backtrack mit"/>
|
|
<node CREATED="1513293889809" FOLDED="true" ID="ID_277229668" MODIFIED="1525124214820" TEXT="Wirkung unklar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513293901848" FOLDED="true" ID="ID_1292422466" MODIFIED="1525124214820" TEXT="Modell-1">
|
|
<node CREATED="1513293916558" ID="ID_1801870591" MODIFIED="1513293922177" TEXT="hat selber einen Stack"/>
|
|
<node CREATED="1513293941227" ID="ID_1085854477" MODIFIED="1513293947030" TEXT="erzeugt kopierten Zustand"/>
|
|
</node>
|
|
<node CREATED="1513293910591" FOLDED="true" ID="ID_308120385" MODIFIED="1525124214820" TEXT="Modell-2">
|
|
<node CREATED="1513293959848" ID="ID_227867197" MODIFIED="1513293968451" TEXT="reine Callbacks"/>
|
|
<node CREATED="1513293996403" ID="ID_770475649" MODIFIED="1513294007637" TEXT="2.Callback zum Schließen notwendig"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513395781003" ID="ID_1245121355" MODIFIED="1513395835329" TEXT="Problem: wie anschließen?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
an welcher Stelle wird diese Mechanik
|
|
</p>
|
|
<p>
|
|
an einen bestehenden Iterator angeschlossen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5f7b87" DESTINATION="ID_618831184" ENDARROW="Default" ENDINCLINATION="0;-100;" ID="Arrow_ID_1648666133" STARTARROW="None" STARTINCLINATION="-110;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513395693887" FOLDED="true" ID="ID_618831184" MODIFIED="1525124214820" TEXT="Design">
|
|
<linktarget COLOR="#5f7b87" DESTINATION="ID_618831184" ENDARROW="Default" ENDINCLINATION="0;-100;" ID="Arrow_ID_1648666133" SOURCE="ID_1245121355" STARTARROW="None" STARTINCLINATION="-110;0;"/>
|
|
<node CREATED="1513395706469" ID="ID_708077102" MODIFIED="1513395716207" TEXT="expliziter Chain-Zustand"/>
|
|
<node CREATED="1513395719139" ID="ID_1788966028" MODIFIED="1513395732164" TEXT="wird aus dem expandable-Iter erzeugt"/>
|
|
<node CREATED="1513395734449" ID="ID_1906327703" MODIFIED="1513395755674" TEXT="entfaltet sich per Stack mit Backtracking"/>
|
|
<node CREATED="1513395756646" ID="ID_1845114720" MODIFIED="1513395771104" TEXT="Entfaltungs-Funktor"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513294052460" FOLDED="true" ID="ID_803702364" MODIFIED="1525124214820" TEXT="Technik">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1513294056627" ID="ID_1384622700" MODIFIED="1513294063006" TEXT="Listener-Interface"/>
|
|
<node CREATED="1513294065442" ID="ID_1460481832" MODIFIED="1513294078644" TEXT="Listener als Decorator-chain"/>
|
|
<node CREATED="1513294087167" ID="ID_936833682" MODIFIED="1513294097217" TEXT="BaseAdapter wird Informations-Hub"/>
|
|
<node CREATED="1513395621816" FOLDED="true" ID="ID_1622086178" MODIFIED="1525124214820" TEXT="Problem: virtuelle Calls">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513395629375" ID="ID_698225511" MODIFIED="1513395640418" TEXT="muß nun "downstream" aufrufen"/>
|
|
<node CREATED="1513395641293" ID="ID_1382186294" MODIFIED="1513395660295" TEXT="bedingt Funktor oder VTable"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513395667562" ID="ID_1022574173" MODIFIED="1513395685159" TEXT="widerspricht bisherigen Design-Zielen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1513395862384" FOLDED="true" HGAP="-59" ID="ID_992596886" MODIFIED="1525124214821" TEXT="vorerst nicht weiter verfolgt" VSHIFT="4">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513395903962" ID="ID_1252615834" MODIFIED="1513395908990" TEXT="relativ komplex"/>
|
|
<node CREATED="1513395909914" ID="ID_866089441" MODIFIED="1513395921284" TEXT="Notwendigkeit nicht klar"/>
|
|
<node CREATED="1513395922513" ID="ID_1683537911" MODIFIED="1513396040896" TEXT="könnte aber sehr sinnvoll werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Stichwort HierarchyOrientationIndicator
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
...will sagen, bin nun schon mehrfach in dieses Problem gelaufen,
|
|
</p>
|
|
<p>
|
|
nachdem ich dachte, alles so schön gelöst zu haben.
|
|
</p>
|
|
<p>
|
|
Das Problem ist, daß eben auch der <i>Konsument</i> irgendwie
|
|
</p>
|
|
<p>
|
|
von den verschachtelten Strukturen mit gesteuert wird.
|
|
</p>
|
|
<p>
|
|
Das Ergebnis ist eben nicht rein linear.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513395931727" ID="ID_1852380231" MODIFIED="1513395937842" TEXT="erst mal Erfahrungen sammeln"/>
|
|
<node CREATED="1513395939502" FOLDED="true" ID="ID_1752199055" MODIFIED="1525124214820" TEXT="und direkt die Baum-Tiefe durchgeben">
|
|
<linktarget COLOR="#75c4c1" DESTINATION="ID_1752199055" ENDARROW="Default" ENDINCLINATION="653;643;" ID="Arrow_ID_1536391130" SOURCE="ID_1466307579" STARTARROW="None" STARTINCLINATION="1299;33;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513396293343" ID="ID_861758487" MODIFIED="1513396293343">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist nämlich der triviale Workaround
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513396299238" ID="ID_1740583889" MODIFIED="1513396343855" TEXT="noch besser: diese auf das ChildExpandableSource-Interface legen!">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1513396353871" ID="ID_1928833267" MODIFIED="1513396385476" TEXT="das könnte tatsächlich eine echte pragmatische Alternative sein!">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513447925593" FOLDED="true" ID="ID_1239682661" MODIFIED="1561827469130" TEXT="expansion depth">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513447947870" ID="ID_328146397" MODIFIED="1513448183232" TEXT="nach außen zugänglich machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513447956069" FOLDED="true" ID="ID_1345517957" MODIFIED="1525124214821" TEXT="Problem: muß dafür korrekt sein">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513447967084" ID="ID_476332936" MODIFIED="1513447978718" TEXT="d.h. muß die logische Tiefe widerspiegeln"/>
|
|
<node CREATED="1513447979450" ID="ID_224439756" MODIFIED="1513448250249" TEXT="...auch wenn der Vater bereits erschöpft ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir hatten bisher eine auto-Aufräum-Routine in iterNext(),
|
|
</p>
|
|
<p>
|
|
welche dazu führt, daß ein erschöpfter Vater sofort weggeräumt wird,
|
|
</p>
|
|
<p>
|
|
noch bevor wir dazu kommen, die Kinder zu pushen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513448002247" FOLDED="true" ID="ID_804459643" MODIFIED="1525124214821" TEXT="Lösung">
|
|
<linktarget COLOR="#63b5aa" DESTINATION="ID_804459643" ENDARROW="Default" ENDINCLINATION="456;372;" ID="Arrow_ID_1606709369" SOURCE="ID_1181955496" STARTARROW="None" STARTINCLINATION="1446;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513448017406" ID="ID_753765398" MODIFIED="1513448275095" TEXT="iterNext aufspalten"/>
|
|
<node CREATED="1513448019398" ID="ID_1143482463" MODIFIED="1513448026224" TEXT="Invariante explizit machen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513990803915" FOLDED="true" ID="ID_292438102" MODIFIED="1561827469130" TEXT="IterSource-Integration">
|
|
<linktarget COLOR="#659fa4" DESTINATION="ID_292438102" ENDARROW="Default" ENDINCLINATION="853;414;" ID="Arrow_ID_1802135668" SOURCE="ID_1529167083" STARTARROW="None" STARTINCLINATION="674;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513990840253" ID="ID_923982542" MODIFIED="1514050246345" TEXT="wrapper und Iterator bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513990851580" ID="ID_1445466432" MODIFIED="1514081134408" TEXT="Traits erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513990858787" ID="ID_1444097417" MODIFIED="1514081138141" TEXT="Funktor erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511837384749" FOLDED="true" ID="ID_274979743" MODIFIED="1561827469149" TEXT="asIterSource">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512621242778" FOLDED="true" ID="ID_695969017" MODIFIED="1561827469130" TEXT="Eigenschaften">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1511837396075" ID="ID_1916743569" MODIFIED="1511837401078" TEXT="abschließender Dekorator"/>
|
|
<node CREATED="1511837401738" ID="ID_289320579" MODIFIED="1511837414204" TEXT="verpackt hinter OO-Interface mit virtuellen Funktionen"/>
|
|
<node CREATED="1511837421967" ID="ID_906113750" MODIFIED="1511837433914" TEXT="automatische Heap-Storage"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512621260992" FOLDED="true" ID="ID_611871784" MODIFIED="1561827469130" TEXT="erweitertes Interface">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#990000" CREATED="1512621268527" FOLDED="true" ID="ID_1388034155" MODIFIED="1525124214825" TEXT="wie bauen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512711450864" ID="ID_1595268563" MODIFIED="1512711455248" TEXT="sollte simpel sein"/>
|
|
<node CREATED="1512711430770" ID="ID_217126119" MODIFIED="1512711446628" TEXT="mit builder-Funktion die Baseclass initialisieren"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1512621274166" FOLDED="true" ID="ID_1452751365" MODIFIED="1525124214825" TEXT="wie expand() an die Quelle weitergeben?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512711382889" ID="ID_1913647489" MODIFIED="1512711393299" TEXT="muß virtuelle methode sein"/>
|
|
<node CREATED="1512711396279" ID="ID_633403108" MODIFIED="1512769358637" TEXT="also: muß IterSource erweitern">
|
|
<arrowlink COLOR="#b92b64" DESTINATION="ID_1665958887" ENDARROW="Default" ENDINCLINATION="65;-99;" ID="Arrow_ID_1257583135" STARTARROW="None" STARTINCLINATION="-371;-34;"/>
|
|
</node>
|
|
<node CREATED="1512711404526" ID="ID_17184885" MODIFIED="1512711414688" TEXT="IterSource steckt im shared_ptr"/>
|
|
<node CREATED="1512711415324" ID="ID_1951957730" MODIFIED="1512711423975" TEXT="also muß Front-End einen downcast machen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512711462926" FOLDED="true" ID="ID_1665958887" MODIFIED="1525124214825" TEXT="IterSource erweitern">
|
|
<linktarget COLOR="#b92b64" DESTINATION="ID_1665958887" ENDARROW="Default" ENDINCLINATION="65;-99;" ID="Arrow_ID_1257583135" SOURCE="ID_633403108" STARTARROW="None" STARTINCLINATION="-371;-34;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#b60303" CREATED="1512711475196" HGAP="15" ID="ID_899953833" MODIFIED="1512769566817" TEXT="Diamond of Death ?!!" VSHIFT="23">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512711573727" FOLDED="true" ID="ID_1346721743" MODIFIED="1512926193415" TEXT="TODO: virtuelle inheritance nachlesen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512769100530" ID="ID_547968053" MODIFIED="1512769116100" TEXT="vitual muß direkt unter der Basis erfolgen"/>
|
|
<node CREATED="1512769116952" ID="ID_1359676759" MODIFIED="1512769124770" TEXT="virtual muß dort in allen Zweigen verwendet werden"/>
|
|
<node CREATED="1512769133350" ID="ID_609049064" MODIFIED="1512769142944" TEXT="andernfalles bekommen wir mehrere Sub-Objekte der Basisklasse"/>
|
|
</node>
|
|
<node CREATED="1512711613841" FOLDED="true" ID="ID_1594826715" MODIFIED="1512926193415" STYLE="fork" TEXT="Kosten? zusätzlicher VTable-Pointer?">
|
|
<node CREATED="1512711638574" ID="ID_1769096857" MODIFIED="1512769458120" TEXT="könnte verschmerzbar sein">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1512769160218" ID="ID_155388893" MODIFIED="1512769462006" TEXT="Kosten kommen vom Memory-Layout">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1512769179503" ID="ID_1053011981" MODIFIED="1512769198300">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>jeder</i> Zugriff auf ein Sub-Objekt muß durch eine VTable
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512769199597" ID="ID_1928524017" MODIFIED="1512769227486">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Stichwort: <b>virtual base offset</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#5229a2" CREATED="1512769231648" ID="ID_925551162" LINK="http://web.archive.org/web/20160413064252/http://www.phpcompiler.org/articles/virtualinheritance.html" MODIFIED="1512769289609" TEXT="Beschreibung der GCC-Implementierung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512711586005" FOLDED="true" ID="ID_652398650" MODIFIED="1512926193415" TEXT="vielleicht kein Problem, da wir explizit casten">
|
|
<node CREATED="1512769376605" ID="ID_1401491527" MODIFIED="1512769512216" TEXT="ja, workaround">
|
|
<arrowlink COLOR="#7c89a1" DESTINATION="ID_813779439" ENDARROW="Default" ENDINCLINATION="178;-25;" ID="Arrow_ID_1765195063" STARTARROW="None" STARTINCLINATION="23;85;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512769383980" ID="ID_415336941" MODIFIED="1512769397102" TEXT="den Zusammenhang nicht im Interface ausdrücken"/>
|
|
<node CREATED="1512769398050" ID="ID_1821068883" MODIFIED="1512769409404" TEXT="zusatz-Feature "extendChildren" in separates Interface"/>
|
|
</node>
|
|
<node COLOR="#2b3cb9" CREATED="1512769068942" ID="ID_1398747892" LINK="https://stackoverflow.com/questions/47722508/cost-of-virtual-inheritance-from-an-interface" MODIFIED="1512769090329" TEXT="Frage auf Stackoverflow gepostet">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1512769478607" HGAP="-17" ID="ID_813779439" MODIFIED="1512769512216" TEXT="setze den Workaround um" VSHIFT="28">
|
|
<linktarget COLOR="#7c89a1" DESTINATION="ID_813779439" ENDARROW="Default" ENDINCLINATION="178;-25;" ID="Arrow_ID_1765195063" SOURCE="ID_1401491527" STARTARROW="None" STARTINCLINATION="23;85;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512782185739" FOLDED="true" HGAP="21" ID="ID_787592346" MODIFIED="1525124214825" TEXT="deepCopy()" VSHIFT="13">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512782196185" FOLDED="true" ID="ID_730992497" MODIFIED="1512926193415" TEXT="sinnvoll?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512782214975" ID="ID_1723806811" MODIFIED="1512782227225" TEXT="Kopie des Iterator Front-End"/>
|
|
<node CREATED="1512782228405" ID="ID_1929504787" MODIFIED="1512782239591" TEXT="aber gleiches IterSource Back-End"/>
|
|
</node>
|
|
<node CREATED="1512782243187" FOLDED="true" ID="ID_836129726" MODIFIED="1512926193416" TEXT="machbar?">
|
|
<node CREATED="1512782248162" FOLDED="true" ID="ID_1374048285" MODIFIED="1512926193409" TEXT="analog zu expandChildren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512782411812" ID="ID_123602287" MODIFIED="1512782418183" TEXT="deepCopy wird virtual function"/>
|
|
<node CREATED="1512782418987" ID="ID_1515367406" MODIFIED="1512782431453" TEXT="Implementierung klont und baut neue IterSource"/>
|
|
<node CREATED="1512782435761" ID="ID_299702661" MODIFIED="1512782444278" TEXT="ja das wäre machbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512782259136" FOLDED="true" ID="ID_1896672181" MODIFIED="1512926193409" TEXT="einigermaßen technisch...">
|
|
<node CREATED="1512782296798" ID="ID_347250455" MODIFIED="1512782320932" TEXT="es müßte sich PackagedTreeExplorerSource selbst bauen können"/>
|
|
<node CREATED="1512782329311" ID="ID_1917918946" MODIFIED="1512782351304" TEXT="außerdem müßte nun das ChildExpandableSource auf VAL getemplated werden"/>
|
|
<node CREATED="1512782382056" ID="ID_657754771" MODIFIED="1512782393002" TEXT="und der ganze Build-Ausdruck wird auf mehrere Klassen verteilt"/>
|
|
<node CREATED="1512782393902" ID="ID_1809708776" MODIFIED="1512782398528" TEXT="ned schee">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512782476707" FOLDED="true" ID="ID_1058031222" MODIFIED="1512926193410" TEXT="fragwürdig....">
|
|
<node CREATED="1512782485498" ID="ID_1399160841" MODIFIED="1512782495540" TEXT="normalerweise sind Iteratoren nicht re-startbar"/>
|
|
<node CREATED="1512782496417" ID="ID_1935883418" MODIFIED="1512782502387" TEXT="wir könnten sie sogar move-only machen"/>
|
|
<node CREATED="1512782505231" ID="ID_1563966686" MODIFIED="1512782514850" TEXT="und der Pipeline-Builder ist bequem"/>
|
|
<node CREATED="1512782515966" ID="ID_4691119" MODIFIED="1512782523832" TEXT="also im Zwefel neu bauen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512782275078" ID="ID_14348211" MODIFIED="1512782286709" TEXT="im Moment nicht notwendig">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512621185490" FOLDED="true" ID="ID_1611878074" MODIFIED="1561827469130" TEXT="Probleme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512621202688" FOLDED="true" ID="ID_57740660" MODIFIED="1525124214825" TEXT="durchreichen der Basis-Konstruktoren">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1512706139167" FOLDED="true" ID="ID_1731306892" MODIFIED="1512926193416" TEXT="Basis-Copy-Konstruktoren werden nicht geerbt">
|
|
<node CREATED="1512706158004" ID="ID_958479010" MODIFIED="1512706289090" TEXT="nicht in C++14">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da gibt es eine explizite Ausnahme-Regel.
|
|
</p>
|
|
<p>
|
|
Die Copy-Konstruktoren werden aus der Kandidaten-Menge entfernt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Grund ist, daß die default-Initialisierung der Member-Felder noch nicht hinrechend geklärt war.
|
|
</p>
|
|
<p>
|
|
C++17 holt das nach
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512706162921" ID="ID_601609235" MODIFIED="1512706394332" TEXT="ab C++17 ist das anders">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dort wird einfach on-demand in der Basisklasse nachgeschaut.
|
|
</p>
|
|
<p>
|
|
Wenn dabei ein Basis-Copy-Ctor gezogen wird, dann wird eben default-Init für die Felder im abgeleiteten Objekt gemacht.
|
|
</p>
|
|
<p>
|
|
Es gibt dann eine neue, explizite Regel, die verhindert, daß zufällig ein aus der Basis geerbter Ctor
|
|
</p>
|
|
<p>
|
|
die Signatur eines Copy-ctors überdeckt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512706405155" ID="ID_1013782130" MODIFIED="1512706515474">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Allerdings genügt es, dies an <i>einer</i> Stelle in der Kette zu ergänzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar genau dort, wo erstmals ein Basis-Objekt akzeptiert wird.
|
|
</p>
|
|
<p>
|
|
Das ist bei uns im BaseAdapter, also der ersten Ebene über dem zu initialisierenden Basis-Objekt.
|
|
</p>
|
|
<p>
|
|
Alle anderen Layer darüber reichen dann korrekt mit dem geerbten Ctor diese Initialisierung nach Unten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512706516628" ID="ID_1092840037" MODIFIED="1512706656273">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
übrigens ist es im IterSource<T>::iterator <i>nicht</i>  notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das war nur ein unnötiger Fix nach dem Gießkannen-Prinzip.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Denn dieser Iterator soll niemals mit einem Basis-Objekt initialisiert werden,
|
|
</p>
|
|
<p>
|
|
sondern stets von der IterSource-Builder-Funktion konstruiert.
|
|
</p>
|
|
<p>
|
|
Und wenn man selber keinen Ctor in eine Klasse schreibt, sondern nur ctor-erbt,
|
|
</p>
|
|
<p>
|
|
dann werden auch die Copy-Konstruktoren korrekt automatisch generiert.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512621222901" FOLDED="true" ID="ID_701320194" MODIFIED="1525124214825" TEXT="bad function call">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512621654283" ID="ID_1975194377" MODIFIED="1512621667489" TEXT="passiert im FIlter-Iterator-Test">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1512621668449" ID="ID_369576813" MODIFIED="1512705931292" TEXT="hab ich einen schon funktionierenden Test gebrochen?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1512705938426" FOLDED="true" ID="ID_483656941" MODIFIED="1512926193416" TEXT="nein: der Test-Code war kaputt">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512705974765" ID="ID_1628672101" MODIFIED="1512706019739" TEXT="Vorsicht: der Builder macht move!">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1512706022079" ID="ID_118572066" MODIFIED="1512706045943" TEXT="d.h. die lokale Variable im Test war danach kaputt..."/>
|
|
<node CREATED="1512706051907" ID="ID_133885955" MODIFIED="1512706067900" TEXT="in der vorherigen Version fehlte nur irgendwo in der Kette ein move-ctor"/>
|
|
<node CREATED="1512706069104" ID="ID_596682451" MODIFIED="1512706085953" TEXT="und deshalb ist nicht aufgefallen, daß das Objekt schon tot war"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512787530248" FOLDED="true" ID="ID_1415286168" MODIFIED="1525124214826" TEXT="IterSource design mismatch">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1512788814147" ID="ID_499062281" MODIFIED="1512788850106" TEXT="versteckt gecachete Auswertung im Pos-Pointer">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1512788851294" FOLDED="true" ID="ID_185134520" MODIFIED="1512926193416" TEXT="hat nur zwei Iteration-control-Funtkionen">
|
|
<node CREATED="1512788924908" ID="ID_1786665760" MODIFIED="1512788936838" TEXT="vmtl. von Java inspiriert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512788878042" ID="ID_1218734139" MODIFIED="1512788887877" TEXT="rein logisch sollten es 3 sein"/>
|
|
<node CREATED="1512788911973" ID="ID_565612331" MODIFIED="1512788919552" TEXT="denn check() != yield()"/>
|
|
</node>
|
|
<node CREATED="1512788944977" FOLDED="true" ID="ID_1974205271" MODIFIED="1512926193416" TEXT="Konequenz">
|
|
<node CREATED="1512788955751" ID="ID_1249769782" MODIFIED="1512788975537" TEXT="Zustand nach letztem iterate() wird verschleppt"/>
|
|
<node CREATED="1512788976389" ID="ID_409716481" MODIFIED="1512788989639" TEXT="der Pos-Pointer zeigt irgendwo in die Implementierung"/>
|
|
<node CREATED="1512788990467" ID="ID_1029092512" MODIFIED="1512788998757" TEXT="erzeugt ungesunde Koppelung"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512789824290" FOLDED="true" ID="ID_283479652" MODIFIED="1512926193416" TEXT="Beschluß">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512789836161" ID="ID_1758704874" MODIFIED="1512789845955" TEXT="Design von IterSource ist nicht in Ordnung"/>
|
|
<node CREATED="1512789847183" ID="ID_1699957562" MODIFIED="1512789865193" TEXT="es sollte sich am "state core"-Schema orientieren"/>
|
|
<node CREATED="1512789870516" ID="ID_1318870340" LINK="http://issues.lumiera.org/ticket/1125" MODIFIED="1512794035043">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ticket machen: <font color="#b90736">#1125</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#7f5f85" DESTINATION="ID_1318870340" ENDARROW="Default" ENDINCLINATION="867;50;" ID="Arrow_ID_1918593298" SOURCE="ID_1066396845" STARTARROW="None" STARTINCLINATION="483;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512358595283" FOLDED="true" ID="ID_1526405052" MODIFIED="1561827469149" TEXT="piggyback?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1512358616584" ID="ID_1041373923" MODIFIED="1512358662699" TEXT=""könnte mal praktisch sein"">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1512358626607" FOLDED="true" ID="ID_853537387" MODIFIED="1561827469130" TEXT="hab die Idee schon lange">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...daß man ein Ding komplett in einen Iterator packt,
|
|
</p>
|
|
<p>
|
|
und dieser es dann auch managed
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1512358864343" FOLDED="true" ID="ID_1251747225" MODIFIED="1525124214828">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist das <font color="#9e1124">#190</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512358896258" ID="ID_62377324" MODIFIED="1512358945435" TEXT="nein das ist was anderes">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1512358903177" ID="ID_1427111206" MODIFIED="1512358940471" TEXT="das wäre OpaqueHolder heute">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512358931774" ID="ID_1681797535" MODIFIED="1512358937271" TEXT="plus etwas Magie">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512358965657" ID="ID_816120367" MODIFIED="1512359005565" TEXT="trotzdem... auch IterSnapshot">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist partiell diese Idee.
|
|
</p>
|
|
<p>
|
|
Nur auch das auf einem etwas anderem Level,
|
|
</p>
|
|
<p>
|
|
und immer mit einem Heap-allozierten vector
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512358632486" ID="ID_1795551304" MODIFIED="1512358640785" TEXT="aber keine konkrete Anwendung"/>
|
|
<node CREATED="1512358649900" FOLDED="true" ID="ID_1625666992" MODIFIED="1561827469130" TEXT="wäre hier billig zu haben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1513473578677" ID="ID_834217894" MODIFIED="1513473581168" TEXT="ja..."/>
|
|
<node CREATED="1513473581876" ID="ID_1304656331" MODIFIED="1513473586811" TEXT="bei Bedarf">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941467586" FOLDED="true" ID="ID_381928532" MODIFIED="1561827482920" TEXT="TreeExplorer_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1510969031378" FOLDED="true" ID="ID_1678287752" MODIFIED="1561827469149" TEXT="verify_wrappedIterator();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511054727547" ID="ID_328168347" MODIFIED="1511054858441" TEXT="Problem: muß Iterator-Arten unterscheiden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511054740579" FOLDED="true" ID="ID_776471136" MODIFIED="1561827469130" TEXT="StateCore direkt verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511054762608" ID="ID_1129026084" MODIFIED="1511054793514" TEXT="muß IterStateWrapper unterstützen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511054775616" ID="ID_1071927856" MODIFIED="1511054795068" TEXT="Metafuntkion um Erweiterungspunkte zu erkennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511054800851" ID="ID_186154206" MODIFIED="1511054827673" TEXT="Lumiera-Iterator verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511054810307" ID="ID_418847335" MODIFIED="1511227734539" TEXT="Range-iter um STL -iterable legen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510969031379" FOLDED="true" ID="ID_1298407683" MODIFIED="1561827469149" TEXT="verify_expandOperation();">
|
|
<linktarget COLOR="#5d68b6" DESTINATION="ID_1298407683" ENDARROW="Default" ENDINCLINATION="-53;-200;" ID="Arrow_ID_1214344498" SOURCE="ID_1808038526" STARTARROW="None" STARTINCLINATION="-292;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511227813712" FOLDED="true" ID="ID_942570698" MODIFIED="1561827469131" TEXT="Fall-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511227821087" ID="ID_1644135845" MODIFIED="1511571551953" TEXT="monadisch / funktional">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511571810531" ID="ID_84419798" MODIFIED="1511571819891" TEXT="Val -> Core">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511227824495" ID="ID_1299746114" MODIFIED="1511731959295" TEXT="Val -> Iter<Val>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511571834032" ID="ID_1315469399" MODIFIED="1511754060610" TEXT="Val -> collection<Val>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511227861867" FOLDED="true" ID="ID_1821706302" MODIFIED="1561827469131" TEXT="Fall-2 ">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1511227870346" ID="ID_797579225" MODIFIED="1511571541045" TEXT="verzahnte Implementierung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1511227975028" FOLDED="true" ID="ID_1769405758" MODIFIED="1525124214840" TEXT="Sub-Fälle">
|
|
<node COLOR="#338800" CREATED="1511227917971" ID="ID_200983707" MODIFIED="1511571722416" TEXT="Core& -> Core">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511227902005" ID="ID_1992381343" MODIFIED="1511754553025" TEXT="Core -> Iter<Val>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1511571746395" FOLDED="true" ID="ID_1199592659" MODIFIED="1512926193416" TEXT="generisches Lambda">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511227944392" ID="ID_881609766" MODIFIED="1511571897315" TEXT="Iter<Val>& -> Core">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511227925202" ID="ID_290152631" MODIFIED="1511755056399" TEXT="Iter<Val> -> Iter<Val>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510969031379" FOLDED="true" ID="ID_358406634" MODIFIED="1561827469149" TEXT="verify_transformOperation();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1511835550655" ID="ID_1305788204" MODIFIED="1512276390701" TEXT="Transformer(Iter<Core>)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511835603751" ID="ID_6147833" MODIFIED="1512276267722" TEXT="Transformer(Iter<Val>)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511835716176" ID="ID_1407397782" MODIFIED="1512276211354" TEXT="Transformer mit Seiteneffekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511835691963" FOLDED="true" ID="ID_175353270" MODIFIED="1561827469131" TEXT="Transform: generic Lambda">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512181454244" ID="ID_23118252" MODIFIED="1512271778125" TEXT="AUA: warum wird hier ein Value als Arguement übergeben">
|
|
<arrowlink COLOR="#a83e54" DESTINATION="ID_215116122" ENDARROW="Default" ENDINCLINATION="351;347;" ID="Arrow_ID_891457048" STARTARROW="None" STARTINCLINATION="683;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512181480616" FOLDED="true" ID="ID_1099744034" MODIFIED="1525124214840" TEXT="Beobachtung: move in join">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512181493551" ID="ID_1834475937" MODIFIED="1512181507297" TEXT="Bei Übergabe in stringify() fehlt std::forward"/>
|
|
<node CREATED="1512181508053" ID="ID_1058623354" MODIFIED="1512181516343" TEXT="transformIterator strippt die Referenz"/>
|
|
<node CREATED="1512181517955" ID="ID_517823516" MODIFIED="1512181526366" TEXT="aus LValue wird RValue"/>
|
|
<node CREATED="1512181527834" ID="ID_1446020077" MODIFIED="1512181535898" TEXT="Peng">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1512181547263" FOLDED="true" ID="ID_1700050621" MODIFIED="1512926193416" TEXT="Aufklären: warum wird Referenz gestrippt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512349360360" ID="ID_1400970540" MODIFIED="1512349365789" TEXT="vmtl Programmierfehler"/>
|
|
<node CREATED="1512349367230" ID="ID_1844975610" MODIFIED="1512349379887" TEXT="IterTool braucht den Typ des Basis-Iterators"/>
|
|
<node CREATED="1512349380643" ID="ID_1515581078" MODIFIED="1512349403999">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
versehentlich wurde <i>auch der</i> an std::forward gegeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512349405280" ID="ID_1121668073" MODIFIED="1512349446256" TEXT="war nachweislich eine echte Fehlfunktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habs mit FormatUtils_test bewiesen
|
|
</p>
|
|
<p>
|
|
Dazu in NumIter einen explizit tracenden move-ctor eingebaut
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512181592137" FOLDED="true" ID="ID_1472433606" MODIFIED="1512926193417" TEXT="im Ergebnis folgenlos, aber gefährlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil der Aufruf von join(&&) selber wasserdicht ist
|
|
</p>
|
|
<p>
|
|
D.h. er frisst keine Werte.
|
|
</p>
|
|
<p>
|
|
Deshalb fällt dieses doppelte Problem nicht auf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1512349447978" ID="ID_1467669966" MODIFIED="1512349453141" TEXT="und zwar wegen util::join"/>
|
|
<node CREATED="1512349454562" ID="ID_1337232290" MODIFIED="1512349470555" TEXT="dieses hat --versehentlich-- eine Kopie zu viel gemacht"/>
|
|
<node CREATED="1512349471143" ID="ID_540600531" MODIFIED="1512349476953" TEXT="Hurrgha!!!!!">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512349501091" ID="ID_1425293642" MODIFIED="1512349506090" TEXT="beide defekte gefixt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512355552695" ID="ID_1326048469" MODIFIED="1512355578832" TEXT="Beobachtung: ItemWrapper unterstützt kein move">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511835901999" FOLDED="true" ID="ID_1717235881" MODIFIED="1561827469131" TEXT="Transform: Core& -> irgendwas">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1512276512313" ID="ID_725756500" MODIFIED="1512276517860" TEXT="sollte theoretisch möglich sein"/>
|
|
<node CREATED="1512276524111" ID="ID_453994757" MODIFIED="1512276583587" TEXT="nicht sonderlich sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil man den konkreten Typ der Core kennen muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512276518472" ID="ID_1860559214" MODIFIED="1512278316412" TEXT="per Testfall dokumentiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510969031379" FOLDED="true" ID="ID_722056043" MODIFIED="1561827469149" TEXT="verify_combinedExpandTransform();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512363192308" FOLDED="true" ID="ID_1913090689" MODIFIED="1561827469131" TEXT="expand über Transformer hinweg">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512363626338" ID="ID_1302720848" MODIFIED="1512363637547" TEXT="funktioniert out-of-the-Box">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1512363638640" ID="ID_67728054" MODIFIED="1512363645997" TEXT="naja fast">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363210130" FOLDED="true" ID="ID_480959271" MODIFIED="1561827469131" TEXT="expand aus manipulierendem Transformer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512363649158" ID="ID_1152388495" MODIFIED="1512363655383" TEXT="ebenso">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1512522106792" ID="ID_1499481842" MODIFIED="1512522120926" TEXT="naja fast noch fastiger">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363659085" ID="ID_1079241242" MODIFIED="1512521919442" TEXT="TODO output CHECK">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512363228751" ID="ID_579206895" MODIFIED="1512516921091" TEXT="Problem: re-evaluate nach expand">
|
|
<arrowlink COLOR="#5a92a2" DESTINATION="ID_531127457" ENDARROW="Default" ENDINCLINATION="385;167;" ID="Arrow_ID_556443427" STARTARROW="None" STARTINCLINATION="844;55;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511836579562" FOLDED="true" ID="ID_1718741335" MODIFIED="1561827469150" TEXT="verify_FilterIterator();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512523719350" ID="ID_351021178" MODIFIED="1512606882124" TEXT="einfaches Prädikat">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512523726885" ID="ID_282579718" MODIFIED="1512608271472" TEXT="konsumieren bis leer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512523773559" FOLDED="true" ID="ID_917494688" MODIFIED="1561827469131" TEXT="Prädikat<Core>">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512609324903" ID="ID_1654303504" MODIFIED="1512609343982" TEXT="kann an den Vorgängern vorbeitunneln">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512523783318" ID="ID_1808219280" MODIFIED="1512611989218" TEXT="Prädikat<Iter> (generisch)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512523810946" ID="ID_461047497" MODIFIED="1512612006569" TEXT="... mit expand()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512612008548" ID="ID_13525358" MODIFIED="1512612041105" TEXT="...und Seiteneffekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512612015283" ID="ID_1560717932" MODIFIED="1512612042056" TEXT="...und geklontem Zustand">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512612027105" ID="ID_739092273" MODIFIED="1512612042905" TEXT="...und nachträglich hinzugefügtem Layer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#2b7d95" CREATED="1512612043592" ID="ID_1719204676" MODIFIED="1512612065051" TEXT="...es lebe die Komplexität">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1511836589393" FOLDED="true" ID="ID_54165230" MODIFIED="1561827469150" TEXT="verify_asIterSource();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512620990860" ID="ID_167384287" MODIFIED="1512789972907" TEXT="einfach verpacken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512620997827" ID="ID_173233581" MODIFIED="1512789974436" TEXT="erzeugte source erneut verpacken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512621101645" ID="ID_1982135306" MODIFIED="1512789977343" TEXT="Polymorphie: verschiedene Pipelines">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verschiedendste Pipeline-Konstruktionen
|
|
</p>
|
|
<p>
|
|
können nun hinter dem gleichen Interface sitzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512621116947" FOLDED="true" ID="ID_1907769466" MODIFIED="1561827469131" TEXT="durchgeschleifte expandChildren()-Operation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512787465929" ID="ID_1053911863" MODIFIED="1512788738307" TEXT="Bug!">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512787549870" ID="ID_1969077394" MODIFIED="1512789984536" TEXT="wieder mal kein refresh nach expandChildren()">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512788719640" ID="ID_1066396845" LINK="http://issues.lumiera.org/ticket/1125" MODIFIED="1512794080241" TEXT="TODO: Design-Mismatch -> Ticket">
|
|
<arrowlink COLOR="#7f5f85" DESTINATION="ID_1318870340" ENDARROW="Default" ENDINCLINATION="867;50;" ID="Arrow_ID_1918593298" STARTARROW="None" STARTINCLINATION="483;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512621383815" FOLDED="true" ID="ID_1705587551" MODIFIED="1561827469131" TEXT="Problem: shallow copy">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rein ein Problem mit der Test-Fixture.
|
|
</p>
|
|
<p>
|
|
Da die Quelle nun von einem shared-ptr gehalten wird,
|
|
</p>
|
|
<p>
|
|
erzeugt eine Kopie des Iterator-Front-End
|
|
</p>
|
|
<p>
|
|
nun nicht mehr eine Kopie des ganzen Zustandes.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
das wäre aber bequem für den Test.
|
|
</p>
|
|
<p>
|
|
<u>Frage</u>: ist das überhaupt eine gute Idee, vom Design her??
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1512711333823" ID="ID_1629518942" MODIFIED="1512711345303" TEXT="Idee: deepCopy bieten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1512789897080" ID="ID_1862531344" MODIFIED="1512789900649" TEXT="njet">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1512789907575" ID="ID_1220260137" MODIFIED="1512789914778" TEXT="ist nur ein Problem in Tests etc."/>
|
|
<node CREATED="1512789946314" ID="ID_1425696979" MODIFIED="1512789953964" TEXT="widerspricht dem Iteratoren-Konzept"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513990814361" FOLDED="true" ID="ID_306902168" MODIFIED="1561827469150" TEXT="verify_IterSource()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513990873545" ID="ID_1789456983" MODIFIED="1514050256867" TEXT="einfache Iteration">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514081155455" ID="ID_1538736368" MODIFIED="1514081182820" TEXT="Iteration ohne storage management">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513990880600" ID="ID_1730629901" MODIFIED="1514081152728" TEXT="Iteration + Expansion">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514747089115" FOLDED="true" ID="ID_1696559217" MODIFIED="1561827469150" TEXT="verify_scheduledExpansion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514747105248" ID="ID_952786179" MODIFIED="1514824954671" TEXT="setup wie child expansion">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514747112048" ID="ID_1206186653" MODIFIED="1514827171677" TEXT="wird aber erst bei Iteration vollzogen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510969031379" FOLDED="true" ID="ID_1327871737" MODIFIED="1561827469150" TEXT="verify_depthFirstExploration();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512844598906" ID="ID_933777340" MODIFIED="1512861473722" TEXT="expand incl Parent">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512952896394" FOLDED="true" ID="ID_501441857" MODIFIED="1561827469132" TEXT="Beispiel mit Tuple als Zwischenwert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1512952911249" ID="ID_302553275" MODIFIED="1512952934726" TEXT="Funktion mit Tuple-Wert läßt sich nicht binden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512952922127" ID="ID_748691821" MODIFIED="1512955609419" TEXT="Unsinn im Tuple-Helper identifiziert">
|
|
<arrowlink COLOR="#408281" DESTINATION="ID_568101334" ENDARROW="Default" ENDINCLINATION="-136;7;" ID="Arrow_ID_1210920107" STARTARROW="None" STARTINCLINATION="-417;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512952846993" FOLDED="true" HGAP="71" ID="ID_568101334" MODIFIED="1525124214841" TEXT="TupleHelper_test broken" VSHIFT="111">
|
|
<linktarget COLOR="#408281" DESTINATION="ID_568101334" ENDARROW="Default" ENDINCLINATION="-136;7;" ID="Arrow_ID_1210920107" SOURCE="ID_748691821" STARTARROW="None" STARTINCLINATION="-417;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512952975600" FOLDED="true" ID="ID_1282921475" MODIFIED="1525124214840" TEXT="Types<tuple<TYPES...>>">
|
|
<node CREATED="1512952994765" ID="ID_1028880050" MODIFIED="1512953023243" TEXT="wurde automatisch gehoben auf Types<TYPES...>">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1512953008628" ID="ID_105420180" MODIFIED="1512953018858" TEXT="ziemlich dumme Idee">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512953639277" FOLDED="true" ID="ID_93632445" MODIFIED="1525124214841" TEXT="broken sind...">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1512953663356" FOLDED="true" ID="ID_587022650" MODIFIED="1525124214840" TEXT="Tup1 :">
|
|
<node CREATED="1512953639278" ID="ID_1100197404" MODIFIED="1512954771519" TEXT="TUPLE-<1>-<3>-<5>-">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512953639278" ID="ID_894542190" MODIFIED="1512954775187" TEXT="TUPLE-<tuple<Num<1>, Num<3>, Num<5> >>-">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512953674962" FOLDED="true" ID="ID_1880760198" MODIFIED="1525124214840" TEXT="T_L1 :">
|
|
<node CREATED="1512953639278" ID="ID_1929044147" MODIFIED="1512954778777" TEXT="TUPLE-<1>-<3>-<5>-">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512953639278" ID="ID_1790615976" MODIFIED="1512954785530" TEXT="TUPLE-<tuple<Num<1>, Num<3>, Num<5> >>-">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512953684233" FOLDED="true" ID="ID_608070908" MODIFIED="1525124214840" TEXT="Seq1 :">
|
|
<node CREATED="1512953639279" ID="ID_1741392154" MODIFIED="1512955031447" TEXT="-<1>-<3>-<5>-">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512953639279" ID="ID_213667790" MODIFIED="1512955034003" TEXT="-<tuple<Num<1>, Num<3>, Num<5> >>-">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512953692712" FOLDED="true" ID="ID_690443382" MODIFIED="1525124214840" TEXT="Prepend :">
|
|
<node CREATED="1512953639279" ID="ID_1949823809" MODIFIED="1512954789660" TEXT="TUPLE-<i>-<1>-<3>-<5>-">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1512953639279" ID="ID_1268362964" MODIFIED="1512954792261" TEXT="TUPLE-<tuple<int, Num<1>, Num<3>, Num<5> >>-">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1512953030113" FOLDED="true" HGAP="21" ID="ID_227944051" MODIFIED="1525124214841" TEXT="bestehenden Code in Commands gefixt" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1512953037928" ID="ID_1081876156" MODIFIED="1512953052337" TEXT="verwende nun explizite Rebinding-Metafunktion"/>
|
|
<node CREATED="1512955051435" ID="ID_1397072837" MODIFIED="1512955062645" TEXT="weitere Fehler im Test-Diagnose-Code">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1512844615941" ID="ID_1111018492" MODIFIED="1512952089605" TEXT="auto expand to leafs">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1512844628403" ID="ID_926180284" MODIFIED="1513217015005" TEXT="Heben von single values">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510969031379" FOLDED="true" ID="ID_842384656" MODIFIED="1561827469150" TEXT="demonstrate_LayeredEvaluation();">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513035990902" FOLDED="true" ID="ID_1647713519" MODIFIED="1561827469132" TEXT="Zweck">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1513035997493" ID="ID_1010963261" MODIFIED="1513036010287" TEXT="vorbereitender Fingerübung für UI-Coord-Matching"/>
|
|
<node CREATED="1513036021682" ID="ID_979180127" MODIFIED="1513036042627" TEXT="demonstriert Arbeiten auf opaque Daten"/>
|
|
<node CREATED="1513036050278" ID="ID_1967927817" MODIFIED="1513036064144" TEXT="demonstriert Algo in Layern"/>
|
|
</node>
|
|
<node CREATED="1513036074899" FOLDED="true" ID="ID_1736020922" MODIFIED="1561827469132" TEXT="Vorgaben">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513036079426" ID="ID_1465268489" MODIFIED="1513036093852" TEXT="Text-Fixture so einfach wie möglich"/>
|
|
<node CREATED="1513036109158" ID="ID_142686199" MODIFIED="1513036128095" TEXT="es wird tatsächlich etwas Baum-artig gesucht"/>
|
|
<node CREATED="1513036128988" ID="ID_1461134959" MODIFIED="1513036135063" TEXT="das Ergebnis ist verifizierbar"/>
|
|
</node>
|
|
<node CREATED="1513036196163" FOLDED="true" ID="ID_994330749" MODIFIED="1561827469132" TEXT="Idee-1">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513036205114" ID="ID_792801416" MODIFIED="1513036214764" TEXT="zufällige Zahlenfolge wiederfinden"/>
|
|
<node CREATED="1513036215559" ID="ID_971330002" MODIFIED="1513036250591" TEXT="...indem man in N Permutationen hintereinander sucht"/>
|
|
<node CREATED="1513036284727" FOLDED="true" ID="ID_1614652691" MODIFIED="1525124214841" TEXT="brauche...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1513036309324" ID="ID_1342792562" MODIFIED="1513036336740" TEXT="Folge von N (zufälligen) Zahlen"/>
|
|
<node CREATED="1513036452217" ID="ID_526681708" MODIFIED="1513036460131" TEXT="permutierte, iterierbare Kopie dieser"/>
|
|
<node CREATED="1513036690929" ID="ID_956797377" LINK="http://en.cppreference.com/w/cpp/algorithm/random_shuffle" MODIFIED="1513036739059">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
siehe <font color="#4423e3"><b>std::shuffle</b></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513036568505" FOLDED="true" ID="ID_1862649545" MODIFIED="1525124214841" TEXT="Kritik">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513128587329" ID="ID_1360317308" MODIFIED="1513202754508" TEXT="Ergebnis nicht klar erkennbar"/>
|
|
<node CREATED="1513036574968" ID="ID_7224449" MODIFIED="1513036580732" TEXT="ist nicht wirklich ein Baum"/>
|
|
<node CREATED="1513202756258" ID="ID_397395434" MODIFIED="1513202760717" TEXT="kein Backtracking"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513128368566" FOLDED="true" ID="ID_405602924" MODIFIED="1561827469132" TEXT="Idee-2">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513128409745" ID="ID_784629005" MODIFIED="1513128419748" TEXT="naive Primfaktor-Zerlegung"/>
|
|
<node CREATED="1513129988151" FOLDED="true" ID="ID_1967188076" MODIFIED="1525124214841" TEXT="brauche...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1513129996990" ID="ID_276407850" MODIFIED="1513130019831" TEXT="Baum-artige Darstellung einer repetitiven Berechnung"/>
|
|
<node CREATED="1513130020747" ID="ID_308365494" MODIFIED="1513130093541" TEXT="die nicht so verworren ist, daß sie sofort abschreckt"/>
|
|
</node>
|
|
<node CREATED="1513131251047" FOLDED="true" ID="ID_1217476327" MODIFIED="1525124214841" TEXT="Kritik">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513131259926" ID="ID_1015392046" MODIFIED="1513131271729" TEXT="Verfahren ist komplett deterministisch"/>
|
|
<node CREATED="1513131272956" ID="ID_1394088821" MODIFIED="1513131285590" TEXT="kein Grund, expandChildren() von außen aufzurufen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513206569503" FOLDED="true" ID="ID_729219891" MODIFIED="1561827469132" TEXT="Idee-3">
|
|
<arrowlink COLOR="#374d84" DESTINATION="ID_570463763" ENDARROW="Default" ENDINCLINATION="2;-39;" ID="Arrow_ID_1149883114" STARTARROW="None" STARTINCLINATION="0;47;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513206594428" ID="ID_678047423" MODIFIED="1513206615387">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vorgegebene Zahlenfolge<br />in untendlichem Zufalls-Baum finden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513206650964" FOLDED="true" ID="ID_973791239" MODIFIED="1525124214841" TEXT="brauche...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1513206662290" ID="ID_250120880" MODIFIED="1513206691338" TEXT="unendlichen Zufalls-Wald"/>
|
|
<node CREATED="1513206692190" ID="ID_1442303873" MODIFIED="1513206708352" TEXT="zufällige Kind-sequenzen"/>
|
|
<node CREATED="1513206709484" ID="ID_1659632018" MODIFIED="1513206720390" TEXT="die nicht sicher zum Erfolg führen"/>
|
|
</node>
|
|
<node CREATED="1513206872518" FOLDED="true" ID="ID_1422148890" MODIFIED="1525124214841" TEXT="wichtig">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513206889508" ID="ID_436020243" MODIFIED="1513206900054" TEXT="Trennung zwischen Baum und Suche"/>
|
|
<node CREATED="1513207103464" ID="ID_919723140" MODIFIED="1513207144478" TEXT="durchgehender Zustand in der Suche"/>
|
|
<node CREATED="1513207165088" ID="ID_529012246" MODIFIED="1513207191511" TEXT="Nichtdeterminismus, aber 99.9999% Erfolgs-Chancen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513218546828" FOLDED="true" HGAP="-37" ID="ID_570463763" MODIFIED="1561827469132" TEXT="konkret..." VSHIFT="37">
|
|
<linktarget COLOR="#374d84" DESTINATION="ID_570463763" ENDARROW="Default" ENDINCLINATION="2;-39;" ID="Arrow_ID_1149883114" SOURCE="ID_729219891" STARTARROW="None" STARTINCLINATION="0;47;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513218561938" ID="ID_1431731183" MODIFIED="1513473294567" TEXT="randomTree bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513218569000" ID="ID_973922179" MODIFIED="1513473296220" TEXT="Zustands-Typ bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1513218582175" FOLDED="true" ID="ID_1963772553" MODIFIED="1525124214842" TEXT="Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1513218627121" FOLDED="true" ID="ID_1077327965" MODIFIED="1513473496041" TEXT="Bottom-Error">
|
|
<arrowlink COLOR="#179a76" DESTINATION="ID_474013760" ENDARROW="Default" ENDINCLINATION="513;33;" ID="Arrow_ID_1289625747" STARTARROW="None" STARTINCLINATION="426;-150;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513218635200" ID="ID_418877787" MODIFIED="1513218650010" TEXT="beim Materialisieren der Random-Target-Sequenz"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513218664652" FOLDED="true" ID="ID_606716798" MODIFIED="1513476731235" TEXT="join kopiert einmal zu viel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513218677962" ID="ID_533421172" MODIFIED="1513218685429" TEXT="Ha! in der For-Schleife"/>
|
|
<node CREATED="1513218687113" ID="ID_108639825" MODIFIED="1513218698203" TEXT="der Iter ist benannt, also wird kopiert"/>
|
|
<node CREATED="1513218699103" FOLDED="true" ID="ID_645074355" MODIFIED="1525124214841" TEXT="ENABLE_IN_STD_FOR_LOOP">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1513218716941" ID="ID_1490164328" MODIFIED="1513476644166" TEXT="ist das so korrekt?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1513476644949" ID="ID_1188646042" MODIFIED="1513476648032" TEXT="ich denke schon"/>
|
|
<node CREATED="1513476649092" ID="ID_1643873286" MODIFIED="1513476698904">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man kann move(iter) verwenden,
|
|
</p>
|
|
<p>
|
|
wenn man konsumieren möchte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513476700629" ID="ID_316067173" MODIFIED="1513476716421" TEXT="...oder eine handgeschriebene FOR-Schleife">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513218727603" ID="ID_1592038855" MODIFIED="1513476627801" TEXT="while-Schleife verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513219035419" FOLDED="true" ID="ID_1033553745" MODIFIED="1513473487443" TEXT="prüfen: default constructible state core">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513219271307" ID="ID_474013760" MODIFIED="1513284051101" TEXT="hier liegt der Hund begraben">
|
|
<linktarget COLOR="#179a76" DESTINATION="ID_474013760" ENDARROW="Default" ENDINCLINATION="513;33;" ID="Arrow_ID_1289625747" SOURCE="ID_1077327965" STARTARROW="None" STARTINCLINATION="426;-150;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513219330467" ID="ID_37372305" MODIFIED="1513284091448" TEXT="default-konstruierte RandomSeq muß leer sein!">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1513473427921" FOLDED="true" ID="ID_530629075" MODIFIED="1525124214841" TEXT="Algo-State ist nicht default-constructible">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513473445287" ID="ID_482215181" MODIFIED="1513473460312" TEXT="aber man man kommt damit über die Runden"/>
|
|
<node CREATED="1513473461140" ID="ID_9651434" MODIFIED="1513473477134" TEXT="solange man den resultierenden Iterator nicht default-konstruiert"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513283787640" FOLDED="true" ID="ID_1300399860" MODIFIED="1513476755527" TEXT="Protokoll-pop funktioniert nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1513283807613" ID="ID_711568006" MODIFIED="1513283821335" TEXT="erschöpfter Kind-Iter wird nicht weggeräumt"/>
|
|
<node CREATED="1513283822323" ID="ID_1993626666" MODIFIED="1513283848220" TEXT="Folge: es wird auf dem letzten Element weitergezählt"/>
|
|
<node CREATED="1513283849472" FOLDED="true" ID="ID_1522104923" MODIFIED="1525124214841" TEXT="Aber der Basis-Iter (Datenquelle) funktioniert korrekt">
|
|
<node CREATED="1513283998356" ID="ID_265634850" MODIFIED="1513284011958" TEXT="deshalb funktioniert der Basis-Algo halbwegs"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513284012947" ID="ID_968932002" MODIFIED="1513476746547" TEXT="aber kein korrekte Backtracking">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513284021720" ID="ID_591353215" MODIFIED="1513476751387" TEXT="und das Protokoll geht out-of sync">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513283870965" FOLDED="true" ID="ID_372321627" MODIFIED="1525124214842" TEXT="Verdacht: wieder IterSrource schuld">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1513283882027" ID="ID_835741483" MODIFIED="1513283887198" TEXT="iterate hinter Ende"/>
|
|
<node CREATED="1513283888099" ID="ID_418628311" MODIFIED="1513283895629" TEXT="hätte den Pointer auf NULL setzen müssen"/>
|
|
<node CREATED="1513286352195" ID="ID_613044101" MODIFIED="1513286362260" TEXT="nein, das ist es nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1513286365209" ID="ID_1245783923" MODIFIED="1513286383453" TEXT="dataSrc poppt ja transparent...">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513286396525" FOLDED="true" ID="ID_1013175212" MODIFIED="1525124214842" TEXT="Logisches Problem mit layered expand">
|
|
<arrowlink COLOR="#9c5265" DESTINATION="ID_263549307" ENDARROW="Default" ENDINCLINATION="189;145;" ID="Arrow_ID_1920033917" STARTARROW="None" STARTINCLINATION="1219;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1513286420386" ID="ID_32133695" MODIFIED="1513286442066" TEXT="oberer Layer bekommt Ende der Quell-Folge nicht mit"/>
|
|
<node CREATED="1513286442822" ID="ID_1310607126" MODIFIED="1513286465873" TEXT="...und macht daher endlos mit den Kindern weiter">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513396403408" FOLDED="true" ID="ID_1034289731" MODIFIED="1525124214842" TEXT="pragmatischer Workaround">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513396411416" ID="ID_1466307579" MODIFIED="1513401380676" TEXT="Tiefe über ChildExpandableSource durchgeben">
|
|
<arrowlink COLOR="#75c4c1" DESTINATION="ID_1752199055" ENDARROW="Default" ENDINCLINATION="653;643;" ID="Arrow_ID_1536391130" STARTARROW="None" STARTINCLINATION="1299;33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513401151507" FOLDED="true" ID="ID_1181955496" MODIFIED="1525124214842" TEXT="Protokoll aber immer noch nicht korrekt implementiert">
|
|
<arrowlink COLOR="#63b5aa" DESTINATION="ID_804459643" ENDARROW="Default" ENDINCLINATION="456;372;" ID="Arrow_ID_1606709369" STARTARROW="None" STARTINCLINATION="1446;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513401162242" ID="ID_147162782" MODIFIED="1513401173005" TEXT="push am Ende"/>
|
|
<node CREATED="1513401192358" ID="ID_91552039" MODIFIED="1513401294410" TEXT="Beispiel "FAVSU"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rLet(40878 < 18446744073709551615) → S
|
|
</p>
|
|
<p>
|
|
|↯| S ... 40878
|
|
</p>
|
|
<p>
|
|
rLet(40879 < 18446744073709551615) → F
|
|
</p>
|
|
<p>
|
|
|!| expand 40879
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → A
|
|
</p>
|
|
<p>
|
|
rLet(40880 < 18446744073709551615) → Q
|
|
</p>
|
|
<p>
|
|
|.| A -->> 40879
|
|
</p>
|
|
<p>
|
|
|!| expand 40879
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → F
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → N
|
|
</p>
|
|
<p>
|
|
|.| F -->> 40879
|
|
</p>
|
|
<p>
|
|
|↯| F ... 40879
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → W
|
|
</p>
|
|
<p>
|
|
|↯| W ... 40879-0-1
|
|
</p>
|
|
<p>
|
|
rLet(2 < 4) → N
|
|
</p>
|
|
<p>
|
|
|↯| N ... 40879-0-2
|
|
</p>
|
|
<p>
|
|
rLet(3 < 4) → T
|
|
</p>
|
|
<p>
|
|
|↯| T ... 40879-0-3
|
|
</p>
|
|
<p>
|
|
rLet(4 < 4) → F
|
|
</p>
|
|
<p>
|
|
|↯| N ... 40879-1
|
|
</p>
|
|
<p>
|
|
rLet(2 < 4) → F
|
|
</p>
|
|
<p>
|
|
|↯| F ... 40879-2
|
|
</p>
|
|
<p>
|
|
rLet(3 < 4) → A
|
|
</p>
|
|
<p>
|
|
|!| expand 40879-3
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → J
|
|
</p>
|
|
<p>
|
|
rLet(4 < 4) → Y
|
|
</p>
|
|
<p>
|
|
|.| J -->> 40879-3
|
|
</p>
|
|
<p>
|
|
|↯| J ... 40879-3
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → H
|
|
</p>
|
|
<p>
|
|
|↯| H ... 40879-4
|
|
</p>
|
|
<p>
|
|
rLet(2 < 4) → H
|
|
</p>
|
|
<p>
|
|
|↯| H ... 40879-5
|
|
</p>
|
|
<p>
|
|
rLet(3 < 4) → F
|
|
</p>
|
|
<p>
|
|
|↯| F ... 40879-6
|
|
</p>
|
|
<p>
|
|
rLet(4 < 4) → V
|
|
</p>
|
|
<p>
|
|
|↯| Q ... 40880
|
|
</p>
|
|
<p>
|
|
rLet(40881 < 18446744073709551615) → A
|
|
</p>
|
|
<p>
|
|
|↯| A ... 40881
|
|
</p>
|
|
<p>
|
|
rLet(40882 < 18446744073709551615) → X
|
|
</p>
|
|
<p>
|
|
|↯| X ... 40882
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513401185198" ID="ID_933999759" MODIFIED="1513473212036" TEXT="Zähler läuft weiter">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1513473196754" ID="ID_570569140" MODIFIED="1513473207824" TEXT="Lösung: depth()-Infromation nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513447822247" ID="ID_1725576262" MODIFIED="1513448159466" TEXT="jetzt scheint's zu funktionieren...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rLet(77943 < 18446744073709551615) → R
|
|
</p>
|
|
<p>
|
|
|↯| R ... 77943
|
|
</p>
|
|
<p>
|
|
rLet(77944 < 18446744073709551615) → X
|
|
</p>
|
|
<p>
|
|
|!| expand 77944
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → U
|
|
</p>
|
|
<p>
|
|
rLet(77945 < 18446744073709551615) → I
|
|
</p>
|
|
<p>
|
|
|.| U -->> 77944-0
|
|
</p>
|
|
<p>
|
|
|↯| U ... 77944-0
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → X
|
|
</p>
|
|
<p>
|
|
|!| expand 77944-1
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → K
|
|
</p>
|
|
<p>
|
|
rLet(2 < 4) → Z
|
|
</p>
|
|
<p>
|
|
|.| K -->> 77944-1-0
|
|
</p>
|
|
<p>
|
|
|!| expand 77944-1-0
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → V
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → Y
|
|
</p>
|
|
<p>
|
|
|.| V -->> 77944-1-0-0
|
|
</p>
|
|
<p>
|
|
|↯| V ... 77944-1-0-0
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → I
|
|
</p>
|
|
<p>
|
|
|↯| I ... 77944-1-0-1
|
|
</p>
|
|
<p>
|
|
rLet(2 < 4) → I
|
|
</p>
|
|
<p>
|
|
|↯| I ... 77944-1-0-2
|
|
</p>
|
|
<p>
|
|
rLet(3 < 4) → Z
|
|
</p>
|
|
<p>
|
|
|!| expand 77944-1-0-3
|
|
</p>
|
|
<p>
|
|
rLet(0 < 4) → Q
|
|
</p>
|
|
<p>
|
|
rLet(4 < 4) → X
|
|
</p>
|
|
<p>
|
|
|.| Q -->> 77944-1-0-3-0
|
|
</p>
|
|
<p>
|
|
|↯| Q ... 77944-1-0-3-0
|
|
</p>
|
|
<p>
|
|
rLet(1 < 4) → M
|
|
</p>
|
|
<p>
|
|
Protocol of the search: 77944-1-0-3-1
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941646050" ID="ID_596422747" MODIFIED="1535892395441" TEXT="expandable ChildIter">
|
|
<linktarget COLOR="#283b63" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="66;49;" ID="Arrow_ID_1521598219" SOURCE="ID_1408571420" STARTARROW="Default" STARTINCLINATION="94;-19;"/>
|
|
<linktarget COLOR="#786296" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="278;120;" ID="Arrow_ID_1919142695" SOURCE="ID_115330701" STARTARROW="None" STARTINCLINATION="952;148;"/>
|
|
<linktarget COLOR="#236375" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="-1080;23;" ID="Arrow_ID_1748772698" SOURCE="ID_463934766" STARTARROW="None" STARTINCLINATION="-1002;-57;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1510941655360" ID="ID_1359727169" MODIFIED="1514292297209" TEXT="verwendet TreeExplorer">
|
|
<arrowlink COLOR="#585e9d" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-23;161;" ID="Arrow_ID_402051988" STARTARROW="None" STARTINCLINATION="138;6;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941661615" ID="ID_463290050" MODIFIED="1514292291295" TEXT="verpackt in IterSource">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513561602173" FOLDED="true" HGAP="180" ID="ID_760843174" MODIFIED="1561827483827" TEXT="Design" VSHIFT="29">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513560607636" FOLDED="true" ID="ID_774099115" MODIFIED="1561827482920" TEXT="expand -- wie?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1513560618698" ID="ID_471382650" MODIFIED="1513560638771" TEXT="Brauche Navigations-Zustand"/>
|
|
<node CREATED="1513560639504" ID="ID_1901070791" MODIFIED="1513560645283" TEXT="eine Position im Baum"/>
|
|
<node CREATED="1513560646014" ID="ID_812625308" MODIFIED="1513560649570" TEXT="implementation defined"/>
|
|
<node CREATED="1513560650614" ID="ID_127083955" MODIFIED="1513560657793" TEXT="muß dort Kind-iterieren können"/>
|
|
</node>
|
|
<node CREATED="1513561422541" FOLDED="true" ID="ID_1500554436" MODIFIED="1561827482920" TEXT="was ist depth()?">
|
|
<arrowlink COLOR="#62326e" DESTINATION="ID_1709677569" ENDARROW="Default" ENDINCLINATION="-209;-29;" ID="Arrow_ID_894748806" STARTARROW="Default" STARTINCLINATION="43;132;"/>
|
|
<linktarget COLOR="#9493b7" DESTINATION="ID_1500554436" ENDARROW="Default" ENDINCLINATION="91;103;" ID="Arrow_ID_811314610" SOURCE="ID_937539446" STARTARROW="None" STARTINCLINATION="-39;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1513561437011" ID="ID_263179318" MODIFIED="1513561443415" TEXT="absolut oder relativ"/>
|
|
<node CREATED="1513561451138" FOLDED="true" ID="ID_1617286796" MODIFIED="1561827469150" TEXT="absolut">
|
|
<node CREATED="1513561456016" ID="ID_1274246203" MODIFIED="1513561465683" TEXT="Tiefe im Gesamt-Baum"/>
|
|
<node CREATED="1513561467719" ID="ID_339272046" MODIFIED="1513561480090" TEXT="startet am Aufsetz-Punkt"/>
|
|
<node CREATED="1513561484277" ID="ID_1051233845" MODIFIED="1513561491224" TEXT="kein Aufstieg darüber möglich"/>
|
|
</node>
|
|
<node CREATED="1513561492668" FOLDED="true" ID="ID_600604579" MODIFIED="1561827469150" TEXT="relativ">
|
|
<node CREATED="1513561497003" ID="ID_860544223" MODIFIED="1513561508950" TEXT="expandChildren-Level"/>
|
|
<node CREATED="1513561509754" ID="ID_1041068517" MODIFIED="1513561522123" TEXT="startet mit 0 für normalen ChildIterator"/>
|
|
<node CREATED="1513561531383" ID="ID_442154302" MODIFIED="1513561547728" TEXT="Match-Algo muß start-Offset verwalten und draufschlagen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513561577840" FOLDED="true" HGAP="63" ID="ID_260039139" MODIFIED="1561827482920" TEXT="Struktur Navigations-Zustand" VSHIFT="22">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513561744004" ID="ID_937539446" MODIFIED="1513961543467" TEXT="hängt ab von relativ/absolut?">
|
|
<arrowlink COLOR="#9493b7" DESTINATION="ID_1500554436" ENDARROW="Default" ENDINCLINATION="91;103;" ID="Arrow_ID_811314610" STARTARROW="None" STARTINCLINATION="-39;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1513561681235" FOLDED="true" ID="ID_671830446" MODIFIED="1561827469151" TEXT="relativ => Node-Ref genügt">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1513561715590" ID="ID_1509891681" MODIFIED="1513859782028" TEXT="nein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513561717958" ID="ID_333457131" MODIFIED="1513561721993" TEXT="Sonderfall Perspektive"/>
|
|
<node CREATED="1513859759850" ID="ID_799120258" MODIFIED="1513859771462" TEXT="Grundsätzlich kann es Sonderfälle geben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513561916554" ID="ID_1130596381" MODIFIED="1513561945359" TEXT="(node&, depth)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1513562001015" FOLDED="true" ID="ID_1952968226" MODIFIED="1561827469151" TEXT="zuzüglich konkretem Kind-Iterator">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513564476303" FOLDED="true" ID="ID_718816032" MODIFIED="1561827469133" TEXT="Problem: Typ">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513564486206" ID="ID_586028205" MODIFIED="1513564495520" TEXT="Typ ist nicht uniform"/>
|
|
<node CREATED="1513564496228" ID="ID_559674728" MODIFIED="1513564503503" TEXT="wird erst hinter IterSource konform"/>
|
|
<node CREATED="1513564546974" ID="ID_301275475" MODIFIED="1513887480560" TEXT="wirklich relevantes Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil es mutmaßlich
|
|
</p>
|
|
<p>
|
|
im realen UI in ähnlicher Form auch auftreten wird:
|
|
</p>
|
|
<p>
|
|
die Menge der Top-Level-Fenster ist eben etwas anderes,
|
|
</p>
|
|
<p>
|
|
als die Menge der Tracks in der Timeline.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Erst nach einer Transformation wird daraus eine Menge von Strings
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513859299432" FOLDED="true" ID="ID_1668202627" MODIFIED="1525124214849" TEXT="Minimal-Forderungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1513859392644" ID="ID_368154471" MODIFIED="1513859402742" TEXT="Verhältnis von Original zu Expanded"/>
|
|
<node CREATED="1513859408489" ID="ID_1040511060" MODIFIED="1513859645105" TEXT="Expanded::yield muß kompatibel zu Original::yield sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1513859477704" FOLDED="true" ID="ID_1667428111" MODIFIED="1525124214849">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Expand-Funktor hat <i>einen</i> Rückgabe-Typ
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1513859590489" ID="ID_1305886859" MODIFIED="1513859654062" TEXT="das ist die stärkste Limitierung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1513859609438" ID="ID_1238327119" MODIFIED="1513859619487" TEXT="nicht Referenz-kompatibel">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1513859597904" ID="ID_35135467" MODIFIED="1513859623114" TEXT="Wert-Kopie-kompatibel">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513864109584" FOLDED="true" HGAP="58" ID="ID_363837528" MODIFIED="1561827469133" TEXT="gesucht ist...." VSHIFT="-10">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1513864121911" ID="ID_137778872" MODIFIED="1513864124330" TEXT="State-Core"/>
|
|
<node CREATED="1513864125110" FOLDED="true" ID="ID_102689213" MODIFIED="1525124214849" TEXT="(node&, depth)">
|
|
<node CREATED="1513864147403" ID="ID_1713142534" MODIFIED="1513864154086" TEXT="wegen Spezial-Behandlung"/>
|
|
<node CREATED="1513864155194" ID="ID_173512509" MODIFIED="1513864163093" TEXT="an die Kinder rankommen"/>
|
|
</node>
|
|
<node CREATED="1513864167704" FOLDED="true" ID="ID_1035755808" MODIFIED="1525124214849" TEXT="aktuelle-Kind-Iteratrion">
|
|
<node CREATED="1513864226776" ID="ID_744083786" MODIFIED="1513864232132" TEXT="fester Typ"/>
|
|
<node CREATED="1513864232744" ID="ID_856825900" MODIFIED="1513864245898" TEXT="variablel wegen Spezial-Behandlung"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1513864247318" ID="ID_522758461" MODIFIED="1513889050556" TEXT="Widerspruch">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513864213482" ID="ID_1903636205" MODIFIED="1513864220098" TEXT="keine zusätzliche Allokation">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513889026175" FOLDED="true" ID="ID_1644294386" MODIFIED="1561827469133" TEXT="Lösungs-Möglichkeiten">
|
|
<node CREATED="1513889102196" ID="ID_583394337" MODIFIED="1513890986515" TEXT="zweimal VTable">
|
|
<linktarget COLOR="#3c6aa0" DESTINATION="ID_583394337" ENDARROW="Default" ENDINCLINATION="313;-25;" ID="Arrow_ID_387579532" SOURCE="ID_1469033836" STARTARROW="None" STARTINCLINATION="309;-7;"/>
|
|
</node>
|
|
<node CREATED="1513889145935" FOLDED="true" ID="ID_1909411263" MODIFIED="1525124214849" TEXT="protokoll-basierter Iterator">
|
|
<node CREATED="1513889759051" ID="ID_1243725514" MODIFIED="1513889793242" TEXT="analog zu IterAdapter"/>
|
|
<node CREATED="1513889793879" ID="ID_1469033836" MODIFIED="1513890986515" TEXT="braucht aber Funktions-Zeiger">
|
|
<arrowlink COLOR="#3c6aa0" DESTINATION="ID_583394337" ENDARROW="Default" ENDINCLINATION="313;-25;" ID="Arrow_ID_387579532" STARTARROW="None" STARTINCLINATION="309;-7;"/>
|
|
</node>
|
|
<node CREATED="1513890876028" ID="ID_1863789470" MODIFIED="1513890944145" TEXT="oder gemeinsame Datenstruktur">
|
|
<arrowlink COLOR="#3b69a0" DESTINATION="ID_1440266471" ENDARROW="Default" ENDINCLINATION="299;33;" ID="Arrow_ID_141537663" STARTARROW="None" STARTINCLINATION="258;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513889813876" ID="ID_1440266471" MODIFIED="1513890944145" TEXT="Abstraktion via Datenstruktur">
|
|
<linktarget COLOR="#3b69a0" DESTINATION="ID_1440266471" ENDARROW="Default" ENDINCLINATION="299;33;" ID="Arrow_ID_141537663" SOURCE="ID_1863789470" STARTARROW="None" STARTINCLINATION="258;0;"/>
|
|
</node>
|
|
<node CREATED="1513890469187" FOLDED="true" ID="ID_572634197" MODIFIED="1525124214850" TEXT="Expander vor IterSource setzen">
|
|
<node CREATED="1513891132026" HGAP="30" ID="ID_1902519381" MODIFIED="1513891279623" TEXT="Stack of IterSources" VSHIFT="13">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1513891253569" FOLDED="true" ID="ID_972377662" MODIFIED="1525124214850" TEXT="Bauformen">
|
|
<node CREATED="1513891231085" ID="ID_1187042759" MODIFIED="1513891239903" TEXT="aus zwei TreeExplorern zusammengesetzt"/>
|
|
<node CREATED="1513891240587" ID="ID_1455962854" MODIFIED="1513891250606" TEXT="in das IterSource-Interface integriert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513891620064" FOLDED="true" HGAP="-78" ID="ID_393488703" MODIFIED="1561827469151" TEXT="Diskussion" VSHIFT="10">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1513891660578" FOLDED="true" ID="ID_1557026848" MODIFIED="1561827469133" TEXT="heterogener Baum">
|
|
<node CREATED="1513891666641" ID="ID_84511927" MODIFIED="1513891673373" TEXT="erzwingt Abstraktion"/>
|
|
<node CREATED="1513891674913" ID="ID_1300876479" MODIFIED="1513891696041" TEXT="erzgingt Platzhalter für "Position""/>
|
|
</node>
|
|
<node CREATED="1513891739920" FOLDED="true" ID="ID_1279255374" MODIFIED="1561827469133" TEXT="Meta-Datenstruktur == Reflection">
|
|
<node CREATED="1513891751766" ID="ID_1061575112" MODIFIED="1513891760585" TEXT="muß nicht per se schlecht sein"/>
|
|
<node CREATED="1513891771979" ID="ID_1279317536" MODIFIED="1513891793738">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>wenn</i> es sie gäbe <i>könnte</i> man sie hier nutzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513891804199" FOLDED="true" ID="ID_992579634" MODIFIED="1525124214857" TEXT="Ideen">
|
|
<node CREATED="1513891809406" ID="ID_397605243" MODIFIED="1513891818033" TEXT="GTK-Widget-Container"/>
|
|
<node CREATED="1513891818933" ID="ID_1781581570" MODIFIED="1513891823696" TEXT="GObject"/>
|
|
<node CREATED="1513891825708" ID="ID_1596653216" MODIFIED="1513891848885" TEXT="gui::model::Tangible"/>
|
|
</node>
|
|
<node CREATED="1513891876365" ID="ID_39114883" MODIFIED="1513891928397" TEXT="Knackpunkt: Struktur muß schon da sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt:
|
|
</p>
|
|
<p>
|
|
diese Struktur muß bereits beim Aufbauen des GUI
|
|
</p>
|
|
<p>
|
|
nebenbei mit aufgebaut werden, und über alle
|
|
</p>
|
|
<p>
|
|
mutierenden Aktionen hinweg automatisch konsistent bleiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#37417e" CREATED="1513891943436" ID="ID_1217718033" MODIFIED="1513891970693" TEXT="ist mir unsympatisch">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513892821757" ID="ID_812339590" MODIFIED="1513892833608" TEXT="Navigation allein erzwingt schon VTable"/>
|
|
<node CREATED="1513893044279" FOLDED="true" ID="ID_1996211433" MODIFIED="1561827469133" TEXT="Nav und IterSource verschmelzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513893027482" ID="ID_1061106814" MODIFIED="1513893042316" TEXT="minimales Design"/>
|
|
<node CREATED="1513893243100" FOLDED="true" ID="ID_622400006" MODIFIED="1525124214857" TEXT="Cursor-Interface">
|
|
<node CREATED="1513893512792" ID="ID_254466319" MODIFIED="1513893533977" TEXT="Iteration: next sibling"/>
|
|
<node CREATED="1513893536957" ID="ID_1831743270" MODIFIED="1513893551318" TEXT="Up: zum Vater"/>
|
|
<node CREATED="1513893552050" ID="ID_917117587" MODIFIED="1513893567173" TEXT="expand: Kind-Navigator"/>
|
|
<node CREATED="1513893589742" ID="ID_487266516" MODIFIED="1513893601664" TEXT="yield: Knoten-ID"/>
|
|
<node CREATED="1513893602348" ID="ID_1276818073" MODIFIED="1513893611167" TEXT="path: konstruiere UI-Coord"/>
|
|
</node>
|
|
<node CREATED="1513961350296" ID="ID_1067031793" MODIFIED="1513961358138" TEXT="TreeExplorer könnte sowas unterstützen..."/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1513893637863" FOLDED="true" ID="ID_1710637822" MODIFIED="1525124214857" TEXT="schön aber fragwürdig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513893645254" ID="ID_111789267" MODIFIED="1513893649713" TEXT="YAGNI"/>
|
|
<node CREATED="1513893653949" ID="ID_201919603" MODIFIED="1513893660896" TEXT="Up erfordert Backlink"/>
|
|
<node CREATED="1513893682521" ID="ID_1477689037" MODIFIED="1513893811288">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>möglicherwese</i> aber notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen
|
|
</p>
|
|
<p>
|
|
wenn ich mir heute so die Situation vorstelle,
|
|
</p>
|
|
<p>
|
|
könnte es darauf hinauslaufen, daß man das braucht.
|
|
</p>
|
|
<p>
|
|
Und zwar, zumindest die Eigenschaft, von gegebenem Element
|
|
</p>
|
|
<p>
|
|
die Koordinaten zu ermitteln.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das ist aber dann <i>pratkisch auch schon</i> eine "Up"-Funktion,
|
|
</p>
|
|
<p>
|
|
selbst wenn man sie nur indirekt implementiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513893841787" FOLDED="true" ID="ID_588599089" MODIFIED="1561827469133">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>vorläufige</i> MInimal-Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513893858089" ID="ID_1090821912" MODIFIED="1513893873067" TEXT="nur Expander nach außen ziehen"/>
|
|
<node CREATED="1513893873983" ID="ID_926734576" MODIFIED="1513893886449" TEXT="und fest als "Iterator"-Klasse definieren"/>
|
|
<node CREATED="1513894301013" FOLDED="true" ID="ID_1705515857" MODIFIED="1525124214858" TEXT="aktuell">
|
|
<node CREATED="1513893940206" ID="ID_1268073991" MODIFIED="1513893969869">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>bis jetzt</i> kommen wir ohne <b>Pos</b>-Abstraktion aus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1513893892581" ID="ID_447708501" MODIFIED="1513893978568">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das <b>Nav</b>-Interface könnte daraus entstehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513893916705" ID="ID_1837000174" MODIFIED="1513894531402" TEXT="als nested-Interface von LocationQuery"/>
|
|
</node>
|
|
<node COLOR="#177d54" CREATED="1513894057318" FOLDED="true" HGAP="19" ID="ID_1657702066" MODIFIED="1535891921460" TEXT="Weiterungen..." VSHIFT="28">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513894072292" ID="ID_550737261" MODIFIED="1513894085095" TEXT="die nächsten Schritte wären....">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513894141899" ID="ID_210080543" MODIFIED="1513894154501" TEXT="IterSource control-API umbauen"/>
|
|
<node CREATED="1513894156185" ID="ID_1081040201" MODIFIED="1513894165924" TEXT="spezielle StateCore für IterSource"/>
|
|
<node CREATED="1513894173999" ID="ID_1818551612" MODIFIED="1513894187080" TEXT="...damit das breiter API aus Funktoren zugänglich wird"/>
|
|
<node CREATED="1513894188668" ID="ID_910323938" MODIFIED="1513894200942" TEXT="TreeExplorer erkennt IterSource"/>
|
|
<node CREATED="1513894240293" ID="ID_1730534731" MODIFIED="1513894256719" TEXT="Expander kann expand-Funktor in VTable nutzen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513961595678" FOLDED="true" HGAP="101" ID="ID_66715685" MODIFIED="1561827482921" TEXT="Beschluß" VSHIFT="26">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513961667045" ID="ID_688351481" MODIFIED="1513962278992" TEXT="nur Verwenden von bestehenden Bausteinen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es werden jetzt keine weiteren Features für TreeExplorer gebaut....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513961683154" ID="ID_1803800382" MODIFIED="1513961693725" TEXT="Expander kommt vor das IterSource-Interface"/>
|
|
<node CREATED="1513962370870" ID="ID_1858133966" MODIFIED="1513962394590" TEXT="in einen komplett generischen Iterator-Typ"/>
|
|
<node CREATED="1514086892237" ID="ID_1709677569" MODIFIED="1514087030296" TEXT="depth() bleibt vorerst relativ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...mal sehen, ob wir jemals daran anstoßen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#62326e" DESTINATION="ID_1709677569" ENDARROW="Default" ENDINCLINATION="-209;-29;" ID="Arrow_ID_894748806" SOURCE="ID_1500554436" STARTARROW="Default" STARTINCLINATION="43;132;"/>
|
|
</node>
|
|
<node CREATED="1513961696753" FOLDED="true" ID="ID_1159003711" MODIFIED="1561827469151" TEXT="unschön aber zukunftsweisend...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1513961791716" FOLDED="true" ID="ID_996099359" MODIFIED="1561827469134" TEXT="zusätzliche Heap-Alloc für jedes Expand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist,
|
|
</p>
|
|
<p>
|
|
<i>zusätzlich</i> zu dem Eintrag im Stack,
|
|
</p>
|
|
<p>
|
|
der ohnehin selbst Heap-alloziert ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1513961961661" FOLDED="true" ID="ID_96700718" MODIFIED="1525124214858" TEXT="Ziel wäre...">
|
|
<node CREATED="1513962003719" ID="ID_432597650" MODIFIED="1513962013743" TEXT="nur ein shared_ptr"/>
|
|
<node CREATED="1513961972116" ID="ID_135060444" MODIFIED="1513961978462" TEXT="nur ein Heap-Block"/>
|
|
<node CREATED="1513961979106" ID="ID_1816600166" MODIFIED="1513961984765" TEXT="inilne+overflow"/>
|
|
</node>
|
|
<node CREATED="1513962016229" FOLDED="true" ID="ID_328900065" MODIFIED="1525124214858" TEXT="Relevanz später untersuchen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1513962043170" ID="ID_156284138" MODIFIED="1513962051989" TEXT="dazu muß das GUI weitgehend ausprogrammiert sein"/>
|
|
<node CREATED="1513962052808" ID="ID_1434970767" MODIFIED="1513962062555" TEXT="dann kann man das Nutzuns-Pattern extrahieren"/>
|
|
<node CREATED="1513962063639" ID="ID_1542094830" MODIFIED="1513962069898" TEXT="und dann druch Messung überprüfen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513961838174" ID="ID_579783999" MODIFIED="1513962463112" TEXT="Verhältnis der VTable-APIs noch unklar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Was ist <b>Nav</b> und was ist <b>Iteration-control</b>?
|
|
</p>
|
|
<p>
|
|
Ist es sinnvoll, beide in einem gemeinsamen API zu haben,
|
|
</p>
|
|
<p>
|
|
oder delegieren wir besser?
|
|
</p>
|
|
<p>
|
|
Was sind die Kosten dafür?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513961620603" FOLDED="true" ID="ID_1014293898" MODIFIED="1561827483827" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513962702097" FOLDED="true" ID="ID_1829231358" MODIFIED="1561827482921" TEXT="Iterator-Typ konstruieren">
|
|
<arrowlink COLOR="#1d3877" DESTINATION="ID_989478065" ENDARROW="Default" ENDINCLINATION="33;-151;" ID="Arrow_ID_1500458185" STARTARROW="Default" STARTINCLINATION="-102;2;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513966648491" FOLDED="true" ID="ID_558045889" MODIFIED="1561827469151" TEXT="Anforderungen">
|
|
<node CREATED="1513962999465" ID="ID_677650141" MODIFIED="1513963008827" TEXT="ist nicht mehr IterSource<String>::iterator"/>
|
|
<node CREATED="1513963010239" ID="ID_1755646553" MODIFIED="1513963023753" TEXT="baut auf einem Sub-Interface von IterSource auf"/>
|
|
<node CREATED="1513963030333" ID="ID_540171697" MODIFIED="1513963048414" TEXT="delegiert an den WrappedLumieraIterator für Konstruktion"/>
|
|
<node CREATED="1513963055921" ID="ID_598702105" MODIFIED="1513963075090" TEXT="exponiert das expandChildren()"/>
|
|
</node>
|
|
<node CREATED="1513966658753" FOLDED="true" ID="ID_1038653404" MODIFIED="1561827469151" TEXT="Konstrukt">
|
|
<node CREATED="1513966673608" FOLDED="true" ID="ID_343053579" MODIFIED="1561827469134" TEXT="auf IterExploreSource aufbauen?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1513966727648" ID="ID_538128057" MODIFIED="1513966744402" TEXT="das Interface wird in der Implementierung druchgreicht"/>
|
|
<node CREATED="1513966745134" ID="ID_1575558282" MODIFIED="1513966751273" TEXT="man kommt da nicht ohne weiteres ran"/>
|
|
<node CREATED="1513966752029" ID="ID_852127426" MODIFIED="1513966770086" TEXT="genau die expand() und depth() wird gar nicht gebraucht"/>
|
|
<node CREATED="1513966793087" ID="ID_1973470560" MODIFIED="1513966803775" TEXT="das wäre Implementation-reuse">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1513966770770" ID="ID_1037405328" MODIFIED="1513966791882" TEXT="wir bauen gar nicht darauf auf">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513966690757" FOLDED="true" ID="ID_335317868" MODIFIED="1561827469134" TEXT="direkt IterSource::iterator reimplementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513966814204" ID="ID_1477637829" MODIFIED="1513966818232" TEXT="ist halt lästig"/>
|
|
<node CREATED="1513966819268" ID="ID_725108588" MODIFIED="1513966823134" TEXT="hier aber wohl einfacher"/>
|
|
<node CREATED="1513966826779" ID="ID_806221726" MODIFIED="1513966853280" TEXT="könnte blueprint sein??">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
IterSource muß insgesamt besser erweiterbar werden....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513980929860" FOLDED="true" ID="ID_1710959906" MODIFIED="1561827469134" TEXT="Alternativen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1513980747077" FOLDED="true" ID="ID_458778699" MODIFIED="1525124214861" TEXT="IterExploreSource geschickt nutzen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1513980786024" ID="ID_906988400" MODIFIED="1513980803442" TEXT="front-End ist IterExploreSource, ohne Wenn und Aber"/>
|
|
<node CREATED="1513980816020" ID="ID_1544667042" MODIFIED="1513980839954">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Expander sitzt nun doch <i>dahinter,</i> in der Implementierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1513980949474" ID="ID_884281761" MODIFIED="1513980956209" TEXT="damit wieder zwei VTables">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513981063250" FOLDED="true" HGAP="29" ID="ID_1701586789" MODIFIED="1561827469151" TEXT="Builder" VSHIFT="7">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513981080616" ID="ID_75384138" MODIFIED="1513981107456" TEXT="bekommt TreeStructureNavigator *"/>
|
|
<node CREATED="1513981138280" ID="ID_878429069" MODIFIED="1513981146075" TEXT="baut darauf den IterSource::iterator"/>
|
|
<node CREATED="1513981147519" ID="ID_1838710944" MODIFIED="1513981198132" TEXT="setzt darauf einen TreeExplorer auf"/>
|
|
<node CREATED="1513981205567" ID="ID_1678344039" MODIFIED="1513981213954" TEXT="stattet diesen mit einem Expander aus"/>
|
|
<node CREATED="1513981215822" ID="ID_1059471923" MODIFIED="1513981236247" TEXT="welcher das TreeStructureNavigator-Interface nutzt"/>
|
|
<node CREATED="1513981274958" ID="ID_895258746" MODIFIED="1513981289179">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Ergebnis ist der <b>konkrete Iterator-Typ</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513962712192" FOLDED="true" ID="ID_357363842" MODIFIED="1561827482921" TEXT="festlegen, wo die VTable ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513978430367" ID="ID_616991569" MODIFIED="1513978446605" TEXT="Nav und Iter">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513978427353" ID="ID_110999881" MODIFIED="1513978443627" TEXT="TreeStructureNavigator">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513986023498" FOLDED="true" ID="ID_1413967372" MODIFIED="1561827482921" TEXT="Integration mit TreeExplorer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513986032290" FOLDED="true" ID="ID_1427647343" MODIFIED="1561827469151" TEXT="Problem: Zugang zur IterSource">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1513986054199" ID="ID_1239076586" MODIFIED="1513986063345" TEXT="bisher: protected im IterSource::iterator"/>
|
|
<node CREATED="1513986114902" ID="ID_1775644602" MODIFIED="1513986130220" TEXT=""riecht" nach einem generellen Problem">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1513986064509" FOLDED="true" ID="ID_1794003959" MODIFIED="1561827469134" TEXT="nun müßte man...">
|
|
<node CREATED="1513986085162" ID="ID_1791331544" MODIFIED="1513986090214" TEXT="von außen daran kommen"/>
|
|
<node CREATED="1513986090946" ID="ID_668980524" MODIFIED="1513986103340" TEXT="und auch noch downcasten auf TreeStructureNavigator"/>
|
|
</node>
|
|
<node CREATED="1513988678091" FOLDED="true" ID="ID_787175675" MODIFIED="1561827469134" TEXT="Pragmatismus-Trip">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1513988687617" ID="ID_1652718385" MODIFIED="1513988692411" TEXT="nicht jetzt lösen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513988694704" ID="ID_1570679085" MODIFIED="1513988710933" TEXT="das wäre ein Komplett-Umbau von IterSource">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#174e54" CREATED="1513988715838" ID="ID_1398933111" MODIFIED="1513989057765" TEXT="stattdessen: Vorentwurf auf die grüne Wiese">
|
|
<arrowlink COLOR="#1f9aa8" DESTINATION="ID_1242119956" ENDARROW="Default" ENDINCLINATION="87;-111;" ID="Arrow_ID_662359263" STARTARROW="None" STARTINCLINATION="-259;16;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="licq"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513988744665" FOLDED="true" HGAP="27" ID="ID_1242119956" MODIFIED="1561827469152" TEXT="vorläufige IterSource-Integration" VSHIFT="12">
|
|
<linktarget COLOR="#1f9aa8" DESTINATION="ID_1242119956" ENDARROW="Default" ENDINCLINATION="87;-111;" ID="Arrow_ID_662359263" SOURCE="ID_1398933111" STARTARROW="None" STARTINCLINATION="-259;16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513988930537" ID="ID_594152265" MODIFIED="1513992353318" TEXT="kann selbständig Iterator-Front-End bauen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513988952901" ID="ID_1668656742" MODIFIED="1513992356071" TEXT="dieses Front-End hat Zugang zum konkreten Sub-Interface">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1513988974179" ID="ID_900695722" MODIFIED="1513992358833" TEXT="Funktoren können dieses Sub-Interface akzeptieren und liefern">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513989030587" ID="ID_1529167083" MODIFIED="1514082163308" TEXT="TreeExplorer übernimmt / wrappt / packt aus">
|
|
<arrowlink COLOR="#659fa4" DESTINATION="ID_292438102" ENDARROW="Default" ENDINCLINATION="853;414;" ID="Arrow_ID_1802135668" STARTARROW="None" STARTINCLINATION="674;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513962765760" FOLDED="true" ID="ID_795911284" MODIFIED="1561827482921" TEXT="Demo-Impl mit GenNode-Tree">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514153936376" ID="ID_10587919" MODIFIED="1514153997161" TEXT="brauche neuen Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514153943993" ID="ID_1604846560" MODIFIED="1514153996307" TEXT="Sub-Interface dazwischenschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514153999177" FOLDED="true" ID="ID_1077665588" MODIFIED="1561827469152" TEXT="Child-Expansion">
|
|
<linktarget COLOR="#477889" DESTINATION="ID_1077665588" ENDARROW="Default" ENDINCLINATION="-191;0;" ID="Arrow_ID_1839260012" SOURCE="ID_1352163554" STARTARROW="None" STARTINCLINATION="277;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514257085356" FOLDED="true" ID="ID_1953942552" MODIFIED="1561827469134" TEXT="AUA: wieder Problem mit IterSource">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1514257106679" ID="ID_639495082" MODIFIED="1514257205927" TEXT="Design kaputt">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1514257118263" ID="ID_1711832615" MODIFIED="1514257127032" TEXT="nur der Iterator kennt "aktuelles Element""/>
|
|
<node CREATED="1514257127740" ID="ID_1443037774" MODIFIED="1514257143638" TEXT="via IterSource-Interface kommt man da nicht ran"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514257226775" ID="ID_813552503" MODIFIED="1514260900863" TEXT="workaround: mitlauschen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wire-Tap-Implementierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514261162634" FOLDED="true" ID="ID_551533507" MODIFIED="1561827469135" TEXT="funktioniert noch nicht...">
|
|
<linktarget COLOR="#bd4043" DESTINATION="ID_551533507" ENDARROW="Default" ENDINCLINATION="-143;214;" ID="Arrow_ID_327266711" SOURCE="ID_732935391" STARTARROW="None" STARTINCLINATION="86;-19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514291726371" ID="ID_126077844" MODIFIED="1514291734531" TEXT="war harmlos...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514291737914" ID="ID_480408923" MODIFIED="1514291802409" TEXT="kein grundsätzliches Problem">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514291747624" FOLDED="true" ID="ID_1328105733" MODIFIED="1525124214866" TEXT="nur ein logischer Programmier-Fehler">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1514291765589" ID="ID_1350779896" MODIFIED="1514291778528" TEXT="(tree,depth) ist eine Art Koordinate hier"/>
|
|
<node CREATED="1514291781156" ID="ID_1324645338" MODIFIED="1514291796321">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, depth ist <i>aktuelle</i> Tiefe!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941577099" FOLDED="true" ID="ID_394904963" MODIFIED="1533608413635" TEXT="Implementierung">
|
|
<linktarget COLOR="#653655" DESTINATION="ID_394904963" ENDARROW="Default" ENDINCLINATION="606;374;" ID="Arrow_ID_1674594671" SOURCE="ID_286375730" STARTARROW="None" STARTINCLINATION="863;77;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1510941687588" ID="ID_601914095" MODIFIED="1518487921065" TEXT="beispielhaft für GenNode umsetzen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941740069" ID="ID_1408571420" MODIFIED="1561827464929" TEXT="erweiterter ChildIter">
|
|
<arrowlink COLOR="#283b63" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="66;49;" ID="Arrow_ID_1521598219" STARTARROW="Default" STARTINCLINATION="94;-19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513560671819" ID="ID_989478065" MODIFIED="1514292039775" TEXT="Interface umstellen">
|
|
<linktarget COLOR="#1d3877" DESTINATION="ID_989478065" ENDARROW="Default" ENDINCLINATION="33;-151;" ID="Arrow_ID_1500458185" SOURCE="ID_1829231358" STARTARROW="Default" STARTINCLINATION="-102;2;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513560680562" ID="ID_634877617" MODIFIED="1514154023415" TEXT="TreeExplorer-Ausdrücke">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513560690440" ID="ID_122153660" MODIFIED="1514154026278" TEXT="Spezial-Behandlung für Perspektive">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514154062952" FOLDED="true" ID="ID_1352163554" MODIFIED="1561827483827" TEXT="Child-Expansion">
|
|
<arrowlink COLOR="#477889" DESTINATION="ID_1077665588" ENDARROW="Default" ENDINCLINATION="-191;0;" ID="Arrow_ID_1839260012" STARTARROW="None" STARTINCLINATION="277;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514260922259" FOLDED="true" HGAP="37" ID="ID_1286151530" MODIFIED="1561827482921" TEXT="Test..." VSHIFT="25">
|
|
<arrowlink COLOR="#525e89" DESTINATION="ID_113366695" ENDARROW="Default" ENDINCLINATION="125;-4;" ID="Arrow_ID_1734399897" STARTARROW="None" STARTINCLINATION="-10;85;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514261132830" ID="ID_1081488387" MODIFIED="1514292004576" TEXT="einfache Kinder">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514261125623" ID="ID_109806241" MODIFIED="1514261139062" TEXT="depth wird hochgezählt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514291864080" ID="ID_1213636271" MODIFIED="1514291872824" TEXT=""child exploration"">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514261117856" FOLDED="true" ID="ID_732935391" MODIFIED="1561827469152" TEXT="Perspektive: klappt nicht">
|
|
<arrowlink COLOR="#bd4043" DESTINATION="ID_551533507" ENDARROW="Default" ENDINCLINATION="-143;214;" ID="Arrow_ID_327266711" STARTARROW="None" STARTINCLINATION="86;-19;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1514291947981" ID="ID_271670446" MODIFIED="1514291954120" TEXT="kein wikliches Problem"/>
|
|
<node CREATED="1514291954732" ID="ID_1642614412" MODIFIED="1514291964167" TEXT="nur ein Logik-Fehler beim Coden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941748388" HGAP="38" ID="ID_209463158" MODIFIED="1561827464932" TEXT="Zustands-Layer" VSHIFT="1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514333524247" FOLDED="true" ID="ID_1136271037" MODIFIED="1561827483827" TEXT="Zustand umfaßt...">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1514333554411" ID="ID_1337747593" MODIFIED="1514333618358" TEXT="target (Pattern) const&"/>
|
|
<node CREATED="1514333705095" ID="ID_709075863" MODIFIED="1514898052783" TEXT="coverage (Builder)"/>
|
|
<node CREATED="1514333719613" FOLDED="true" ID="ID_256774095" MODIFIED="1561827482921" TEXT="navigator">
|
|
<node CREATED="1514333779158" ID="ID_1595920355" MODIFIED="1514333782280" TEXT="current ID"/>
|
|
<node CREATED="1514333767470" ID="ID_1575075730" MODIFIED="1514898072757" TEXT="depth"/>
|
|
</node>
|
|
<node CREATED="1514333825991" ID="ID_541168831" MODIFIED="1514898080652" TEXT="isSolution (implizit)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514338393316" FOLDED="true" ID="ID_1224653593" MODIFIED="1561827483827" TEXT="für jedes Element...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514338471073" FOLDED="true" ID="ID_1000829527" MODIFIED="1561827482921" STYLE="bubble" TEXT="target[depth] ==?">
|
|
<edge COLOR="#5b5ea6"/>
|
|
<node CREATED="1514338493135" FOLDED="true" ID="ID_1691944473" MODIFIED="1561827469152" TEXT="Ausgang wenn...">
|
|
<node CREATED="1514340242945" ID="ID_150794139" MODIFIED="1514908827230" TEXT="target zuende"/>
|
|
<node CREATED="1514340273349" ID="ID_1117812340" MODIFIED="1514908827230" TEXT="kein match"/>
|
|
<node BACKGROUND_COLOR="#e2f2c8" CREATED="1514340293010" ID="ID_108821287" MODIFIED="1514908880409">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist <i>keine </i>Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514338508292" FOLDED="true" ID="ID_1940839257" MODIFIED="1561827469152" TEXT="sonst">
|
|
<node CREATED="1514338551790" ID="ID_76414417" MODIFIED="1514908827232" TEXT="wildcard -> setzen"/>
|
|
<node CREATED="1514338597880" ID="ID_413282334" MODIFIED="1514908827232" TEXT="match -> setzen"/>
|
|
<node CREATED="1514341358818" ID="ID_1685868652" MODIFIED="1514908827233" TEXT="covered := depth()"/>
|
|
<node CREATED="1514338641730" ID="ID_878171387" MODIFIED="1514908827233" TEXT="scheduleExpansion()"/>
|
|
<node BACKGROUND_COLOR="#e2f2c8" CREATED="1514827974184" ID="ID_1774080036" MODIFIED="1514908873138">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist <i>partielle </i>Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514908723845" ID="ID_1051709102" MODIFIED="1514908732301" TEXT="filtern auf Lösung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514828322209" FOLDED="true" HGAP="447" ID="ID_868482472" MODIFIED="1561827483828" TEXT="Implementierung" VSHIFT="24">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514828365236" ID="ID_596741108" MODIFIED="1514828377582" TEXT="per Seiteneffekt auf den privaten Resolver-state"/>
|
|
<node CREATED="1514828408694" ID="ID_360791024" MODIFIED="1514828619139">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Ergebnis-Ausgabe </i>ist die jeweilige mögliche Coverage
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1514847720759" FOLDED="true" ID="ID_831358447" MODIFIED="1561827482922" TEXT="Struktur">
|
|
<node CREATED="1514847726158" FOLDED="true" ID="ID_460639525" MODIFIED="1561827469152" TEXT="wo brauche ich Builder?">
|
|
<node CREATED="1514847747979" ID="ID_710804937" MODIFIED="1514847782198" TEXT="target ist ein Builder, wird aber nicht geändert">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1514847769184" ID="ID_567857702" MODIFIED="1514847778011" TEXT="neue Coverage muß geändert werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514847804652" FOLDED="true" ID="ID_1778000574" MODIFIED="1561827469152" TEXT="sind Builder sinnvoll?">
|
|
<node CREATED="1514847810723" ID="ID_468954134" MODIFIED="1514847816622" TEXT="gegenwärtig nicht klar"/>
|
|
<node CREATED="1514847817306" ID="ID_417284469" MODIFIED="1514847833963" TEXT="UICoord soll immutable sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1514847837399" FOLDED="true" ID="ID_198877050" MODIFIED="1561827469135" TEXT="Problem Normalisierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1514847847398" ID="ID_1538721674" MODIFIED="1514847856905" TEXT="Builder-Funktionen können denormalisieren"/>
|
|
<node CREATED="1514847857748" ID="ID_1388054576" MODIFIED="1514847876837" TEXT="der Matching-Algo verläßt sich auf die Normalisierung">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1514847882601" ID="ID_1468209152" MODIFIED="1514847895570" TEXT="beim Verlassen eines Builders ist erneut zu normalisieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514847919164" FOLDED="true" ID="ID_1457973741" MODIFIED="1561827469152" TEXT="spezieller Manipulations-Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514847939937" ID="ID_1183828033" MODIFIED="1514847949844" TEXT="erlaubt punktweise Manipulation"/>
|
|
<node CREATED="1514847950576" ID="ID_1211653233" MODIFIED="1514850848636" TEXT="normalisiert automatisch beim Abholen des Ergebnisses"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514942333406" FOLDED="true" ID="ID_1235716633" MODIFIED="1561827482922" TEXT="Ankern unvollständiger Pfade">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514942350940" ID="ID_1658536334" MODIFIED="1515034261027" TEXT="erweitertes Verständnis von "Wildcard"">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515031418282" ID="ID_1390320369" MODIFIED="1515034265977" TEXT="Anker im Match berücksichtigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514942365034" ID="ID_1911438770" MODIFIED="1515034279431" TEXT="nebenbei Anker aktualisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514942372976" ID="ID_1541868169" MODIFIED="1515034395295" TEXT="feststellen, ob coverage real oder möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern wir nur eine (partielle) Lösung signalisieren,
|
|
</p>
|
|
<p>
|
|
wenn wir einen <i>direkten</i> Match erziehlen.
|
|
</p>
|
|
<p>
|
|
Ein wildcard-Match führt nur dazu, daß wir zu den Kindern absteigen,
|
|
</p>
|
|
<p>
|
|
aber zählt erst mal für sich nicht als Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508915741" ID="ID_974516393" MODIFIED="1518750409200">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Support für <i>elided</i> element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7e9da8" DESTINATION="ID_796216711" ENDARROW="Default" ENDINCLINATION="989;-91;" ID="Arrow_ID_925245331" STARTARROW="None" STARTINCLINATION="199;-5;"/>
|
|
<linktarget COLOR="#91a7b5" DESTINATION="ID_974516393" ENDARROW="Default" ENDINCLINATION="-759;53;" ID="Arrow_ID_862004765" SOURCE="ID_140988955" STARTARROW="None" STARTINCLINATION="1590;41;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1514897795054" FOLDED="true" ID="ID_1126804251" MODIFIED="1561827482922" TEXT="Erweiterung: verschiedne Filter">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1515034405447" ID="ID_1908721517" MODIFIED="1515034409410" TEXT="YAGNI"/>
|
|
<node CREATED="1515034414286" ID="ID_216901407" MODIFIED="1515034430396" TEXT="kann mir jetzt keinen wirklichen Nutzen dafür vorstellen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514339655585" FOLDED="true" ID="ID_20763657" MODIFIED="1561827483828" TEXT="brauche">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1514339665248" ID="ID_1142507602" MODIFIED="1514339776889" TEXT="low-level-Operation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
nur für internen Gebrauch
|
|
</li>
|
|
<li>
|
|
protected im Builder
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514339673519" FOLDED="true" ID="ID_1697551113" MODIFIED="1561827482922" TEXT="writeAt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514339689469" ID="ID_686921797" MODIFIED="1514339694112" TEXT="erweitert bei Bedarf"/>
|
|
<node CREATED="1514339695220" ID="ID_1819447572" MODIFIED="1514339700103" TEXT="überschreibt Position"/>
|
|
<node CREATED="1514339700955" ID="ID_503690023" MODIFIED="1514339717876" TEXT="kürzt/ändert sonst nix"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514746187370" FOLDED="true" ID="ID_989083906" MODIFIED="1561827482923" TEXT="Problem der partiellen Covfefe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514746268280" FOLDED="true" ID="ID_1650861625" MODIFIED="1561827469152" TEXT="totale Coverage ist einfach">
|
|
<node CREATED="1514746278542" ID="ID_638094416" MODIFIED="1514746296223">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösungen müssen
|
|
</p>
|
|
<p>
|
|
am Ende des Patterns liegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514746306619" ID="ID_1050824210" MODIFIED="1514746324227" TEXT="überall partielle Lösungen möglich"/>
|
|
<node CREATED="1514746345078" ID="ID_1469851869" MODIFIED="1514746354935" TEXT="wir wissen nicht, ob expand überhaupt geht"/>
|
|
<node CREATED="1514746367418" ID="ID_1714254434" MODIFIED="1514827781975" TEXT="Lösungsidee: partielle Lösungen filtern">
|
|
<arrowlink COLOR="#426785" DESTINATION="ID_43243557" ENDARROW="Default" ENDINCLINATION="156;-113;" ID="Arrow_ID_977247001" STARTARROW="None" STARTINCLINATION="-109;6;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1514747333011" FOLDED="true" ID="ID_1334730598" MODIFIED="1561827469152" TEXT="Rekursion fällt weg">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1514747381652" ID="ID_798538712" MODIFIED="1514747385435" TEXT="super genital">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1514747405345" ID="ID_1406501979" MODIFIED="1514747435945" TEXT="jetzt strukturell lazy">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514746923713" FOLDED="true" ID="ID_1928999977" MODIFIED="1561827482923" TEXT="scheduleExpansion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514746932144" ID="ID_1456732951" MODIFIED="1514897708074" TEXT="neue TreeExplorer-Operation"/>
|
|
<node CREATED="1514746940111" ID="ID_899254883" MODIFIED="1514897708074" TEXT="sieht eine child-Expansion bei nächster Iteration vor">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514746959580" ID="ID_836777766" MODIFIED="1514897708074" TEXT="eigener Layer notwendig, mit bool-Flag">
|
|
<arrowlink COLOR="#455b75" DESTINATION="ID_108671176" ENDARROW="Default" ENDINCLINATION="-973;135;" ID="Arrow_ID_1758556486" STARTARROW="None" STARTINCLINATION="959;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941754211" HGAP="36" ID="ID_996085388" MODIFIED="1561827464963" TEXT="Filter-Layer" VSHIFT="-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514747460122" ID="ID_1735380227" MODIFIED="1514908757875" TEXT="fischt nach tatsächlichen Lösungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514747470624" ID="ID_43243557" MODIFIED="1514827781975" TEXT="ermöglicht partielle und maximale Lösungen">
|
|
<linktarget COLOR="#426785" DESTINATION="ID_43243557" ENDARROW="Default" ENDINCLINATION="156;-113;" ID="Arrow_ID_977247001" SOURCE="ID_1714254434" STARTARROW="None" STARTINCLINATION="-109;6;"/>
|
|
</node>
|
|
<node CREATED="1514747496973" FOLDED="true" ID="ID_1992822141" MODIFIED="1561827483828" TEXT="Fälle">
|
|
<linktarget COLOR="#7e90a1" DESTINATION="ID_1992822141" ENDARROW="Default" ENDINCLINATION="0;56;" ID="Arrow_ID_26195276" SOURCE="ID_1556354374" STARTARROW="Default" STARTINCLINATION="-20;-69;"/>
|
|
<node CREATED="1514747500948" ID="ID_849508712" MODIFIED="1515031494705" TEXT="erste totale Lösung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1514747506516" ID="ID_1823650567" MODIFIED="1515031497729" TEXT="alle totalen Lösungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1514747511683" ID="ID_1711746734" MODIFIED="1515031538639" TEXT="erste maximale partielle Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514747534880" ID="ID_668507058" MODIFIED="1515031542774" TEXT="alle maximalen partiellen Lösungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1514747542535" FOLDED="true" ID="ID_1475644253" MODIFIED="1561827482923" TEXT="alle lokal maximalen partiellen Lösungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1514747562436" ID="ID_1216946339" MODIFIED="1514747569143" TEXT="am Ende einer Glückssträne"/>
|
|
<node CREATED="1514747652752" ID="ID_694825695" MODIFIED="1514747659603" TEXT="etwas kniffelig zu implementieren"/>
|
|
<node CREATED="1514747694763" ID="ID_1088990348" MODIFIED="1514747707037" TEXT="letztlich ähnlich wie globale Maximums-Suche"/>
|
|
<node CREATED="1514747709400" ID="ID_556979975" MODIFIED="1514747724946" TEXT="lediglich das Maximum wird zurückgesetzt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829169777" HGAP="32" ID="ID_331008637" MODIFIED="1561827464965" TEXT="Integration" VSHIFT="10">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514829220907" FOLDED="true" ID="ID_1488508113" MODIFIED="1561827483828" TEXT="zunächst Algo für partielle Coverage bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514829338427" ID="ID_623381151" MODIFIED="1515034463168" TEXT="Zustandstyp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1514829343538" FOLDED="true" ID="ID_61753442" MODIFIED="1561827482923" TEXT="Transformer auf Zustand">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1514850791535" ID="ID_1339395363" MODIFIED="1514850794763" TEXT="nicht notwendig"/>
|
|
<node CREATED="1514850795678" ID="ID_497352305" MODIFIED="1514850803482" TEXT="Zustand per Seiteneffekt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829349585" ID="ID_1389488008" MODIFIED="1515034463168" TEXT="Algo-Kern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829353681" ID="ID_62480447" MODIFIED="1515034463168" TEXT="einfachster Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829412249" FOLDED="true" ID="ID_1641757769" MODIFIED="1561827483828" TEXT="Einbindung Resolution-State">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514829452692" ID="ID_1692090746" MODIFIED="1515034463169" TEXT="nested Class">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829466506" ID="ID_1652951449" MODIFIED="1515034463169" TEXT="low-level writeAt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829511716" ID="ID_747113559" MODIFIED="1515034463169" TEXT="Pipeline-Builder wie?">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829532945" ID="ID_1664484116" MODIFIED="1515034463169" TEXT="Ergebnis-Abruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1514829238960" FOLDED="true" ID="ID_1556354374" MODIFIED="1576282358121" TEXT="Varianten definieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
YAGNI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7e90a1" DESTINATION="ID_1992822141" ENDARROW="Default" ENDINCLINATION="0;56;" ID="Arrow_ID_26195276" STARTARROW="Default" STARTINCLINATION="-20;-69;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1514942095070" ID="ID_815761690" MODIFIED="1515034463169" TEXT="default: ermitteln der maximalen partiellen Coverage">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1514942111347" ID="ID_1991949921" MODIFIED="1515034463169" TEXT="die maximale Lösung ist totale Coverage, wenn möglich">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1514942171091" ID="ID_1193370362" MODIFIED="1515034463169" TEXT="später/bei Bedarf: alle Lösungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1515034212096" ID="ID_1153983253" MODIFIED="1515034463169" TEXT="vermutlich garnicht notwendig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514848454621" FOLDED="true" ID="ID_472406160" MODIFIED="1561827483828" TEXT="std::swap für UICoord">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514848818421" ID="ID_26529397" MODIFIED="1515206142953" TEXT="vermutlich (fast) nix zu tun">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die Standard-Implementierung von std::swap macht einen Dreiecks-Move
|
|
</li>
|
|
<li>
|
|
wir haben effiziente Move-Konstruktoren
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514848861831" FOLDED="true" ID="ID_297570158" MODIFIED="1561827482923" TEXT="noexcept() bedenken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515206011718" ID="ID_1572220372" MODIFIED="1515206130684" TEXT="std::Array hat impliziten move-ctor">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515206027308" ID="ID_1973328661" MODIFIED="1515206127344" TEXT="muß Konstruktor von lib::Literal noexcept machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515206107418" ID="ID_97679310" MODIFIED="1515206126419" TEXT="move-Ctors von Extension (für PathArray) noexcept machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514848874005" ID="ID_751821458" MODIFIED="1515034463169" TEXT="PathArray: move effizienter als swap">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514829244384" FOLDED="true" ID="ID_174527898" MODIFIED="1561827483828" TEXT="API umstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514942071848" ID="ID_642968204" MODIFIED="1515034463169" TEXT="totale Coverage wird default">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514942216013" ID="ID_1147733516" MODIFIED="1515034537518" TEXT="Prädikate spiegeln stets den Zustand der UI-Coord">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und nicht den <i>möglichen</i> Zustand.
|
|
</p>
|
|
<p>
|
|
Denn für letzteren gibt es die "canXX"-Prädikate
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514943888969" ID="ID_1634332467" MODIFIED="1515034463169" TEXT="möglichen Anker nebenbei ermitteln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1510941766817" HGAP="13" ID="ID_1117346518" MODIFIED="1561827464970" TEXT="Testfälle" VSHIFT="29">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1513477873206" ID="ID_939423021" MODIFIED="1518487921065" TEXT="definieren was abzudecken ist...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513478153511" ID="ID_1826394146" MODIFIED="1518487921065" TEXT="bisherige ChildIter-Testfälle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514260998192" ID="ID_113366695" MODIFIED="1518487921065" TEXT="einmal child-Expansion">
|
|
<linktarget COLOR="#525e89" DESTINATION="ID_113366695" ENDARROW="Default" ENDINCLINATION="125;-4;" ID="Arrow_ID_1734399897" SOURCE="ID_1286151530" STARTARROW="None" STARTINCLINATION="-10;85;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#3b5a89" CREATED="1514292065333" FOLDED="true" ID="ID_1133433583" MODIFIED="1576282358120" TEXT="Frage: expliziter Test für path resolution?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
macht es Sinn, dafür einen expliziten Testfall zu konstruieren,
|
|
</p>
|
|
<p>
|
|
oder verfangen wir uns da sofort zu sehr in der Implementierungs-Technik?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1514329257785" ID="ID_1871812757" MODIFIED="1518487921065" TEXT="Nein">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1514329280718" ID="ID_674722968" MODIFIED="1518487921065" TEXT="sonst müssen wir die BlackBox öffnen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1514329261217" ID="ID_1909490994" MODIFIED="1518487921065" TEXT="die Testfälle für Coverage-Mutation genügen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514329328840" FOLDED="true" HGAP="35" ID="ID_1362494392" MODIFIED="1561827483829" TEXT="Abzudecken ist...." VSHIFT="4">
|
|
<linktarget COLOR="#715b79" DESTINATION="ID_1362494392" ENDARROW="Default" ENDINCLINATION="-578;-16;" ID="Arrow_ID_1072715196" SOURCE="ID_1751192686" STARTARROW="None" STARTINCLINATION="477;0;"/>
|
|
<linktarget COLOR="#4b5c8d" DESTINATION="ID_1362494392" ENDARROW="Default" ENDINCLINATION="398;572;" ID="Arrow_ID_82261909" SOURCE="ID_1688800613" STARTARROW="None" STARTINCLINATION="1404;115;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1514329411197" FOLDED="true" ID="ID_1637267494" MODIFIED="1561827482923" TEXT="Trivial-Fall: bestehenden Pfad finden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514329441136" ID="ID_359779455" MODIFIED="1518487921065" TEXT="mit unvollständiger Coverage">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329450807" ID="ID_211306404" MODIFIED="1518487921065" TEXT="mit Überhang">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515114713029" FOLDED="true" ID="ID_424458820" MODIFIED="1561827482923" TEXT="Ankern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514745345018" ID="ID_1229106293" MODIFIED="1518487921065" TEXT="fehlender Anker allein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515114721228" ID="ID_1329702278" MODIFIED="1518487921065" TEXT="fehlender Anker">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515114740273" FOLDED="true" ID="ID_224432926" MODIFIED="1561827482923" TEXT="interpolieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514329498169" ID="ID_259096801" MODIFIED="1518487921065" TEXT="einfache Lücke schließen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329504776" ID="ID_1411396073" MODIFIED="1518487921065" TEXT="doppelte Lücke schließen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329542594" ID="ID_959715297" MODIFIED="1518487921065" TEXT="fehlenden Anker interpolieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514745294579" ID="ID_576780085" MODIFIED="1518487921065" TEXT="fehlender Anker und folgende Lücke">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329555505" ID="ID_1508437078" MODIFIED="1518487921065" TEXT="fehlender Anker plus zweite Lücke">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517509311733" ID="ID_796216711" MODIFIED="1518750402160" TEXT="Anker+elided plus Lücke schließen">
|
|
<linktarget COLOR="#7e9da8" DESTINATION="ID_796216711" ENDARROW="Default" ENDINCLINATION="989;-91;" ID="Arrow_ID_925245331" SOURCE="ID_974516393" STARTARROW="None" STARTINCLINATION="199;-5;"/>
|
|
<linktarget COLOR="#4b5cab" DESTINATION="ID_796216711" ENDARROW="Default" ENDINCLINATION="-145;942;" ID="Arrow_ID_570641462" SOURCE="ID_1542036736" STARTARROW="None" STARTINCLINATION="383;78;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517509541382" FOLDED="true" ID="ID_1722401650" MODIFIED="1561827469153">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
realer Pfad endet mit elided <i>nach</i> Wildcard
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518752249648" ID="ID_221401224" MODIFIED="1518752257211" TEXT="erst wollte ich das ausschließen"/>
|
|
<node CREATED="1518752257871" ID="ID_1394674174" MODIFIED="1518752269436" TEXT="denke jetzt aber, das soll so sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517509325755" ID="ID_208496330" MODIFIED="1518758436086" TEXT="Anker+elided gilt als partial coverage">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329861519" FOLDED="true" ID="ID_946875811" MODIFIED="1561827482924" TEXT="Scheitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514329465117" FOLDED="true" ID="ID_1304144230" MODIFIED="1561827469153" TEXT="trailing Wildcards scheitern">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1515120863655" ID="ID_1222552441" MODIFIED="1518487921065" TEXT="werden stets schon vom Konstrukor bereinigt"/>
|
|
<node COLOR="#338800" CREATED="1515120874318" ID="ID_282902710" MODIFIED="1518487921065">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann jedoch demonstrieren,
|
|
</p>
|
|
<p>
|
|
daß der Algorithmus solche Lösungen verwirft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329890564" ID="ID_723199137" MODIFIED="1518487921065" TEXT="realer Pfad endet vor Wildcards">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329901562" ID="ID_1644217459" MODIFIED="1518487921065" TEXT="realer Pfad endet bündig mit Wildcards">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329925895" ID="ID_257945525" MODIFIED="1518487921066" TEXT="mismatch auf erstem festen element">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329932501" ID="ID_1190347841" MODIFIED="1518487921066" TEXT="mismatch direkt hinter zweiter Lücke">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514330003204" ID="ID_443318342" MODIFIED="1518487921066" TEXT="mismatch wg. verschobenem (matchendem) Element">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514330049166" ID="ID_1096135763" MODIFIED="1518487921066" TEXT="Ankern scheitert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329636838" FOLDED="true" ID="ID_815146070" MODIFIED="1561827482924" TEXT="Lösungs-Auswahl">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514329649868" ID="ID_1490593624" MODIFIED="1518487921066" TEXT="erste von zwei äquivalenten Lösungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329715859" ID="ID_734262382" MODIFIED="1518487921066" TEXT="größere Coverage durch längeres, festes Postifix">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329773739" ID="ID_1790993462" MODIFIED="1518487921066" TEXT="größere Lösung wird später gefunden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329784090" ID="ID_976931684" MODIFIED="1518487921066" TEXT="größere Lösung als mittlere von dreien">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514329806999" ID="ID_787741094" MODIFIED="1518487921066" TEXT="größte Lösung zuerst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518051827562" FOLDED="true" ID="ID_126260279" MODIFIED="1561827482924" TEXT="partielle coverage mit Rest">
|
|
<linktarget COLOR="#647a94" DESTINATION="ID_126260279" ENDARROW="Default" ENDINCLINATION="-70;102;" ID="Arrow_ID_1703739591" SOURCE="ID_1400256094" STARTARROW="None" STARTINCLINATION="417;-7;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518051858813" ID="ID_712764658" MODIFIED="1518487921066" TEXT="Erfolg: alles explizit, teilweise gecovert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518051877651" ID="ID_931862394" MODIFIED="1518487921066" TEXT="Erfolg: Lücke schließen, Rest erhalten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518051909942" ID="ID_1891019118" MODIFIED="1518487921066" TEXT="Scheitern: kann Lücke nicht schließen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518051925316" ID="ID_766944591" MODIFIED="1518487921066" TEXT="Scheitern: Rest enthält noch Wildcards">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508540835505" ID="ID_191493714" MODIFIED="1561827464979" TEXT="Zustand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514748438984" ID="ID_84241950" MODIFIED="1518487921066" TEXT="reflektiert letzte Lösung"/>
|
|
<node CREATED="1514748445520" ID="ID_728061293" MODIFIED="1518487921066" TEXT="*this = move (Coverage)"/>
|
|
<node COLOR="#338800" CREATED="1514748450687" ID="ID_919694647" MODIFIED="1533608413663" TEXT="default: total">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1514748463645" ID="ID_2814761" MODIFIED="1518487921066" TEXT="TODO: ändern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514748505488" ID="ID_947047856" MODIFIED="1576282358120" TEXT="TODO: API umstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
neue Einsicht 31.12.17
|
|
</p>
|
|
<p>
|
|
totale Coverage ist das, was man naiverweise erwartet.
|
|
</p>
|
|
<p>
|
|
Also sollte <i>das</i> auf dem API der default sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518052051947" ID="ID_1272905286" MODIFIED="1561827464979" TEXT="coverPartially">
|
|
<linktarget COLOR="#50546a" DESTINATION="ID_1272905286" ENDARROW="Default" ENDINCLINATION="394;1164;" ID="Arrow_ID_396720500" SOURCE="ID_1447232325" STARTARROW="None" STARTINCLINATION="1558;-33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518052100828" ID="ID_1400256094" MODIFIED="1518143014344" TEXT="funktioniert analog zu cover()">
|
|
<arrowlink COLOR="#647a94" DESTINATION="ID_126260279" ENDARROW="Default" ENDINCLINATION="-70;102;" ID="Arrow_ID_1703739591" STARTARROW="None" STARTINCLINATION="417;-7;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518052123401" ID="ID_969568669" MODIFIED="1518143010646" TEXT="übernimmt überschüssigen Rest">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518052149982" ID="ID_1099521506" MODIFIED="1518143007944" TEXT="sicherstellen, daß keine Wildcards verbleiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515451105808" ID="ID_1323377531" MODIFIED="1561827464980" TEXT="extend">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515451117055" ID="ID_602743049" MODIFIED="1515451126326" TEXT="durch explizit gegebenes Suffix">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515451127221" ID="ID_130067342" MODIFIED="1515460212289" TEXT="durch (partielle) UI-Coord spec">
|
|
<linktarget COLOR="#4f6f95" DESTINATION="ID_130067342" ENDARROW="Default" ENDINCLINATION="544;89;" ID="Arrow_ID_992203487" SOURCE="ID_1736775031" STARTARROW="None" STARTINCLINATION="704;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515455194222" ID="ID_1550640486" MODIFIED="1533608413663" TEXT="brauche (nun doch) overwrite">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1515455204572" ID="ID_538708318" MODIFIED="1515455215023" TEXT="im UI-Coord-Builder ansiedeln"/>
|
|
<node CREATED="1515455215779" ID="ID_1744879837" MODIFIED="1515455225131" TEXT="protected....">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515455238808" ID="ID_1864948105" MODIFIED="1515460226143" TEXT="Fehlerbehandlung: Überlapp finden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508538883715" FOLDED="true" ID="ID_506584428" MODIFIED="1531584013560" TEXT="Basis: LocationQuery">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508538979935" ID="ID_1139910958" MODIFIED="1576282358119" TEXT="immer explizit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt: keine Wildcards, keine pseudo-Specs (currentWindow)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1508539089208" ID="ID_1071949477" MODIFIED="1508539131769" TEXT="Query">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1508619321957" ID="ID_1269390045" MODIFIED="1508717810127" TEXT="anchor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508619329420" ID="ID_360997488" MODIFIED="1508619334447" TEXT="in: expliziter Pfad"/>
|
|
<node CREATED="1508619335131" ID="ID_327874233" MODIFIED="1576282358119" TEXT="out: Anker-Literal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zweck ist vor allem, meta-Specs wie firstWindow, currentWindow aufzulösen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539108398" ID="ID_681619275" MODIFIED="1509319949242" TEXT="coverage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508539968020" ID="ID_64225559" MODIFIED="1508539972951" TEXT="in: expliziter Pfad"/>
|
|
<node CREATED="1508539973587" ID="ID_822140715" MODIFIED="1508539984350" TEXT="out: Tiefe(Zahl)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1508539115533" ID="ID_1048456515" MODIFIED="1509319964032" TEXT="child Iteration">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508539986290" ID="ID_821465952" MODIFIED="1508539992221" TEXT="in: expliziter Pfad"/>
|
|
<node CREATED="1508539992944" ID="ID_1384353532" MODIFIED="1509319961089" TEXT="out: IterSource<Literal>"/>
|
|
<node CREATED="1514330179052" ID="ID_1033437899" MODIFIED="1514330186823" TEXT="mit expandChildren()-Operation"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509319992204" HGAP="60" ID="ID_258976142" MODIFIED="1576282358118" TEXT="prototypische Implementierung...." VSHIFT="21">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...verwendet einen GenNode-Tree
|
|
</p>
|
|
<p>
|
|
als Repräsentation des real-existierenden UI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506957414370" ID="ID_848105210" MODIFIED="1518487921066">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Integration ViewLocator
|
|
</p>
|
|
<p>
|
|
Resolver / Navigator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#3f4b87" DESTINATION="ID_848105210" ENDARROW="Default" ENDINCLINATION="-1260;542;" ID="Arrow_ID_1760927309" SOURCE="ID_1256149179" STARTARROW="None" STARTINCLINATION="1244;-591;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1515884080567" ID="ID_1610510897" MODIFIED="1518487921066" TEXT="Frage der Abhängigkeit">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1515884093053" ID="ID_578386223" MODIFIED="1518487921066" TEXT="könnte zyklisch sein">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1515884156717" ID="ID_1719646750" MODIFIED="1518487921066" TEXT="ViewLocator">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1515884167067" ID="ID_252275651" MODIFIED="1518487921066" TEXT="Einzel-Zugang"/>
|
|
<node CREATED="1515884183937" ID="ID_1146786067" MODIFIED="1518487921066" TEXT="explizit per Typ"/>
|
|
<node CREATED="1515884193464" ID="ID_680693474" MODIFIED="1533608413664">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber auch: <b>Resolver</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#3b6680" DESTINATION="ID_680693474" ENDARROW="Default" ENDINCLINATION="-178;8;" ID="Arrow_ID_1157808975" SOURCE="ID_1356241564" STARTARROW="None" STARTINCLINATION="98;0;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1515884215165" ID="ID_1855078495" MODIFIED="1518487921066" TEXT="baut auf DSL auf"/>
|
|
<node CREATED="1515884220428" ID="ID_513230162" MODIFIED="1518487921066" TEXT="Struktur-Regeln"/>
|
|
<node CREATED="1515884235658" ID="ID_1028909961" MODIFIED="1518487921066" TEXT="finden oder zeugen"/>
|
|
</node>
|
|
<node CREATED="1515885720655" ID="ID_1092683882" MODIFIED="1533608413665" TEXT="bündelt low-level-Zugang">
|
|
<linktarget COLOR="#8c98a0" DESTINATION="ID_1092683882" ENDARROW="Default" ENDINCLINATION="-155;0;" ID="Arrow_ID_1761525173" SOURCE="ID_150080053" STARTARROW="None" STARTINCLINATION="-156;6;"/>
|
|
<node CREATED="1515885728374" ID="ID_152777185" MODIFIED="1533685424812" TEXT="Bezug auf GlobalCtx">
|
|
<node CREATED="1515885839951" ID="ID_123309845" MODIFIED="1518487921066" TEXT="für WindowLocator"/>
|
|
<node CREATED="1515885847767" ID="ID_1781347382" MODIFIED="1518487921066" TEXT="für PanelManager"/>
|
|
<node CREATED="1515885855014" ID="ID_1634512088" MODIFIED="1518487921066" TEXT="für LocationQuery">
|
|
<arrowlink COLOR="#8c98a0" DESTINATION="ID_150080053" ENDARROW="Default" ENDINCLINATION="198;0;" ID="Arrow_ID_1806083846" STARTARROW="None" STARTINCLINATION="10;48;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515885751787" ID="ID_1669926039" MODIFIED="1518487921066" TEXT="indirekt zyklisch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1515885762754" ID="ID_657098401" MODIFIED="1576282358118" TEXT="ist OK">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Regel ist:
|
|
</p>
|
|
<p>
|
|
Bei zyklischen Abhängigkeiten erfolgt der Ringschluß
|
|
</p>
|
|
<p>
|
|
an einer Stelle über eine allgemeine Abstraktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515884935318" ID="ID_1231381049" MODIFIED="1518487921066" TEXT="Navigator">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1515884949013" ID="ID_562171495" MODIFIED="1518487921066" TEXT="nur lesend"/>
|
|
<node CREATED="1515884972018" ID="ID_105092644" MODIFIED="1518487921066" TEXT="leistet Baum-Abstraktion"/>
|
|
<node CREATED="1515884955620" ID="ID_1330012545" MODIFIED="1518487921066" TEXT="manipuliert Zustand, nicht Struktur"/>
|
|
<node CREATED="1515885006181" ID="ID_150080053" MODIFIED="1518487921066">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
implementiert <b>LocationQuery</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8c98a0" DESTINATION="ID_1092683882" ENDARROW="Default" ENDINCLINATION="-155;0;" ID="Arrow_ID_1761525173" STARTARROW="None" STARTINCLINATION="-156;6;"/>
|
|
<linktarget COLOR="#8c98a0" DESTINATION="ID_150080053" ENDARROW="Default" ENDINCLINATION="198;0;" ID="Arrow_ID_1806083846" SOURCE="ID_1634512088" STARTARROW="None" STARTINCLINATION="10;48;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515891291587" HGAP="42" ID="ID_1000521247" MODIFIED="1518487921066" TEXT="Design" VSHIFT="11">
|
|
<node CREATED="1515891297466" ID="ID_1885414397" MODIFIED="1518487921066" TEXT="Komponenten sind nach Themen geschnitten"/>
|
|
<node CREATED="1515891308057" ID="ID_89499528" MODIFIED="1518487921066" TEXT="Zyklen werden über abstrakte Interfaces geführt"/>
|
|
<node CREATED="1515891349731" ID="ID_1663035567" MODIFIED="1518487921066" TEXT="ViewLocator "generiert nebenbei" die DSL-Token">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506175097367" ID="ID_1442345755" MODIFIED="1561827465011" TEXT="ViewSpec-DSL">
|
|
<arrowlink COLOR="#b45c5a" DESTINATION="ID_686917529" ENDARROW="Default" ENDINCLINATION="-468;-196;" ID="Arrow_ID_1955094318" STARTARROW="None" STARTINCLINATION="360;85;"/>
|
|
<linktarget COLOR="#6a8499" DESTINATION="ID_1442345755" ENDARROW="Default" ENDINCLINATION="-1029;85;" ID="Arrow_ID_1191206769" SOURCE="ID_1844877136" STARTARROW="None" STARTINCLINATION="426;-63;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1515877499720" HGAP="-59" ID="ID_1283126436" MODIFIED="1518487921066" TEXT="Basis" VSHIFT="29">
|
|
<node CREATED="1515877527300" ID="ID_1356241564" MODIFIED="1518487921066" TEXT="ist Teil des ViewLocators">
|
|
<arrowlink COLOR="#3b6680" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-269;-228;" ID="Arrow_ID_408957918" STARTARROW="Default" STARTINCLINATION="-858;0;"/>
|
|
<arrowlink COLOR="#3b6680" DESTINATION="ID_680693474" ENDARROW="Default" ENDINCLINATION="-178;8;" ID="Arrow_ID_1157808975" STARTARROW="None" STARTINCLINATION="98;0;"/>
|
|
</node>
|
|
<node CREATED="1515877545642" ID="ID_1723275956" MODIFIED="1518487921066" TEXT="lebt in der Implementierung"/>
|
|
<node CREATED="1515877577414" ID="ID_664776417" MODIFIED="1576282358117" TEXT="Bausteine sind sichtbar...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...als Namespace-globale Variable mit externer Linkage
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1523117792890" ID="ID_1972679538" MODIFIED="1576282358117" TEXT="Effizienz mäßig/unkritisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ein Lookup-Vorgang ist schon ehr aufwendig,
|
|
</p>
|
|
<p>
|
|
jedoch harmlos im Vergleich zu einer einzigen Frame-Berechnung.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
im ersten Schritt machen wir eine Tiefensuche potentiell über die ganze UI-Topologie
|
|
</li>
|
|
<li>
|
|
im zweiten Schritt wiederholen wir noch mal den Abstiegspfad zur Lösung des ersten Schrittes
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Grundsätzlich gilt hier die Einschätzung: <b>Klarheit der Schnittstelle hat Vorrang</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#abc5e4" DESTINATION="ID_1210359211" ENDARROW="Default" ENDINCLINATION="-217;-87;" ID="Arrow_ID_1226100946" STARTARROW="None" STARTINCLINATION="-187;427;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181855132" ID="ID_787628963" MODIFIED="1522939107508" TEXT="ViewSpec">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506181868898" ID="ID_1852393086" MODIFIED="1531584013566" TEXT="Resolver">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515634532968" ID="ID_1968327718" MODIFIED="1518487921066" TEXT="Abrufen der UI-Coord triggert Resolver">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#2b46b7" CREATED="1515631590595" FOLDED="true" ID="ID_1454085887" MODIFIED="1529076581800" TEXT="wie mit ViewLocator-Service verdrahten?">
|
|
<arrowlink COLOR="#614483" DESTINATION="ID_1252372720" ENDARROW="Default" ENDINCLINATION="-203;-10;" ID="Arrow_ID_1759099248" STARTARROW="Default" STARTINCLINATION="-373;-23;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522809043561" ID="ID_1735397574" MODIFIED="1522809050105" TEXT="gar nicht direkt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1522809051096" ID="ID_1045087817" MODIFIED="1522809066884">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ViewLocator <i>ruft</i> die DSL auf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522809068294" ID="ID_1952538901" MODIFIED="1522809098365" TEXT="LocatorSpec in der DSL hat ein Depend<UILocationSolver>"/>
|
|
<node CREATED="1522809099593" ID="ID_627167110" MODIFIED="1522809142602">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welcher wiederum von ViewLocator <i>betrieben</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522809144347" ID="ID_1903702867" MODIFIED="1522809145703" TEXT="und mit Navigator als LocationQuery hinterlegt ist"/>
|
|
<node CREATED="1522809146618" ID="ID_827431936" MODIFIED="1522809154977" TEXT="ois kloar?">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515631616944" ID="ID_700537003" MODIFIED="1518487921066" TEXT="verbinden mit Navigator als LocationQuery-Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515631646108" ID="ID_1553855476" MODIFIED="1518840394020" TEXT="UICoordResolver erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515979648475" FOLDED="true" HGAP="38" ID="ID_350272872" MODIFIED="1561827465016" TEXT="Funktionsweise der "Resolution" klären" VSHIFT="1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1515980158112" ID="ID_1744041635" MODIFIED="1522939070606" TEXT="der Reihe nach prüfen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515979664353" ID="ID_1353761382" MODIFIED="1533608413665" TEXT="was heißt "existing"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1515979750382" ID="ID_598253186" MODIFIED="1518487921067" TEXT="darf nicht neu erzeugt werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1515979791512" ID="ID_1473589676" MODIFIED="1518487921067" TEXT="Gegensatz: View ggfs an bekannter Stelle erzeugen"/>
|
|
<node CREATED="1515979803503" ID="ID_397957162" MODIFIED="1561827465017" TEXT="Schlußfolgerung">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1516909893778" ID="ID_659065678" MODIFIED="1518487921067" TEXT=""existing" ⟺ total coverage"/>
|
|
<node CREATED="1516909908686" ID="ID_1886532442" MODIFIED="1518487921067" TEXT=""create" ⟺ can cover"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515980170359" ID="ID_1820091983" MODIFIED="1518487921067" TEXT="Lösung erfordert wenigstens partielle coverage"/>
|
|
<node CREATED="1515982274106" ID="ID_1283888757" MODIFIED="1533608413666" TEXT="Problem: Match ermöglichen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1515982295663" ID="ID_208797931" MODIFIED="1518487921067" TEXT="der View-Name fehlt noch"/>
|
|
<node CREATED="1515982302678" ID="ID_1579006450" MODIFIED="1518487921067" TEXT="nicht existierende Parents"/>
|
|
<node CREATED="1515982330139" ID="ID_176314830" MODIFIED="1518487921067" TEXT="Perspective == egal"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1515982375397" FOLDED="true" ID="ID_773035469" MODIFIED="1533608413667" STYLE="fork" TEXT="Fallback "wenn alles scheitert"?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1516910666253" ID="ID_1056732886" MODIFIED="1518487921067" TEXT="Misconfig"/>
|
|
<node CREATED="1516910669357" ID="ID_1129354200" MODIFIED="1518487921067" TEXT="fataler Fehler"/>
|
|
<node CREATED="1516910673110" ID="ID_436584221" MODIFIED="1561827465017" TEXT="Regel muß Fallback enthalten">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1516910710727" ID="ID_1042011734" MODIFIED="1518487921067" TEXT="warum?"/>
|
|
<node CREATED="1516910736388" ID="ID_1267411576" MODIFIED="1518487921067" TEXT="Principle of least surprise"/>
|
|
<node CREATED="1516910715343" ID="ID_1721041331" MODIFIED="1576282358116" TEXT="sonst default für den default">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sonst bekommen wir eine versteckte
|
|
</p>
|
|
<p>
|
|
zweite hart-gecodete Fallback-Konfig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1516147992493" FOLDED="true" HGAP="24" ID="ID_4925227" MODIFIED="1533608413668" TEXT="wie wird das Zielobjekt selber bestimmt?" VSHIFT="-1">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1516148029148" ID="ID_1974346974" MODIFIED="1561827465018" TEXT="Möglichkeiten">
|
|
<node CREATED="1516148034899" ID="ID_1675414085" MODIFIED="1518487921067" TEXT="explizit anschreiben"/>
|
|
<node CREATED="1516148048121" ID="ID_1850664922" MODIFIED="1518487921067" TEXT="aus letzter gegebener Komponente ableiten"/>
|
|
<node CREATED="1516909656846" ID="ID_1429663106" MODIFIED="1518487921067" TEXT="aus Typ ableiten und fehlende Parents ergänzen"/>
|
|
</node>
|
|
<node CREATED="1516148091716" ID="ID_1815243780" MODIFIED="1561827465018" TEXT="Anforderungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1516148107065" ID="ID_389475040" MODIFIED="1518487921067" TEXT="Name-ID des Elements bestimmbar"/>
|
|
<node CREATED="1516148118064" FOLDED="true" ID="ID_541058997" MODIFIED="1561827483829" TEXT="Coverage feststellbar">
|
|
<node CREATED="1516148128790" FOLDED="true" ID="ID_739368723" MODIFIED="1561827482924" TEXT="partiell">
|
|
<node CREATED="1516148133085" ID="ID_325513379" MODIFIED="1518487921067" TEXT="ein nicht-Wildcard darunter muß schon existieren"/>
|
|
<node CREATED="1516148144267" ID="ID_1074912934" MODIFIED="1518487921067" TEXT="Problem: Perspektive"/>
|
|
</node>
|
|
<node CREATED="1516148152938" FOLDED="true" ID="ID_1439081992" MODIFIED="1561827482924" TEXT="total">
|
|
<node CREATED="1516148156514" ID="ID_323573839" MODIFIED="1518487921067" TEXT="Komponente selber muß spezifiziert sein"/>
|
|
<node CREATED="1516148172864" ID="ID_1611427093" MODIFIED="1518487921067" TEXT="erst dann kann man Match überhaupt prüfen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1516148185461" FOLDED="true" ID="ID_1903672954" MODIFIED="1561827483829" TEXT="Konsequenz">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1516148190821" ID="ID_1390287231" MODIFIED="1518487921067" TEXT="Koordinaten-Ergänzung muß im Locator erfolgen"/>
|
|
<node CREATED="1516909726125" ID="ID_1451248007" MODIFIED="1518487921067">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>existing()</b> sollte <i>default</i> sein und <b>create()</b> explizit anzufordern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil der größte Teil aller real anzugebenden Regel-Klauseln
|
|
</p>
|
|
<p>
|
|
von der Bedeutung her "existing" meint
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1516912422576" ID="ID_1350672682" MODIFIED="1518487921067" TEXT="create() tritt normalerweise auf der letzten Regel auf"/>
|
|
<node CREATED="1516912433647" ID="ID_1102539904" MODIFIED="1518487921067" TEXT="das könnte redundant sein, ist aber klarer so"/>
|
|
<node CREATED="1516910880176" ID="ID_1842572487" MODIFIED="1518487921067" TEXT="create() kann scheitern"/>
|
|
<node CREATED="1516910885938" FOLDED="true" ID="ID_348346243" MODIFIED="1561827482924" TEXT="abschließende create()-Regel">
|
|
<node CREATED="1516910927252" ID="ID_219541480" MODIFIED="1518487921067" TEXT="sollte failsafe sein"/>
|
|
<node CREATED="1516910928914" ID="ID_698619582" MODIFIED="1518487921067" TEXT="d.h. stets realisierbar"/>
|
|
<node CREATED="1516910936185" ID="ID_1449340119" MODIFIED="1518487921067" TEXT="modulo Perspektive"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1516916455847" ID="ID_1054137561" MODIFIED="1561827465025" TEXT="Ergebnis">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1516916468901" ID="ID_1527047531" MODIFIED="1518487921067">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>komplett definierter</i> Pfad incl Zielobjekt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1516916496673" ID="ID_1162890109" MODIFIED="1518487921067">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ggfs wird <i>höchstes ein abschließendes</i> Element hinzugefügt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1516916543155" ID="ID_458920753" MODIFIED="1518487921067">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieser Pfad ist stets <i>anchored</i> und <i>partially covered</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#48639d" CREATED="1516916096887" FOLDED="true" HGAP="32" ID="ID_319974456" MODIFIED="1533608413676" TEXT="zu klären...." VSHIFT="8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1516916105462" ID="ID_1576570507" MODIFIED="1561827465026" TEXT="ist die Semantik of canCover() ausreichend?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517011522978" ID="ID_1745637631" MODIFIED="1518487921067" TEXT="im Prinzip ja">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1517011530017" ID="ID_1904091651" MODIFIED="1518487921067" TEXT="Sonderbehandlung Perspektive notwendig"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1516916140785" ID="ID_1667593991" MODIFIED="1561827465027" TEXT="wie umschiffen wir konkret das Problem mit der Perspektive?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517011709672" FOLDED="true" ID="ID_755188751" MODIFIED="1561827483829" TEXT="Problem ist...">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1517011717447" ID="ID_1098719627" MODIFIED="1518487921067" TEXT="daß es typischerweise nur eine Perspektive gibt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwar könnte es (später mal) sein,
|
|
</p>
|
|
<p>
|
|
daß wir mehrere Perspektiven gleichzeitig in die UI-Topologie abbilden...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517011727918" ID="ID_1678474222" MODIFIED="1518487921067" TEXT="und man daher typischerweise diese in der Spec weglassen möchte">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil die Perspektive eigentlich als <i>etwas Orthogonales</i> empfunden wird,
|
|
</p>
|
|
<p>
|
|
das nicht dirket zur "harten" Topologie gehört, sondern vielmehr bestehende Elemente umgruppiert.
|
|
</p>
|
|
<p>
|
|
Andererseits möchte man eben doch manchmal eine View-Spec eigens auf eine bestimmte Perspektive beschränken,
|
|
</p>
|
|
<p>
|
|
und deshalb habe ich die Perspektive zu den UI-Koordinaten hinzugenommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517011745635" ID="ID_1001739741" MODIFIED="1518487921067" TEXT="aber dies einen Wildcard zur Folge hat, der eine Lösung verhindern kann">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar genau dann, wenn bereits die nächste Komponente unterhalb der Perspektive,
|
|
</p>
|
|
<p>
|
|
also das Pannel, nicht oder nicht in dieser Form existiert, also erzeugt werden müßte.
|
|
</p>
|
|
<p>
|
|
Unser Kriterium für Lösungen jedoch verlangt mindestens einen Match jenseits der Wildcards,
|
|
</p>
|
|
<p>
|
|
um den Match eindeutig zu machen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517012023926" FOLDED="true" ID="ID_836827160" MODIFIED="1561827483829" TEXT="mehre Möglichkeiten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1517012160083" FOLDED="true" ID="ID_485906589" MODIFIED="1561827482924" TEXT="currentPerspective()">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1517012171313" ID="ID_736089446" MODIFIED="1518487921067" TEXT="weiteres Prädikat"/>
|
|
<node CREATED="1517012228857" ID="ID_308230619" MODIFIED="1518487921067" TEXT="muß explizit in der Spec stehen"/>
|
|
<node CREATED="1517012184768" ID="ID_165605510" MODIFIED="1518487921067" TEXT="wird durch das gewählte Fenster gebunden"/>
|
|
<node CREATED="1517012202061" ID="ID_910880935" MODIFIED="1518487921067" TEXT="Name ist unbefriedigend"/>
|
|
<node CREATED="1517012253638" ID="ID_154854590" MODIFIED="1518487921067" TEXT="sprengt die bisherige Implementierung"/>
|
|
</node>
|
|
<node CREATED="1517012313269" FOLDED="true" ID="ID_1391847315" MODIFIED="1561827482925" TEXT="Wildcard-Erkennung manipulieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1517012327796" ID="ID_1970065087" MODIFIED="1518487921068" TEXT="wenn Perspektive der letzte Wildcard ist"/>
|
|
<node CREATED="1517012337771" ID="ID_1231541108" MODIFIED="1518487921068" TEXT="...dann zählt das nicht mehr als Wildcard"/>
|
|
<node CREATED="1517012358240" ID="ID_813053802" MODIFIED="1518487921068" TEXT="und wird folglich gebunden und als Lösung geliefert"/>
|
|
<node CREATED="1517012382901" FOLDED="true" ID="ID_273084853" MODIFIED="1561827469153" TEXT="Pro">
|
|
<node CREATED="1517012386556" ID="ID_391025327" MODIFIED="1518487921068" TEXT="funktioniert zuverlässig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sofern es stets eine Perspektive geben muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517012407785" ID="ID_420210882" MODIFIED="1518487921068" TEXT="leicht auf den bestehenden Algo aufzupflanzen"/>
|
|
</node>
|
|
<node CREATED="1517012430454" FOLDED="true" ID="ID_347958929" MODIFIED="1561827469153" TEXT="Contra">
|
|
<node CREATED="1517012434342" ID="ID_421366317" MODIFIED="1518487921068" TEXT="magisch"/>
|
|
<node CREATED="1517012444100" ID="ID_936293863" MODIFIED="1518487921068" TEXT="Funktionsweise nicht leicht zu durchschauen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517012475424" FOLDED="true" ID="ID_1174371180" MODIFIED="1561827482925" TEXT="element elided">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517012497909" ID="ID_1850562402" MODIFIED="1518487921068" TEXT="neuer spezieller Wildcard"/>
|
|
<node CREATED="1517012527593" ID="ID_1563301573" MODIFIED="1518487921068" TEXT="wird behandelt wie direkter Match"/>
|
|
<node CREATED="1517012749682" ID="ID_616699299" MODIFIED="1518487921068" TEXT="kann ggfs in mehreren Zweigen matchen"/>
|
|
<node CREATED="1517012770456" ID="ID_1332721436" MODIFIED="1518487921068" TEXT="könnte vom DSL-Handler bei Bedarf injiziert werden">
|
|
<linktarget COLOR="#d55642" DESTINATION="ID_1332721436" ENDARROW="Default" ENDINCLINATION="-121;7;" ID="Arrow_ID_1616643867" SOURCE="ID_1238726037" STARTARROW="None" STARTINCLINATION="81;-10;"/>
|
|
</node>
|
|
<node CREATED="1517012855604" FOLDED="true" ID="ID_1313395113" MODIFIED="1561827469153" TEXT="Pro">
|
|
<node CREATED="1517012861315" ID="ID_1630656396" MODIFIED="1518487921068" TEXT="war ohnehin vorgesehen und notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar zwingend notwendig, weil es (viele) Views geben wird,
|
|
</p>
|
|
<p>
|
|
welche keine mehrfachen TABs unterstützen. In solchen Fällen brauchen wir
|
|
</p>
|
|
<p>
|
|
ein Konstrukt, mit dem sich eine Ebene im Baum überspringen läßt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517012879513" ID="ID_391823235" MODIFIED="1518487921068" TEXT="muß sowiso noch nachimplementiert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>"muß"</i> ist relativ, denn mit den bisherigen Anforderungen
|
|
</p>
|
|
<p>
|
|
hätte es genügt, den "elided"-Platzhalter nur in den konkreten UI-Koordinaten
|
|
</p>
|
|
<p>
|
|
zu verwenden, und ihn dann jeweils per Wildcard zu matchen (was automatisch passiert,
|
|
</p>
|
|
<p>
|
|
einfach wenn die betreffende Komponente in der Angabe fehlt)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517012889559" ID="ID_1411847979" MODIFIED="1518487921068" TEXT="fügt sich organisch in die Implementierung ein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die korrekte Semantik fällt uns hier wirklich in den Schoß,
|
|
</p>
|
|
<p>
|
|
es ist nur eine weitere Zeile in dem Test, ob ein Match vorliegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517012992353" FOLDED="true" ID="ID_1397586437" MODIFIED="1561827469153" TEXT="Contra">
|
|
<node CREATED="1517012996289" ID="ID_251225300" MODIFIED="1518487921068" TEXT="magisch und subtil"/>
|
|
<node CREATED="1517013001144" ID="ID_711459982" MODIFIED="1518487921068" TEXT="zwei verschiedene Wildcards">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wobei einer, nämlich '*' sehr offensichtlich und bekannt ist,
|
|
</p>
|
|
<p>
|
|
während der andere (eben dieses '.' == elided) eigens erklärt werden muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517013053265" ID="ID_1569479466" MODIFIED="1518487921068" TEXT="gewisses Mißbrauchs-Potential">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil es eigentlich ein Wildcard ist,
|
|
</p>
|
|
<p>
|
|
aber vom gesamten sonstigen Algorithmus nicht als Wildcard behandelt wird.
|
|
</p>
|
|
<p>
|
|
Damit kann man alle Einschränkungen unterlaufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517013164050" ID="ID_623452791" MODIFIED="1518487921068" TEXT="mehrfach-Lösungen nicht offensichtlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Korrekter Gebrauch setzt eigentlich voraus,
|
|
</p>
|
|
<p>
|
|
daß es an dieser Stelle auch tatsächlich "gar nichts" oder nur "ein stets festes Element" gibt.
|
|
</p>
|
|
<p>
|
|
Für die Perspektive ist das (nach jetztiger Planung) stets gegeben.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wenn man allerdings diese Bedingung verletzt, dann matcht der "elided"-Platzhalter
|
|
</p>
|
|
<p>
|
|
in mehreren alternativen Zweigen wie ein Wildcard, und es hängt dann von
|
|
</p>
|
|
<p>
|
|
zufälligen Umständen ab, ob man die erwartete Lösung bekommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517013731613" ID="ID_1238726037" MODIFIED="1518487921068" TEXT="besste Lösung offensichtlich....">
|
|
<arrowlink COLOR="#d55642" DESTINATION="ID_1332721436" ENDARROW="Default" ENDINCLINATION="-121;7;" ID="Arrow_ID_1616643867" STARTARROW="None" STARTINCLINATION="81;-10;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1516916210656" ID="ID_1339759450" MODIFIED="1561827465032" TEXT="wie ermitteln wir das zu erzeugende Suffix des Pfades?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517016683468" ID="ID_174913733" MODIFIED="1518487921068" TEXT=""create()"-Fall ⟹ partiallyCovered()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1517016762625" ID="ID_320463832" MODIFIED="1518487921068" TEXT="...müßte diese Info an den Allocator weitergeben"/>
|
|
<node CREATED="1517016781198" FOLDED="true" ID="ID_1556601725" MODIFIED="1561827483829" TEXT="Idee: Allocator nimmt UI-Coord-Resolver?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1517018164354" ID="ID_308763864" MODIFIED="1518487921068" TEXT="würde theoretisch gehen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bloß würde sich die Signatur der DSL-Bausteine ändern:
|
|
</p>
|
|
<p>
|
|
Allocator = std::function<UICoord(UICoordResolver)>;
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517018171153" ID="ID_912683774" MODIFIED="1518487921068" TEXT="wird ziemlich technisch in der Implementierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn Reolver ist ein UICoord::Builder und als Solcher non-copyable.
|
|
</p>
|
|
<p>
|
|
Also würde das ganze Gefrickel mit Referenzen losgehen,
|
|
</p>
|
|
<p>
|
|
in einem Stück Metaprogramming-Code, das ohnenhin schon ziemlich "dicht" ist....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517018198398" ID="ID_986073860" MODIFIED="1518487921068" TEXT="sonst muß man halt noch mal traversieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Punkt ist: das ist eine reine Lauzeit/Effzienz-Überlegung.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Nachdem das Pfad-Matching in der DSL für die Location die passende Lösung gewählt hat,
|
|
</p>
|
|
<p>
|
|
wäre -- im UICoordResolver eben -- auch schon die effektive Coverage bekannt.
|
|
</p>
|
|
<p>
|
|
Da aber unser API nach (reinen) UI-Coord verlangt, werden diese aus der berechneten Lösung
|
|
</p>
|
|
<p>
|
|
herausbewegt. Und der Allokator muß sich dann erneut einen UICoordResolver bauen,
|
|
</p>
|
|
<p>
|
|
oder zumindest das LocationQuery-Interface bemühen, welches dann nochmal den Baum
|
|
</p>
|
|
<p>
|
|
traversiert um die Coverage festzustellen.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Ja, das kostet und ist verschwenderisch...
|
|
</li>
|
|
<li>
|
|
und Ja, vermutlich sind die paar CPU-Zyklen komplett egal
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517018183472" ID="ID_1424416822" MODIFIED="1518487921068" TEXT="als Optimierung auf später vertagt...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist der klassische Fall, wo man wegen einer solchen Optimierung
|
|
</p>
|
|
<p>
|
|
sich ein Interface versaut und ziemliche zusätzliche Komplexitäten an Bord zieht.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517018624028" ID="ID_701345322" MODIFIED="1518487921068" TEXT="Antwort: gar nicht, wir berechnen das neu">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518658487899" ID="ID_1831478029" MODIFIED="1561827465033" TEXT="wie können Regeln auf den Anwendungs-Kontext Bezug nehmen?">
|
|
<linktarget COLOR="#967ea6" DESTINATION="ID_1831478029" ENDARROW="Default" ENDINCLINATION="-800;514;" ID="Arrow_ID_162294902" SOURCE="ID_986224819" STARTARROW="None" STARTINCLINATION="693;-50;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518658506857" ID="ID_589229909" MODIFIED="1518658523711" TEXT="das Problem "asset Tab"">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1518658837468" ID="ID_744795602" MODIFIED="1518658861070" TEXT="invertiert die logischen Abhängigkeiten">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1518658902747" FOLDED="true" ID="ID_976555378" MODIFIED="1576282358116" TEXT="entspricht der Unifikation in Logik-Programmierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern auch dort
|
|
</p>
|
|
<p>
|
|
die jeweilige generische Regel parametrisiert / instantiiert wird
|
|
</p>
|
|
<p>
|
|
gegen den Kontext, mit dem sie matchen soll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1518762048186" ID="ID_1857576258" MODIFIED="1518762055013" TEXT="möchte ich eigentlich nicht einführen"/>
|
|
<node CREATED="1518762055881" ID="ID_1976334061" MODIFIED="1518762100381" TEXT="vorerst nicht weiter verfolgt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518746009058" ID="ID_1800549154" MODIFIED="1518830352525" TEXT="#1130 allow view location by similar kind">
|
|
<arrowlink COLOR="#77546e" DESTINATION="ID_1501187790" ENDARROW="Default" ENDINCLINATION="447;-339;" ID="Arrow_ID_437325251" STARTARROW="None" STARTINCLINATION="486;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518659028202" ID="ID_1880101392" MODIFIED="1518659037749" TEXT="betrifft eigentlich auch currentWindow()"/>
|
|
<node CREATED="1518659526767" ID="ID_839916178" MODIFIED="1518742936572" TEXT="⟹ ist Variablen-Bindung und Funktionsauswertung">
|
|
<arrowlink COLOR="#8e6e9e" DESTINATION="ID_1208480183" ENDARROW="Default" ENDINCLINATION="-458;-16;" ID="Arrow_ID_504124124" STARTARROW="None" STARTINCLINATION="-600;49;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#48639d" CREATED="1516916599018" ID="ID_809925267" MODIFIED="1561827465034" TEXT="wie genau muß die Aufrufschnittstelle aussehen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1517084001346" FOLDED="true" ID="ID_101484926" MODIFIED="1561827483830" TEXT="bekannter Ausgangspunkt">
|
|
<node CREATED="1517083926212" FOLDED="true" ID="ID_1898315920" MODIFIED="1561827482925" TEXT="location">
|
|
<node CREATED="1517021261097" ID="ID_127451793" MODIFIED="1518487921068" TEXT="wird von der Umwandlung in UICoord getrieben"/>
|
|
<node CREATED="1517084031198" FOLDED="true" ID="ID_120792277" MODIFIED="1561827469153" TEXT="braucht">
|
|
<node CREATED="1517021285330" ID="ID_38597538" MODIFIED="1518487921068" TEXT="LocationQuery"/>
|
|
<node CREATED="1517084112371" ID="ID_769147946" MODIFIED="1518487921068" TEXT="Name bzw. Typ des Elements"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517084049228" FOLDED="true" ID="ID_919406389" MODIFIED="1561827482925" TEXT="allocation">
|
|
<node CREATED="1517084052451" ID="ID_1249788788" MODIFIED="1518487921068" TEXT="konsumiert Ergebnis von location"/>
|
|
<node CREATED="1517084617710" FOLDED="true" ID="ID_1812571482" MODIFIED="1561827469153" TEXT="braucht">
|
|
<node CREATED="1517084621814" FOLDED="true" ID="ID_1163837563" MODIFIED="1561827469135" TEXT="LocationQuery">
|
|
<node CREATED="1517084626949" FOLDED="true" ID="ID_73780971" MODIFIED="1525124214917" TEXT="um die Multiplicity-Constraints zu prüfen">
|
|
<node CREATED="1517084664528" ID="ID_749914799" MODIFIED="1518487921068" TEXT="wir traversieren / matchen erneut"/>
|
|
<node CREATED="1517084673487" ID="ID_114406974" MODIFIED="1518487921068" TEXT="Optimierung wäre ein View-Index">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist eine typische, rein lokale Optimierung (Speicher vs CPU)
|
|
</p>
|
|
<p>
|
|
Ein solcher View-Index sollte dann ebenfalls via LocationQuery exponiert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517084780368" ID="ID_438448516" MODIFIED="1518487921068" TEXT="um das zu erzeugende Pfad-Suffix zu finden"/>
|
|
</node>
|
|
<node CREATED="1517084832201" FOLDED="true" ID="ID_1256502240" MODIFIED="1561827469135" TEXT="ViewLocator">
|
|
<node CREATED="1517084844456" ID="ID_1565019572" MODIFIED="1518487921068" TEXT="um auf die eigentlichen Elemente durchzugreifen"/>
|
|
<node CREATED="1517084853574" ID="ID_654820561" MODIFIED="1518487921068" TEXT="um die Erzeugung anzustoßen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517085201199" FOLDED="true" ID="ID_857446188" MODIFIED="1561827483830" TEXT="Problem: Name/Typ">
|
|
<node CREATED="1517085219749" FOLDED="true" ID="ID_1532208378" MODIFIED="1561827482925" TEXT="muß das DSL-API geändert werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1517085233491" ID="ID_30019292" MODIFIED="1518487921068" TEXT="location auch ein Funktor?"/>
|
|
<node CREATED="1517085244625" ID="ID_413721839" MODIFIED="1518487921068" TEXT="nimmt jeweils den konkreten Typ"/>
|
|
<node CREATED="1517504908529" FOLDED="true" ID="ID_1809382464" MODIFIED="1561827469154" TEXT="Unterschied zum Allocator">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1517504917464" ID="ID_708832973" MODIFIED="1518487921068">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt <i>nur einen</i> "Locator"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1517504936349" ID="ID_554771782" MODIFIED="1518487921068" TEXT="aber viele Allocatoren"/>
|
|
<node CREATED="1517504985135" ID="ID_1830919763" MODIFIED="1518487921068" TEXT="keine partielle Funktor-Applikation notwendig">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1517505012763" ID="ID_1291355818" MODIFIED="1518487921068" TEXT="man kann es fest auscoden">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505097399" FOLDED="true" ID="ID_294737534" MODIFIED="1561827482925" TEXT="Konsequenz: Locator wird zum Funktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517505142369" ID="ID_940906263" MODIFIED="1518487921068" TEXT="wird weiterhin initialisiert mit einer UI-Coord"/>
|
|
<node CREATED="1517508084435" ID="ID_536404927" MODIFIED="1518487921068" TEXT="baut daraus eine LocationRule (embedded delegate)"/>
|
|
<node CREATED="1517505168030" ID="ID_570287604" MODIFIED="1518487921068" STYLE="fork" TEXT="delegiert Lösung an LocationSolver (PImpl)">
|
|
<arrowlink COLOR="#7999a3" DESTINATION="ID_1733459677" ENDARROW="Default" ENDINCLINATION="460;0;" ID="Arrow_ID_1447990036" STARTARROW="None" STARTINCLINATION="-15;211;"/>
|
|
</node>
|
|
<node CREATED="1517505262305" ID="ID_1820737013" MODIFIED="1518487921068" TEXT="ODER ergänzt diesen"/>
|
|
<node CREATED="1517505271712" ID="ID_454259889" MODIFIED="1518487921068" TEXT="Aufruf -> solve -> expliziter Pfad"/>
|
|
</node>
|
|
<node CREATED="1517505121564" ID="ID_880504673" MODIFIED="1518487921068" TEXT="Aufruf ändert sich">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517505406390" FOLDED="true" ID="ID_799191936" MODIFIED="1561827483830" TEXT="DSL-Anwendung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1517505438209" FOLDED="true" ID="ID_1991447613" MODIFIED="1561827482925" TEXT="Schritt 1">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1517505518247" ID="ID_1212835768" MODIFIED="1518487921068" TEXT="locate(typID)"/>
|
|
<node CREATED="1517505532484" FOLDED="true" ID="ID_192986712" MODIFIED="1561827469154" TEXT="liefert Pfad">
|
|
<node CREATED="1517505555066" ID="ID_286561451" MODIFIED="1518487921069" TEXT="komplettiert"/>
|
|
<node CREATED="1517505557977" ID="ID_1809908136" MODIFIED="1518487921069" TEXT="partially covered"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517505442593" FOLDED="true" ID="ID_164467382" MODIFIED="1561827482925" TEXT="Schritt 2">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1517505573687" ID="ID_197290428" MODIFIED="1518487921069" TEXT="allocate(pfad)"/>
|
|
<node CREATED="1517505580870" ID="ID_1902973372" MODIFIED="1518487921069" TEXT="mutiert ggfs das UI"/>
|
|
<node CREATED="1517505599515" FOLDED="true" ID="ID_1414969254" MODIFIED="1561827469154" TEXT="liefert Pfad">
|
|
<node CREATED="1517505605363" ID="ID_1831975809" MODIFIED="1518487921069" TEXT="zeigt auf gewünschtes Element"/>
|
|
<node CREATED="1523750537195" ID="ID_1546579450" MODIFIED="1523750551293" TEXT="hat ggfs die typID/Namens-ID dekoriert"/>
|
|
<node CREATED="1517505614937" ID="ID_262899447" MODIFIED="1518487921069" TEXT="totally covered"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#48639d" CREATED="1516916611433" ID="ID_1887578617" MODIFIED="1561827465044" TEXT="welche zusätzlichen Services werden benötigt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1517021372159" FOLDED="true" ID="ID_841350723" MODIFIED="1561827483830" TEXT="location">
|
|
<node CREATED="1518840121972" ID="ID_989066633" MODIFIED="1522938419001">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein <b>LocationSolver</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1517021326957" ID="ID_20403834" MODIFIED="1522938411626">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>LocationQuery</b> qua Navigator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1517021298929" ID="ID_621970077" MODIFIED="1518487921069">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die es <i>hinten herum</i> bekommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517021389028" FOLDED="true" ID="ID_1240883488" MODIFIED="1561827483830" TEXT="Allocator">
|
|
<node CREATED="1517021395067" ID="ID_1609814715" MODIFIED="1518487921069" TEXT="die konkreten Allokatoren"/>
|
|
<node CREATED="1517021415017" ID="ID_1692689619" MODIFIED="1522938396840">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sehen <b>ViewLocator</b>-API
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517013926947" HGAP="247" ID="ID_1823688859" MODIFIED="1533685136952" TEXT="fehlende Implementierung..." VSHIFT="26">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517013976676" ID="ID_614348470" MODIFIED="1533608413693" TEXT=""elided" als Wildcard behandeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517013994137" ID="ID_140988955" MODIFIED="1518762169701" TEXT="einbauen (EInzeiler)">
|
|
<arrowlink COLOR="#91a7b5" DESTINATION="ID_974516393" ENDARROW="Default" ENDINCLINATION="-759;53;" ID="Arrow_ID_862004765" STARTARROW="None" STARTINCLINATION="1590;41;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517014001792" ID="ID_1542036736" MODIFIED="1518762171655" TEXT="Testfälle nachtragen">
|
|
<arrowlink COLOR="#4b5cab" DESTINATION="ID_796216711" ENDARROW="Default" ENDINCLINATION="-145;942;" ID="Arrow_ID_570641462" STARTARROW="None" STARTINCLINATION="383;78;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1518658696759" FOLDED="true" ID="ID_68856104" MODIFIED="1533608413694">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Regel-Parametrisierung
|
|
</p>
|
|
<p>
|
|
Kontextualisierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#e46465" DESTINATION="ID_68856104" ENDARROW="Default" ENDINCLINATION="74;449;" ID="Arrow_ID_110301671" SOURCE="ID_1208480183" STARTARROW="None" STARTINCLINATION="-232;7;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1518658759567" ID="ID_1257805922" MODIFIED="1561827465048" TEXT="wie?">
|
|
<node CREATED="1517014036148" ID="ID_1650726696" MODIFIED="1518487921069" TEXT="on the fly">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1517014040147" ID="ID_144379993" MODIFIED="1518743268543" TEXT="beim Erzeugen des Resolvers"/>
|
|
</node>
|
|
<node CREATED="1518658744024" ID="ID_1009975119" MODIFIED="1561827465049" TEXT="Zweck">
|
|
<node COLOR="#338800" CREATED="1517014013207" FOLDED="true" ID="ID_1843964714" MODIFIED="1561827483830" TEXT="automatisches Injizieren von "elided"">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518743292259" ID="ID_1943028471" MODIFIED="1518839525198" TEXT="das machen wir trotzdem">
|
|
<arrowlink COLOR="#595f8d" DESTINATION="ID_1516856737" ENDARROW="Default" ENDINCLINATION="302;0;" ID="Arrow_ID_241747952" STARTARROW="None" STARTINCLINATION="697;-153;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1518743303177" ID="ID_1758602660" MODIFIED="1518743321547" TEXT="...und zwar direkt im LocationSolver"/>
|
|
</node>
|
|
<node CREATED="1518658412982" FOLDED="true" ID="ID_1860407174" MODIFIED="1561827483830" TEXT="Lösung für "asset Tab"">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1518745809189" ID="ID_334346990" MODIFIED="1518746202442" TEXT="hier geht es um einen subtilen Punkt im Gebrauch des UI-Raumes">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Man möchte, daß für spezielle Sub-Elemente,
|
|
</p>
|
|
<p>
|
|
die aus einem fremden Kontext heraus geöffnet werden,
|
|
</p>
|
|
<p>
|
|
zunächst versucht wird, einen irgendwo im UI schon bestehenden TAB
|
|
</p>
|
|
<p>
|
|
für speziell diesen Element-Typ wiederzuverwenden; das erlaubt dem User,
|
|
</p>
|
|
<p>
|
|
sich einen Platz für sehr spezielle Sachen beiseite zu setzen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
z.B. sehr spezielle Assets oder ein virtueller Clip.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Erst wenn so ein Ort nicht gefunden wird, möchte man auf einen
|
|
</p>
|
|
<p>
|
|
generischen Ort zurückfallen, und erst als letzte default-Lösung
|
|
</p>
|
|
<p>
|
|
im aktuellen Fenster einen völlig neuen UI-Elementkontext schaffen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#2c4580" DESTINATION="ID_334346990" ENDARROW="Default" ENDINCLINATION="242;0;" ID="Arrow_ID_1968525556" SOURCE="ID_1219364679" STARTARROW="None" STARTINCLINATION="78;0;"/>
|
|
</node>
|
|
<node CREATED="1518745834329" ID="ID_877601312" MODIFIED="1518745855890" TEXT="nicht klar, ob es gerechtfertigt ist, hierfür solche Komplexitäten zu schaffen"/>
|
|
<node CREATED="1518745857950" ID="ID_1572087161" MODIFIED="1518745944379" TEXT="wenn sollte man es besser explizit als Spezialfall hart-coden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...statt die gesamte Matching-Engine mit einer Art
|
|
</p>
|
|
<p>
|
|
halbgaren Unifikation aufzubrezln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1518745906400" ID="ID_958966084" MODIFIED="1518745914960" TEXT="wildMatch() in ui-coord-resolver.cpp">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518746009058" FOLDED="true" ID="ID_43313184" MODIFIED="1561827482926" TEXT="#1130 allow view location by similar kind">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1518762071967" FOLDED="true" ID="ID_1501187790" MODIFIED="1561827469154" TEXT="ggfs partielle Lösung?">
|
|
<linktarget COLOR="#77546e" DESTINATION="ID_1501187790" ENDARROW="Default" ENDINCLINATION="447;-339;" ID="Arrow_ID_437325251" SOURCE="ID_1800549154" STARTARROW="None" STARTINCLINATION="486;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1518830375356" ID="ID_580870700" MODIFIED="1518830460134">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nur eingeschränkt</i> auf die TypID?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1518830433876" FOLDED="true" ID="ID_486080918" MODIFIED="1561827469135" TEXT="Flag, um diese vor Matching injizieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1518830500331" ID="ID_314535087" MODIFIED="1518830531395">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Preprocessing beim <i>Anlegen</i> der Klausel
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1518830545773" ID="ID_533394110" MODIFIED="1518830552887" TEXT="setzt spezielle Syntax in Flag um"/>
|
|
<node CREATED="1518830581200" ID="ID_1879545754" MODIFIED="1518830625478" TEXT="Flag ⟹ aktuelle typID wird als Term angehängt"/>
|
|
<node CREATED="1518830626306" ID="ID_1109967783" MODIFIED="1518830635572" TEXT="...und muß somit schon existieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518660243382" HGAP="32" ID="ID_1951597669" MODIFIED="1561827465053" TEXT="technischer Ansatz" VSHIFT="-2">
|
|
<node CREATED="1518660484501" FOLDED="true" ID="ID_1142230788" MODIFIED="1561827483830" TEXT="Pattern umschreiben">
|
|
<node CREATED="1518660561314" ID="ID_719818438" MODIFIED="1518660568165" TEXT="sehr leicht zu implementieren"/>
|
|
<node CREATED="1518660569273" ID="ID_357095507" MODIFIED="1518660615103" TEXT="verwirrend/magisch/manipulativ"/>
|
|
<node CREATED="1518660696792" FOLDED="true" ID="ID_90938050" MODIFIED="1561827482926" TEXT="verschwenderisch">
|
|
<node CREATED="1518660724012" ID="ID_471630453" MODIFIED="1518660730367" TEXT="zusätzlicher Pass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518660732051" ID="ID_595304644" MODIFIED="1518738065908" TEXT="für ein selten verwendetes Feature">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518660504026" FOLDED="true" ID="ID_923980639" MODIFIED="1561827483830" TEXT="Matcher/Unifizierer">
|
|
<node CREATED="1518660781261" ID="ID_1851856047" MODIFIED="1518660789479" TEXT="sitzt im Solver selber"/>
|
|
<node CREATED="1518660790596" ID="ID_869512309" MODIFIED="1518660793175" TEXT="logisch korrekt"/>
|
|
<node CREATED="1518660795403" FOLDED="true" ID="ID_1080152835" MODIFIED="1561827482926" TEXT="erfordert Abstraktion">
|
|
<node CREATED="1518660845588" ID="ID_1526822574" MODIFIED="1518660850327" TEXT="Definitionsaufwand"/>
|
|
<node CREATED="1518660851035" ID="ID_1271437627" MODIFIED="1518660856798" TEXT="Einrichtungs-Aufwand"/>
|
|
<node CREATED="1518660857434" ID="ID_1501111250" MODIFIED="1518660906191" TEXT="komplex für Test einzurichten"/>
|
|
</node>
|
|
<node CREATED="1518742996348" ID="ID_328356111" MODIFIED="1518743006606" TEXT="von der Ebene der Sprache her schwer zu verstehen"/>
|
|
<node CREATED="1518743012337" ID="ID_1220573120" MODIFIED="1518743054926">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bleibt dem Charakter nach <i>imperativ</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1518743065930" HGAP="79" ID="ID_1989234578" MODIFIED="1561827465059" TEXT="vorerst abgelehnt" VSHIFT="21">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1518743153214" ID="ID_513041431" MODIFIED="1518743159705" TEXT="keine der Lösungen wirklich attraktiv"/>
|
|
<node CREATED="1518743167708" ID="ID_1748977650" MODIFIED="1518743186813" TEXT="sprengt gewissermaßen den Ansatz eines reinen Matchers"/>
|
|
<node CREATED="1518743192305" ID="ID_1134364758" MODIFIED="1518743222705" TEXT="wenn man wirkliche Unifikation will ⟹ Resolution-Engine nehmen"/>
|
|
<node CREATED="1518743226772" FOLDED="true" ID="ID_1108128377" MODIFIED="1561827483830" TEXT="DSL-Entwurf nochmal angeschaut....">
|
|
<node CREATED="1518743248497" ID="ID_1219364679" MODIFIED="1518745996865" TEXT="Feature kann weitgehend umgangen werden">
|
|
<arrowlink COLOR="#2c4580" DESTINATION="ID_334346990" ENDARROW="Default" ENDINCLINATION="242;0;" ID="Arrow_ID_1968525556" STARTARROW="None" STARTINCLINATION="78;0;"/>
|
|
</node>
|
|
<node CREATED="1518743254401" ID="ID_1218065629" MODIFIED="1518743258377" TEXT="YAGNI">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505328936" FOLDED="true" ID="ID_406973235" MODIFIED="1533608413702" TEXT="Umbauen Locator in Functor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517505339663" ID="ID_470503309" MODIFIED="1561827465064" TEXT="DSL-Header restrukturieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517507830918" FOLDED="true" ID="ID_1112334086" MODIFIED="1561827483831" TEXT="Locator analog zu Allocator definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1519355684307" FOLDED="true" ID="ID_336676610" MODIFIED="1561827482926">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was <i>ist</i> der Locator?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1519355702409" ID="ID_609593004" MODIFIED="1520205015753" TEXT="eine LocationRule">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1519355709376" ID="ID_142286917" MODIFIED="1519355717530" TEXT="mit Aufruf-Mechanismus"/>
|
|
</node>
|
|
<node CREATED="1519357904845" FOLDED="true" ID="ID_691482201" MODIFIED="1561827482926" TEXT="Verwendungs-Schema">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1519357910532" FOLDED="true" ID="ID_1670200821" MODIFIED="1561827469154" TEXT="komplett symmetrisch?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1519357919770" ID="ID_1959314257" MODIFIED="1519357951259" TEXT="zusätzliche Art der Location?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1519357938272" ID="ID_446182371" MODIFIED="1519357948252" TEXT="Location-Builder">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519357953550" FOLDED="true" ID="ID_1286263958" MODIFIED="1561827469154" TEXT="eine Ebene heben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1519357991409" ID="ID_994090473" MODIFIED="1519357999947" TEXT="Bauen per Zuweisung"/>
|
|
<node CREATED="1519358000671" ID="ID_49826255" MODIFIED="1519358015345" TEXT="Aufruf mit Typ-ID-Argument"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1519358138988" FOLDED="true" ID="ID_1481930885" MODIFIED="1561827482926" TEXT="DSL-Mechanik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1519358154386" ID="ID_1810798001" MODIFIED="1519358201550" TEXT="Allocator wird durch Zuweisen der AlocSpec generiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1519358178623" ID="ID_517547970" MODIFIED="1519442398323" TEXT="beim Locator fehlt ein entsprechendes Gegenstück">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1519359156410" FOLDED="true" ID="ID_1786241256" MODIFIED="1561827469154" TEXT="Idee">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1519359176855" ID="ID_853060191" MODIFIED="1519359192777">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der <i>Level</i> im UI ist noch offen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1519359193821" ID="ID_588596170" MODIFIED="1519359234665" STYLE="fork" TEXT="das könnte Argument eines Builders sein"/>
|
|
<node CREATED="1519359239735" FOLDED="true" ID="ID_988890391" MODIFIED="1561827469135" TEXT="konkret......">
|
|
<node CREATED="1519438604809" ID="ID_313142617" MODIFIED="1519438615852" TEXT="Lösevorgang muß den Ziel-Level kennen"/>
|
|
<node CREATED="1519438617271" ID="ID_1310079168" MODIFIED="1519438673926">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>fast immer</i> ist das aber UIC_VIEW
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Moment fällt mir überhaupt keine Ausnahme ein
|
|
</p>
|
|
<p>
|
|
aber man soll niemals nie sagen;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
jedenfalls ist der LocationSolver komplett generisch geschrieben,
|
|
</p>
|
|
<p>
|
|
wäre ja auch dämlich, den auf einen Level festzunageln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1519439848624" FOLDED="true" ID="ID_1356890401" MODIFIED="1525124214959">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann man den Level <i>erschließen?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1519439872572" ID="ID_1387780581" MODIFIED="1519439914138" TEXT="fast, aber leider nein">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1519439893089" ID="ID_350245814" MODIFIED="1519440011427" TEXT="nicht wenn alle Pattern gleich lang sind">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist nicht klar, ob die pattern bereits das fragliche View-Element mit einschließen,
|
|
</p>
|
|
<p>
|
|
oder ob das View-Element noch angehängt werden soll. Diese Variation ist essentiell,
|
|
</p>
|
|
<p>
|
|
um Regeln auszudrücken, die explizit nur eine schon existierende UI-Komponente greifen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519440039302" FOLDED="true" ID="ID_779685706" MODIFIED="1525124214959" TEXT="folglich...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1519440044629" ID="ID_433141744" MODIFIED="1519442714991" TEXT="muß der Level entweder aus der DSL kommen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1519440054651" ID="ID_1512334426" MODIFIED="1519442712213" TEXT="oder er muß über den Typ gecodet sein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1519442682549" ID="ID_1285145089" MODIFIED="1519442708878" TEXT="oder explizit beim Aufruf mitgegeben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519437341366" FOLDED="true" ID="ID_1400629217" MODIFIED="1561827469154" TEXT="Alternativen">
|
|
<node CREATED="1519437362523" ID="ID_1967120024" MODIFIED="1519440122737" STYLE="bubble">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auto locate = matchView(
|
|
</p>
|
|
<p>
|
|
                          panel("blah")
|
|
</p>
|
|
<p>
|
|
                          or currentWindow().panel("blubb").create() )
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1519437509655" ID="ID_241024117" MODIFIED="1519442360056" STYLE="bubble">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
LocatorSpec<UIC_VIEW> locate = panel("blah")
|
|
</p>
|
|
<p>
|
|
                                                     or currentWindow().panel("blubb").create()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1519437756333" ID="ID_565391583" MODIFIED="1519440134474" STYLE="bubble">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ViewSpec locate = panel("blah")
|
|
</p>
|
|
<p>
|
|
                                or currentWindow().panel("blubb").create()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519440138712" FOLDED="true" ID="ID_861550710" MODIFIED="1561827469154" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1519440157310" FOLDED="true" ID="ID_1912054433" MODIFIED="1561827469136" TEXT="ziehe die letzte Variante als Standard-Fall vor">
|
|
<node CREATED="1519440168660" ID="ID_1954754744" MODIFIED="1519440288338" TEXT="weil sie am unscheinbarsten ist">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1519440271318" ID="ID_436275698" MODIFIED="1519440283871" TEXT="auch wenn dadurch die Definitionen etwas schief werden">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519440180978" FOLDED="true" ID="ID_42017722" MODIFIED="1561827469136" TEXT="die vorletzte Variante ist die eigentliche Definition">
|
|
<node CREATED="1519440198016" ID="ID_650838793" MODIFIED="1519440207306" TEXT="und ViewSpec ein Typ-Alias"/>
|
|
<node CREATED="1519440208487" ID="ID_1465224504" MODIFIED="1519440222184" TEXT="analog für PanelSpec, WindowSpec"/>
|
|
</node>
|
|
<node CREATED="1519440250849" ID="ID_800018525" MODIFIED="1519440267084" TEXT="die Asymetrie in der DSL-Definition nehme ich in Kauf">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1519355735012" ID="ID_241646491" MODIFIED="1519355793090" TEXT="wo entsteht die LocationRule?">
|
|
<arrowlink COLOR="#647b96" DESTINATION="ID_1664602603" ENDARROW="Default" ENDINCLINATION="1374;300;" ID="Arrow_ID_947721778" STARTARROW="None" STARTINCLINATION="298;36;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517507566761" FOLDED="true" ID="ID_839496495" MODIFIED="1561827483831">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Anwendung <i>delegiert</i> an einen Serivce
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522807009051" ID="ID_578310400" MODIFIED="1522807052395">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
für <i>LocationQuery</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#2c5db0" DESTINATION="ID_578310400" ENDARROW="Default" ENDINCLINATION="52;3;" ID="Arrow_ID_808786860" SOURCE="ID_704863615" STARTARROW="None" STARTINCLINATION="52;3;"/>
|
|
</node>
|
|
<node CREATED="1522807024217" ID="ID_704863615" MODIFIED="1522807052394">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
für <i>LocationSolver</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#2c5db0" DESTINATION="ID_578310400" ENDARROW="Default" ENDINCLINATION="52;3;" ID="Arrow_ID_808786860" STARTARROW="None" STARTINCLINATION="52;3;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1519355422807" FOLDED="true" ID="ID_1718427051" MODIFIED="1561827483831" TEXT="Service-Zugang regeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520221913300" FOLDED="true" ID="ID_906905" MODIFIED="1561827482926" TEXT="Design?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1520221927138" FOLDED="true" ID="ID_782466951" MODIFIED="1561827469155" TEXT="hintenrum injizieren">
|
|
<arrowlink COLOR="#3391c4" DESTINATION="ID_1058958215" ENDARROW="Default" ENDINCLINATION="356;0;" ID="Arrow_ID_1958186293" STARTARROW="None" STARTINCLINATION="40;166;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520222029276" ID="ID_1305200988" MODIFIED="1520222040102" TEXT="magisch"/>
|
|
<node CREATED="1520222040762" ID="ID_1805401030" MODIFIED="1520222046261" TEXT="statefull (Singleton)"/>
|
|
<node CREATED="1520222046905" ID="ID_1622261658" MODIFIED="1520222079625" TEXT="Test wird verwirrend"/>
|
|
<node COLOR="#338800" CREATED="1522806901418" ID="ID_1922399331" MODIFIED="1522806952792" TEXT="Schöne Lösung: lib::Depend">
|
|
<arrowlink COLOR="#3390b9" DESTINATION="ID_871055051" ENDARROW="Default" ENDINCLINATION="-128;-126;" ID="Arrow_ID_1437440702" STARTARROW="None" STARTINCLINATION="-21;26;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1520221939552" FOLDED="true" ID="ID_1782927241" MODIFIED="1561827469155" TEXT="mit Aufruf mitgeben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1520221963005" ID="ID_1864632806" MODIFIED="1520221965097" TEXT="sauber"/>
|
|
<node CREATED="1520221971275" ID="ID_1783955125" MODIFIED="1520222023640" TEXT="gradlinig zu testen"/>
|
|
<node CREATED="1520221965972" ID="ID_610476428" MODIFIED="1520221970496" TEXT="einfach zu implementieren"/>
|
|
<node CREATED="1520221985682" FOLDED="true" ID="ID_589257049" MODIFIED="1561827469136" TEXT="gefällt mir trotzdem nicht">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1520222097723" ID="ID_435762794" MODIFIED="1520222108581" TEXT="weil es die Abstraktion der DSL bricht"/>
|
|
<node CREATED="1520222137669" ID="ID_497050094" MODIFIED="1520222152007" TEXT="weil es logisch nichts mit dem query-Aufruf zu tun hat"/>
|
|
<node CREATED="1520222159722" ID="ID_462075011" MODIFIED="1520222170981" TEXT="weil es asymetrisch zur Allokation ist"/>
|
|
<node CREATED="1520222178063" ID="ID_1483417403" MODIFIED="1520222192305" TEXT="weil es ein Implementierungsdetail auf dem API ist"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522804403692" FOLDED="true" ID="ID_281326685" MODIFIED="1561827482926" TEXT="globale Variable zurückbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522804419777" ID="ID_631271577" MODIFIED="1522806858336" TEXT="locationQuery">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522804436623" ID="ID_968463465" MODIFIED="1522804473410" TEXT="view-locator.cpp">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520721753927" FOLDED="true" ID="ID_1564232821" MODIFIED="1561827482927" TEXT="DependencyFactory verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520721767005" ID="ID_364557801" MODIFIED="1522806969961" TEXT="dazu muß diese erst mal ausgebaut werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1522806971408" ID="ID_747664714" MODIFIED="1522806984381" TEXT="tja, das waren 14 Tage Arbeit....">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520721792978" ID="ID_871055051" MODIFIED="1522806952792" TEXT="#1086 unify Depend singleton and instance management">
|
|
<arrowlink COLOR="#7188b5" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="2227;-4042;" ID="Arrow_ID_1654818003" STARTARROW="None" STARTINCLINATION="775;393;"/>
|
|
<linktarget COLOR="#3390b9" DESTINATION="ID_871055051" ENDARROW="Default" ENDINCLINATION="-128;-126;" ID="Arrow_ID_1437440702" SOURCE="ID_1922399331" STARTARROW="None" STARTINCLINATION="-21;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522804252041" FOLDED="true" HGAP="-15" ID="ID_557569003" MODIFIED="1561827469155" TEXT="Verdrahtung einrichten" VSHIFT="61">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522804312832" ID="ID_1841038371" MODIFIED="1522804485667" STYLE="fork" TEXT="InteractionDirector -> Navigator == Service LocationQuery"/>
|
|
<node CREATED="1522804344916" ID="ID_456601994" MODIFIED="1522804392465" TEXT="ViewLocator -> UILocationSolver == Service"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517507576168" FOLDED="true" ID="ID_700127725" MODIFIED="1561827483831" TEXT="LocationClause">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517507586447" ID="ID_170204980" MODIFIED="1518487921069" TEXT="eingebettete UI-Coord">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517507596445" ID="ID_386656276" MODIFIED="1518487921069" TEXT="zusätzliche Flags">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518312817798" ID="ID_473624624" MODIFIED="1518487921069">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Schreibweise für <i>create Clauses</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505346701" ID="ID_1733459677" MODIFIED="1561827465086" TEXT="LocationSolver einführen">
|
|
<linktarget COLOR="#7999a3" DESTINATION="ID_1733459677" ENDARROW="Default" ENDINCLINATION="460;0;" ID="Arrow_ID_1447990036" SOURCE="ID_570287604" STARTARROW="None" STARTINCLINATION="-15;211;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517505662323" ID="ID_1295083929" MODIFIED="1518487921069" TEXT="baut auf LocationQuery auf">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505700422" ID="ID_387055301" MODIFIED="1518487921069" TEXT="erweiterte solve()-Methode">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505717508" FOLDED="true" ID="ID_636863312" MODIFIED="1561827483831" TEXT="Framework für mehrere Klauseln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517506971514" ID="ID_1227765715" MODIFIED="1518487921069" TEXT="Iterator(LocationClause const&)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508131749" FOLDED="true" ID="ID_1527522188" MODIFIED="1561827482927" TEXT="LocationRule">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517508155177" ID="ID_1404330274" MODIFIED="1518487921069" TEXT="vector(LocationClause (values))">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508205555" ID="ID_1524544821" MODIFIED="1518487921069" TEXT="Iterator daraus generieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508218889" ID="ID_360290307" MODIFIED="1518487921069" TEXT="Alternative anfügen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505737977" FOLDED="true" ID="ID_606655578" MODIFIED="1561827483831" TEXT="Lösungsmechanismus">
|
|
<arrowlink COLOR="#8b9e9d" DESTINATION="ID_1945600026" ENDARROW="None" ENDINCLINATION="341;-39;" ID="Arrow_ID_360373706" STARTARROW="Default" STARTINCLINATION="-302;83;"/>
|
|
<linktarget COLOR="#8b9e9d" DESTINATION="ID_606655578" ENDARROW="Default" ENDINCLINATION="-152;43;" ID="Arrow_ID_1433975114" SOURCE="ID_783849930" STARTARROW="None" STARTINCLINATION="213;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517507636416" ID="ID_1159293904" MODIFIED="1518487921069" TEXT="für jede Klausel...">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506994783" ID="ID_1943710017" MODIFIED="1518487921069" TEXT="baut jeweils UICorrdResolver">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518658805744" FOLDED="true" ID="ID_1208480183" MODIFIED="1561827482927" TEXT="Kontext-Bindung">
|
|
<arrowlink COLOR="#e46465" DESTINATION="ID_68856104" ENDARROW="Default" ENDINCLINATION="74;449;" ID="Arrow_ID_110301671" STARTARROW="None" STARTINCLINATION="-232;7;"/>
|
|
<linktarget COLOR="#8e6e9e" DESTINATION="ID_1208480183" ENDARROW="Default" ENDINCLINATION="-458;-16;" ID="Arrow_ID_504124124" SOURCE="ID_839916178" STARTARROW="None" STARTINCLINATION="-600;49;"/>
|
|
<linktarget COLOR="#b78791" DESTINATION="ID_1208480183" ENDARROW="Default" ENDINCLINATION="-1240;134;" ID="Arrow_ID_831550289" SOURCE="ID_481219776" STARTARROW="None" STARTINCLINATION="1654;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1518659629689" ID="ID_666680369" MODIFIED="1518659660281" TEXT="Löse-Funktion bekommt Kontext"/>
|
|
<node CREATED="1518660033466" ID="ID_1879301424" MODIFIED="1518660044053" TEXT="jede Klausel wird vorbehandelt"/>
|
|
<node CREATED="1518660206867" ID="ID_1357657997" MODIFIED="1518660237412">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
technische Lösug <i>diskutierbar</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen,
|
|
</p>
|
|
<p>
|
|
man kann das erheblich tief und generisch ausbauen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1518742862470" ID="ID_588911138" MODIFIED="1518742880332" TEXT="YAGNI">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518762499749" FOLDED="true" ID="ID_214794727" MODIFIED="1561827482927">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Perspective <i>elided</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#8eacb9" DESTINATION="ID_214794727" ENDARROW="Default" ENDINCLINATION="-653;0;" ID="Arrow_ID_1678351989" SOURCE="ID_606433871" STARTARROW="None" STARTINCLINATION="1400;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518762520034" ID="ID_1516856737" MODIFIED="1518839506876" TEXT="hier automatisch injizieren">
|
|
<linktarget COLOR="#595f8d" DESTINATION="ID_1516856737" ENDARROW="Default" ENDINCLINATION="302;0;" ID="Arrow_ID_241747952" SOURCE="ID_1943028471" STARTARROW="None" STARTINCLINATION="697;-153;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1518762547918" ID="ID_1868672591" MODIFIED="1518762557041" TEXT="nur für create()-Klauseln"/>
|
|
<node CREATED="1518762532376" ID="ID_720810877" MODIFIED="1518762565908" TEXT="pragmatische Lösung, statt voller Unifikation">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1518838263050" FOLDED="true" ID="ID_443518928" MODIFIED="1561827469155" TEXT="Implementierung">
|
|
<node CREATED="1518838267457" ID="ID_943649771" MODIFIED="1518838276599" TEXT="als pre-Processing im Solver">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1518838283262" FOLDED="true" ID="ID_238691976" MODIFIED="1561827469136" TEXT="wie Pattern modifizieren?">
|
|
<node CREATED="1518838298468" ID="ID_753244692" MODIFIED="1518838305407" TEXT="muß überschreiben">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1518838306835" FOLDED="true" ID="ID_1187474816" MODIFIED="1525124214993" TEXT="overwrite ist protected">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1518838316762" ID="ID_375483047" MODIFIED="1518838388905" TEXT="aus gutem Grund">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn durch overwrite kann man denormalisierte Pattern erzeugen.
|
|
</p>
|
|
<p>
|
|
Also muß jeder Anwender dieser Funktion sicherstellen, daß dies
|
|
</p>
|
|
<p>
|
|
entweder nicht passieren kann, oder explizit normalise() aufrufen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1518838372771" ID="ID_1787971906" MODIFIED="1518838384249" TEXT="das soll in der Schachtel bleiben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518838394663" ID="ID_1070204465" MODIFIED="1518839504321" TEXT="der Resolver muß das für uns machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517507036433" ID="ID_921121750" MODIFIED="1518487921069" TEXT="zieht die Antwort bei ersem Erfolg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518051766018" ID="ID_1447232325" MODIFIED="1518487921069" TEXT="brauche neue Resolver-Primitive">
|
|
<arrowlink COLOR="#50546a" DESTINATION="ID_1272905286" ENDARROW="Default" ENDINCLINATION="394;1164;" ID="Arrow_ID_396720500" STARTARROW="None" STARTINCLINATION="1558;-33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518055049276" FOLDED="true" ID="ID_1963190796" MODIFIED="1561827482927" TEXT="Fallunterscheidung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518055059890" FOLDED="true" ID="ID_1240967474" MODIFIED="1561827469155" TEXT="Standard: totale Coverage!">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518055394000" ID="ID_1230502265" MODIFIED="1518487921069" TEXT="alles bis auf Komponente selber muß bestätigt sein">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1518215016983" ID="ID_643091836" MODIFIED="1518487921069" TEXT="ggfs anzuhängende KOmponente nicht Teil der Lösung"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518055089510" FOLDED="true" ID="ID_1374209563" MODIFIED="1561827469155" TEXT="Create-Fall">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518055442607" ID="ID_93235547" MODIFIED="1518487921069" TEXT="partielle coverage erlauben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518055453981" FOLDED="true" ID="ID_1927049673" MODIFIED="1561827469136" TEXT="Frage: totale Neuerzeugung unterstützen?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das würde bedeuten, daß man sogar ein neues Hauptfenster erzeugt.
|
|
</p>
|
|
<p>
|
|
Also in diesem Fall würde überhaupt nichts mit dem existierenden UI matchen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1518145517036" ID="ID_272248384" MODIFIED="1518487921069" TEXT="ja">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518145521684" ID="ID_17194778" MODIFIED="1518487921069" TEXT="ungedeckter Pfad muß explizit sein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518055400412" ID="ID_1517580371" MODIFIED="1518487921069">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Komponente <i>falls nötig</i> anhängen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518215051242" FOLDED="true" ID="ID_1984395087" MODIFIED="1561827469155" TEXT="Ablauf-Logik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518213040236" FOLDED="true" ID="ID_1048898871" MODIFIED="1561827469136" STYLE="bubble" TEXT="Längenbeschrenkung">
|
|
<node BACKGROUND_COLOR="#b6c6f7" CREATED="1518213142062" ID="ID_1389235831" MODIFIED="1518487921069" TEXT="next"/>
|
|
</node>
|
|
<node CREATED="1518213047987" ID="ID_1894250137" MODIFIED="1518487921069" STYLE="bubble" TEXT="Klausel lösen"/>
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213057553" FOLDED="true" ID="ID_1840655064" MODIFIED="1561827469136" STYLE="bubble" TEXT="Standard/Create?">
|
|
<arrowlink COLOR="#4976b7" DESTINATION="ID_1713281564" ENDARROW="Default" ENDINCLINATION="-214;-32;" ID="Arrow_ID_1015037061" STARTARROW="None" STARTINCLINATION="-133;64;"/>
|
|
<node CREATED="1518213079183" FOLDED="true" ID="ID_533214872" MODIFIED="1525124214993" TEXT="Standard">
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213086862" FOLDED="true" ID="ID_6239293" MODIFIED="1525124214993" TEXT="totalyCovered?">
|
|
<node CREATED="1518213134767" FOLDED="true" ID="ID_775708906" MODIFIED="1525124214993" TEXT="nein?">
|
|
<node BACKGROUND_COLOR="#b6c6f7" CREATED="1518213142062" ID="ID_1245747447" MODIFIED="1518487921069" TEXT="next"/>
|
|
</node>
|
|
<node CREATED="1518213159380" FOLDED="true" ID="ID_213462597" MODIFIED="1525124214993" TEXT="ja?">
|
|
<node CREATED="1518213162419" ID="ID_109286322" MODIFIED="1518487921070" TEXT="ggfs Elmnt anhngn"/>
|
|
<node BACKGROUND_COLOR="#efbab6" CREATED="1518213219564" ID="ID_1188365373" MODIFIED="1518487921070" TEXT="move(Solution)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518213235362" FOLDED="true" ID="ID_977251605" MODIFIED="1525124214994" TEXT="Create">
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213253255" FOLDED="true" ID="ID_1769779207" MODIFIED="1525124214994" TEXT="not empty?">
|
|
<node CREATED="1518213302080" FOLDED="true" ID="ID_1846077322" MODIFIED="1525124214993" TEXT="ja?">
|
|
<node CREATED="1518213162419" ID="ID_51616856" MODIFIED="1518487921070" TEXT="ggfs Elmnt anhngn"/>
|
|
<node BACKGROUND_COLOR="#efbab6" CREATED="1518213219564" ID="ID_1352698993" MODIFIED="1518487921070" TEXT="move(Solution)"/>
|
|
</node>
|
|
<node CREATED="1518213331788" FOLDED="true" ID="ID_1239103431" MODIFIED="1525124214994" TEXT="nein?">
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213337332" FOLDED="true" ID="ID_901388238" MODIFIED="1525124214994" TEXT="Klausel explizit?">
|
|
<node BACKGROUND_COLOR="#efbab6" CREATED="1518213440630" ID="ID_1608293138" MODIFIED="1518213851674" STYLE="bubble" TEXT="copy(Klausel)">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
</node>
|
|
<node CREATED="1518213451860" FOLDED="true" ID="ID_1678375217" MODIFIED="1525124214993" TEXT="Wildcards">
|
|
<node BACKGROUND_COLOR="#b6c6f7" CREATED="1518213469114" ID="ID_239069612" MODIFIED="1518487921070" TEXT="next"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518145595274" FOLDED="true" ID="ID_1539200142" MODIFIED="1561827482927" TEXT="in jedem Fall korrekte Länge sicherstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518212471553" FOLDED="true" ID="ID_1821401889" MODIFIED="1561827469155" TEXT="Frage: wann?">
|
|
<node CREATED="1518212565636" ID="ID_1223770753" MODIFIED="1518487921070" TEXT="Lösen einer zu kurzen Klausel bringt nix">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil wir keinen Zustand sammeln
|
|
</p>
|
|
<p>
|
|
und daher jede Klausel von Grund auf neu lösen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1518212627092" ID="ID_1184420038" MODIFIED="1518487921070" TEXT="...also kann man die sofort wegsortieren"/>
|
|
</node>
|
|
<node CREATED="1518212670854" FOLDED="true" ID="ID_1003923585" MODIFIED="1561827469155" TEXT="Frage: zu lange Klauseln?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1518212721599" ID="ID_1131508916" MODIFIED="1518487921070" TEXT="...wären nachträglich unter Ziel-Level zu kürzen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1518212683340" ID="ID_1968312736" MODIFIED="1518487921070">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>könnte</i> man zulassen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1518212772256" ID="ID_1238641704" MODIFIED="1518487921070" TEXT="YAGNI">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518212791566" FOLDED="true" ID="ID_1644096915" MODIFIED="1561827469156" TEXT="Ergebnis">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1518212828593" ID="ID_351911326" MODIFIED="1518487921070" TEXT="gegeben: depth, auf welcher Zielelement aufgesetzt wird">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1518212871379" ID="ID_451555590" MODIFIED="1518487921070" TEXT="len >= depth"/>
|
|
<node CREATED="1518212959895" ID="ID_930933486" MODIFIED="1518487921070" TEXT="len <= depth+1"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518145778249" FOLDED="true" ID="ID_462394658" MODIFIED="1561827482927" TEXT="Fälle geschickt zusammenfassen (duplikate Aktionen)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213086862" FOLDED="true" ID="ID_1713281564" MODIFIED="1561827469156" STYLE="bubble">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
not empty? UND
|
|
</p>
|
|
<p>
|
|
Create ODER totalyCovered?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#4976b7" DESTINATION="ID_1713281564" ENDARROW="Default" ENDINCLINATION="-214;-32;" ID="Arrow_ID_1015037061" SOURCE="ID_1840655064" STARTARROW="None" STARTINCLINATION="-133;64;"/>
|
|
<node CREATED="1518213159380" FOLDED="true" ID="ID_1113830798" MODIFIED="1561827469137" TEXT="ja?">
|
|
<node CREATED="1518213162419" ID="ID_621215851" MODIFIED="1518487921070" TEXT="ggfs Elmnt anhngn"/>
|
|
<node BACKGROUND_COLOR="#efbab6" CREATED="1518213219564" ID="ID_1128021646" MODIFIED="1518487921070" TEXT="move(Solution)"/>
|
|
</node>
|
|
<node CREATED="1518213134767" FOLDED="true" ID="ID_679511688" MODIFIED="1561827469137" TEXT="nein?">
|
|
<node BACKGROUND_COLOR="#efedc4" CREATED="1518213337332" FOLDED="true" ID="ID_1046262927" MODIFIED="1525124214998" TEXT="Create UND Klausel explizit?">
|
|
<node CREATED="1518214337116" FOLDED="true" ID="ID_1397265252" MODIFIED="1525124214998" TEXT="ja">
|
|
<node BACKGROUND_COLOR="#efbab6" CREATED="1518213440630" ID="ID_343251054" MODIFIED="1518213851674" STYLE="bubble" TEXT="copy(Klausel)">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518213451860" FOLDED="true" ID="ID_1801836476" MODIFIED="1525124214998" TEXT="sonst">
|
|
<node BACKGROUND_COLOR="#b6c6f7" CREATED="1518213469114" ID="ID_955201730" MODIFIED="1518487921070" TEXT="next"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517507082826" ID="ID_1177191870" MODIFIED="1518487921070" TEXT="Rückgabe per Value">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517505737977" FOLDED="true" ID="ID_1981924615" MODIFIED="1561827483831" TEXT="Unit-Test">
|
|
<arrowlink COLOR="#465888" DESTINATION="ID_957265584" ENDARROW="Default" ENDINCLINATION="351;-62;" ID="Arrow_ID_1922023705" STARTARROW="None" STARTINCLINATION="-226;69;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518312788963" ID="ID_1715641481" MODIFIED="1518487921070" TEXT="brauche Setup">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518312794346" FOLDED="true" ID="ID_98359518" MODIFIED="1561827482927" TEXT="Schreibweise für create-Klauseln im Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518317872064" ID="ID_230463403" MODIFIED="1518487921070" TEXT="verwende normale Koordinaten-Notation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1518317892197" ID="ID_20769359" MODIFIED="1518487921070" TEXT="forward-Definition des Konversionsoperators"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1519347191513" ID="ID_1058958215" MODIFIED="1561827465124" TEXT="Zugang zum LocationSolver">
|
|
<arrowlink COLOR="#33a0d6" DESTINATION="ID_1459009906" ENDARROW="Default" ENDINCLINATION="766;0;" ID="Arrow_ID_393354619" STARTARROW="None" STARTINCLINATION="-338;0;"/>
|
|
<linktarget COLOR="#3391c4" DESTINATION="ID_1058958215" ENDARROW="Default" ENDINCLINATION="356;0;" ID="Arrow_ID_1958186293" SOURCE="ID_782466951" STARTARROW="None" STARTINCLINATION="40;166;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1519347295051" ID="ID_846050459" MODIFIED="1522808896717" TEXT="im realen UI">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1519347289508" FOLDED="true" ID="ID_723600288" MODIFIED="1561827483831" TEXT="setup für Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522883291235" ID="ID_543936991" MODIFIED="1522883304073" TEXT="GenNodeLocationQuery">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522883297346" ID="ID_1901671292" MODIFIED="1522883303346" TEXT="darauf aufbauender Mock">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1519347266311" ID="ID_1347610352" MODIFIED="1561827465125" TEXT="Funktor-Anwendung implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522808910387" ID="ID_900668862" MODIFIED="1522808936078" TEXT="war Watschn-einfach">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522808920794" ID="ID_93861490" MODIFIED="1522808948322" TEXT="nachdem ich 14 Tage lang das DI-Framework umgebaut habe">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506090553" HGAP="59" ID="ID_1416624438" MODIFIED="1531584013571" TEXT="UILocationSolver" VSHIFT="-20">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1517506104183" ID="ID_798223993" MODIFIED="1522808764330" STYLE="fork" TEXT="ansiedeln im ViewLocator">
|
|
<node CREATED="1522808738035" ID="ID_1951089115" MODIFIED="1522808764329" TEXT="als Service exportieren"/>
|
|
<node CREATED="1522808746394" ID="ID_1564866088" MODIFIED="1522808764329" TEXT="selber mit dem Navigator hinterlegt"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506116502" ID="ID_1945600026" MODIFIED="1522808819872" TEXT="#1127 UILocationSolver">
|
|
<linktarget COLOR="#8b9e9d" DESTINATION="ID_1945600026" ENDARROW="None" ENDINCLINATION="341;-39;" ID="Arrow_ID_360373706" SOURCE="ID_606655578" STARTARROW="Default" STARTINCLINATION="-302;83;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506590574" ID="ID_1459009906" MODIFIED="1522808712178" TEXT="hinten herum verdrahten">
|
|
<linktarget COLOR="#33a0d6" DESTINATION="ID_1459009906" ENDARROW="Default" ENDINCLINATION="766;0;" ID="Arrow_ID_393354619" SOURCE="ID_1058958215" STARTARROW="None" STARTINCLINATION="-338;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517508464896" ID="ID_877224411" MODIFIED="1522938360510" TEXT="generische Aufruf-Schnittstelle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506116502" ID="ID_957265584" MODIFIED="1518487921070" TEXT="eigenständiger Unit-Test">
|
|
<arrowlink COLOR="#465888" DESTINATION="ID_718086573" ENDARROW="Default" ENDINCLINATION="-185;-461;" ID="Arrow_ID_1844529849" STARTARROW="None" STARTINCLINATION="-598;29;"/>
|
|
<linktarget COLOR="#465888" DESTINATION="ID_957265584" ENDARROW="Default" ENDINCLINATION="351;-62;" ID="Arrow_ID_1922023705" SOURCE="ID_1981924615" STARTARROW="None" STARTINCLINATION="-226;69;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506181864011" ID="ID_615395774" MODIFIED="1518487921070" TEXT="Alternativen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515631663265" ID="ID_1149231463" MODIFIED="1518487921070" TEXT="ODER-Operator">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1517970584075" ID="ID_1155445128" MODIFIED="1533608413740" TEXT="Syntax / DSL-Technik">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1517970606791" ID="ID_1375091296" MODIFIED="1561827465125" TEXT="Operatoren haben feste Präzedenz">
|
|
<node CREATED="1517970623613" ID="ID_271068747" MODIFIED="1518487921070" TEXT="OR bindet stärker als Zuweisung"/>
|
|
<node CREATED="1517970650217" ID="ID_1384466296" MODIFIED="1518487921070" TEXT="LocationSpec = ( UICoord::Builder || UICoord)"/>
|
|
</node>
|
|
<node CREATED="1517970828105" ID="ID_803913203" MODIFIED="1561827465126" TEXT="mögliche Alternativen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1517970849142" FOLDED="true" ID="ID_1434826323" MODIFIED="1561827483831" TEXT="Komma-Operator verwenden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1517970857389" ID="ID_815195379" MODIFIED="1518487921070" TEXT="bindet schwächer als Zuweisung"/>
|
|
<node CREATED="1517970865180" ID="ID_349717845" MODIFIED="1518487921070" TEXT="wird folglich auf LocationSpec definiert"/>
|
|
<node CREATED="1517971057730" ID="ID_1385090987" MODIFIED="1518487921070" TEXT="somit einfach zu implementieren"/>
|
|
<node CREATED="1517971070856" ID="ID_1569393703" MODIFIED="1518487921070" TEXT="sauber aus Sicht der Code-Organisation"/>
|
|
<node CREATED="1517971082198" ID="ID_821482262" MODIFIED="1518487921070" TEXT="aber semantisch irreführend">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Komma heißt "and then" in der Logikprogrammierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1517970882714" FOLDED="true" ID="ID_1615423213" MODIFIED="1561827483832" TEXT="Builder muß bereits mit OR umgehen können">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1517971040980" ID="ID_1600012363" MODIFIED="1518487921070" TEXT="vermischt die Themen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1517971023823" ID="ID_1961997914" MODIFIED="1518487921070" TEXT="verkehrt die Definitions-Reihenfolge"/>
|
|
</node>
|
|
<node CREATED="1517970999466" FOLDED="true" ID="ID_1299498209" MODIFIED="1561827483832" TEXT="freier OR-Operator im DSL-Kontext definiert">
|
|
<linktarget COLOR="#55618e" DESTINATION="ID_1299498209" ENDARROW="Default" ENDINCLINATION="115;1000;" ID="Arrow_ID_1706569145" SOURCE="ID_1413272427" STARTARROW="None" STARTINCLINATION="561;-39;"/>
|
|
<node CREATED="1517971299201" ID="ID_1350388784" MODIFIED="1518487921070" TEXT="Builder || UICoord -> LocationRule(LocationClause) . add(LocationClause)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1519355632354" ID="ID_1664602603" MODIFIED="1533608413744" TEXT="wo entsteht die LocationRule?">
|
|
<linktarget COLOR="#647b96" DESTINATION="ID_1664602603" ENDARROW="Default" ENDINCLINATION="1374;300;" ID="Arrow_ID_947721778" SOURCE="ID_241646491" STARTARROW="None" STARTINCLINATION="298;36;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1519355656423" ID="ID_1547517953" MODIFIED="1561827465128" TEXT="in der LocationSpec">
|
|
<node CREATED="1520207968932" ID="ID_1172076522" MODIFIED="1520207982341" TEXT="wenn eine einfache Ortsangabe gegeben ist"/>
|
|
<node CREATED="1520208008190" ID="ID_874779146" MODIFIED="1520208019664" TEXT="dann wird aus dem Builder inline eine LocationClause gemacht"/>
|
|
</node>
|
|
<node CREATED="1519355666797" ID="ID_1270620528" MODIFIED="1561827465128" TEXT="vor der LocationSpec">
|
|
<node CREATED="1520207985113" ID="ID_372230629" MODIFIED="1520208000019" TEXT="wenn mehrere Angaben per OR verbunden werden"/>
|
|
<node CREATED="1520208026027" ID="ID_409650611" MODIFIED="1520208035510" TEXT="dann passiert die Umwandlung bereits im operator OR"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518312758758" ID="ID_675085959" MODIFIED="1518835387835" TEXT="Schreibweise für create-Klauseln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515631675752" ID="ID_1586757410" MODIFIED="1518835393496" TEXT="Repräsentation als Liste von UICoord">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515631690390" ID="ID_783849930" MODIFIED="1518835396708" TEXT=""committed choice" Lösungsmechanismus">
|
|
<arrowlink COLOR="#8b9e9d" DESTINATION="ID_606655578" ENDARROW="Default" ENDINCLINATION="-152;43;" ID="Arrow_ID_1433975114" STARTARROW="None" STARTINCLINATION="213;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506181842670" ID="ID_229712638" MODIFIED="1518487921070" TEXT="Allocator">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1515631726569" ID="ID_1252372720" MODIFIED="1529076581800" TEXT="wie mit ViewLocator-Service verdrahten?">
|
|
<linktarget COLOR="#614483" DESTINATION="ID_1252372720" ENDARROW="Default" ENDINCLINATION="-203;-10;" ID="Arrow_ID_1759099248" SOURCE="ID_1454085887" STARTARROW="Default" STARTINCLINATION="-373;-23;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1515803834302" ID="ID_1965813896" MODIFIED="1518487921070" TEXT="überhaupt nicht auf DSL-Ebene"/>
|
|
<node CREATED="1515803844276" ID="ID_512581752" MODIFIED="1518487921070">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur "hinten herum" über die verwendete <b>LocationQuery</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515631909081" ID="ID_1875881401" MODIFIED="1518487921071" TEXT="Aufrufe auf ViewLocator-API übersetzen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1523118005620" ID="ID_1743128010" MODIFIED="1529076770399" TEXT="klären: auf welches API nun wirklich">
|
|
<linktarget COLOR="#74d8d6" DESTINATION="ID_1743128010" ENDARROW="Default" ENDINCLINATION="205;0;" ID="Arrow_ID_1437087367" SOURCE="ID_539031017" STARTARROW="None" STARTINCLINATION="205;0;"/>
|
|
<linktarget COLOR="#ef9f88" DESTINATION="ID_1743128010" ENDARROW="Default" ENDINCLINATION="-2099;1258;" ID="Arrow_ID_175864704" SOURCE="ID_1335551290" STARTARROW="Default" STARTINCLINATION="-20;-1838;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1529076725873" HGAP="102" ID="ID_995038834" MODIFIED="1529076865273" TEXT="Es ist das ElementAccess-API" VSHIFT="-7">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1529076845081" HGAP="113" ID="ID_1049440738" MODIFIED="1529076871065" TEXT=""irgendwo" gibts dazu das ElemAccessDir" VSHIFT="-30">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1523117208251" FOLDED="true" HGAP="27" ID="ID_1210359211" MODIFIED="1561827465133" TEXT="ist das nicht furchbar verschwenderisch...?" VSHIFT="4">
|
|
<linktarget COLOR="#abc5e4" DESTINATION="ID_1210359211" ENDARROW="Default" ENDINCLINATION="-217;-87;" ID="Arrow_ID_1226100946" SOURCE="ID_1972679538" STARTARROW="None" STARTINCLINATION="-187;427;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1523117293583" ID="ID_1129944871" MODIFIED="1523117297666" TEXT="schrittweise...">
|
|
<node CREATED="1523117228552" ID="ID_11867965" MODIFIED="1523117242297" TEXT="wir verwenden erst einen Resolver"/>
|
|
<node CREATED="1523117242910" ID="ID_260255550" MODIFIED="1523117250656" TEXT="dabei wird der Pfad aufgedröselt"/>
|
|
<node CREATED="1523117251365" ID="ID_1344883302" MODIFIED="1523117269374" TEXT="dann das Ergebnis in einen neuen Pfad kopiert"/>
|
|
<node CREATED="1523117269970" ID="ID_1283489925" MODIFIED="1523117277269" TEXT="und dieser muß dann wieder aufgedröselt werden"/>
|
|
<node CREATED="1523117278161" ID="ID_1145162087" MODIFIED="1523117288019" TEXT="um das das Ergebnis auch umzusetzen"/>
|
|
</node>
|
|
<node CREATED="1523117332841" ID="ID_58827305" MODIFIED="1523117335261" TEXT="effektiv">
|
|
<node CREATED="1523117336257" ID="ID_1661836054" MODIFIED="1523117354618" TEXT="zwei Traversierungen der realen UI-Struktur"/>
|
|
<node CREATED="1523117355966" ID="ID_901586822" MODIFIED="1533608413745" TEXT="die sich unterscheiden">
|
|
<node CREATED="1523117363405" ID="ID_415134573" MODIFIED="1523117377647" TEXT="die erste ist eine depth-first Suche (aufwendig)"/>
|
|
<node CREATED="1523117378307" ID="ID_228369164" MODIFIED="1523117399516" TEXT="die zweite steigt zum Lösungspunkt der ersten nochmal ab"/>
|
|
<node CREATED="1523117436451" ID="ID_1526973711" MODIFIED="1523117445502" TEXT="und baut dort i.d.R weitere Elemente an"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523117416901" ID="ID_666361594" MODIFIED="1523117419705" TEXT="Optimierung">
|
|
<node CREATED="1523117421189" ID="ID_1083685803" MODIFIED="1523117433679" TEXT="den vollen Kontext von der Lösung zur zweiten Traversierung durchreichen"/>
|
|
<node CREATED="1523117477813" ID="ID_5382937" MODIFIED="1533608413745" TEXT="Problem... nicht alles sind Lösungen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1523117488172" ID="ID_1947043295" MODIFIED="1523117492743" TEXT="es gibt zwei Fälle"/>
|
|
<node CREATED="1523117493427" ID="ID_391352800" MODIFIED="1523117501086" TEXT="nur in einem Fall wird eine Lösung konstruiert"/>
|
|
<node CREATED="1523117501722" ID="ID_1104653648" MODIFIED="1523117510604" TEXT="im anderen Fall wird der Pfad direkt interpretiert"/>
|
|
</node>
|
|
<node CREATED="1523117563481" ID="ID_1561615666" MODIFIED="1533608413746" TEXT="Einspar-Potential">
|
|
<node CREATED="1523117578175" ID="ID_17072072" MODIFIED="1523117605679" TEXT="erneuter Einstieg"/>
|
|
<node CREATED="1523117606179" ID="ID_1306679723" MODIFIED="1523117618878" TEXT="i.d.R. Window - Panel - View"/>
|
|
<node CREATED="1523117625392" ID="ID_1699581450" MODIFIED="1523117630964" TEXT="vermutlich gering gegenüber Suche"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1523117634200" ID="ID_249271137" MODIFIED="1523117761784" TEXT="Fazit">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1523117637807" ID="ID_1136409597" MODIFIED="1523117654081" TEXT="Optimierungs-Gewinn nicht offensichtlich, vermutlich gering"/>
|
|
<node CREATED="1523117656380" ID="ID_375543215" MODIFIED="1523117676286" TEXT="Optimierung würde die Schnittstelle komplex machen"/>
|
|
<node CREATED="1523117678010" ID="ID_988976556" MODIFIED="1523117691307" TEXT="die Schnittstelle ist ohnehin schon nicht leicht zu verstehen"/>
|
|
<node CREATED="1523117735746" ID="ID_1310906003" MODIFIED="1523117755013">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
klassischer Fall von »<b>premature optimisation</b>«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354320645" FOLDED="true" ID="ID_431727101" MODIFIED="1519354329172" TEXT="Verhältnis zur DSL">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1519354355113" ID="ID_1466028228" MODIFIED="1519354361395" TEXT="die Aloc-Specs delegieren"/>
|
|
<node CREATED="1519354365423" ID="ID_1473090391" MODIFIED="1519354379881" TEXT="jede Aloc-Speck entspricht einem Service"/>
|
|
<node COLOR="#435e98" CREATED="1519354380677" ID="ID_1029266700" MODIFIED="1529076963809" TEXT="wer bietet diesen Service?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1519355147108" ID="ID_1615393259" MODIFIED="1533608413746" TEXT="in Frage kommen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1519355157603" ID="ID_1219922150" MODIFIED="1519355160662" TEXT="ViewLocator"/>
|
|
<node CREATED="1519355161347" ID="ID_560748249" MODIFIED="1519355167270" TEXT="Navigator"/>
|
|
<node CREATED="1519355186551" ID="ID_1807778011" MODIFIED="1519355191106" TEXT="PanelManager"/>
|
|
</node>
|
|
<node CREATED="1519355289985" ID="ID_239681113" MODIFIED="1519355336332" TEXT="ViewLocator == Dispatcher">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1519355201077" HGAP="31" ID="ID_539031017" MODIFIED="1529076927655" VSHIFT="13">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wer interpretiert
|
|
</p>
|
|
<p>
|
|
UI-Koordinaten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#74d8d6" DESTINATION="ID_1743128010" ENDARROW="Default" ENDINCLINATION="205;0;" ID="Arrow_ID_1437087367" STARTARROW="None" STARTINCLINATION="205;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1529076931278" ID="ID_1289639668" MODIFIED="1533608413746" TEXT="ElemAccessDir">
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1529076946755" ID="ID_104892802" MODIFIED="1529076957961" TEXT="derzeit noch nicht implementierbar">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354420343" HGAP="28" ID="ID_17801598" MODIFIED="1533685336238" TEXT="Varianten" VSHIFT="21">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354443485" ID="ID_1474832227" MODIFIED="1533608413747" TEXT="always create">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354760313" ID="ID_321705251" MODIFIED="1561827465133" TEXT="Umgang mit Duplikaten">
|
|
<linktarget COLOR="#807e9b" DESTINATION="ID_321705251" ENDARROW="Default" ENDINCLINATION="127;-96;" ID="Arrow_ID_1030149985" SOURCE="ID_1792932496" STARTARROW="None" STARTINCLINATION="390;-188;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1519354813458" ID="ID_168710453" MODIFIED="1519354818789" TEXT="beiseite schieben"/>
|
|
<node CREATED="1519354819473" ID="ID_996615547" MODIFIED="1519354824572" TEXT="Tab innerhalb erzeugen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1519354769960" ID="ID_778018274" MODIFIED="1533685343441" TEXT="Festlegung: was sind die Namen?">
|
|
<linktarget COLOR="#2b4283" DESTINATION="ID_778018274" ENDARROW="Default" ENDINCLINATION="-1752;0;" ID="Arrow_ID_1022345699" SOURCE="ID_377787861" STARTARROW="None" STARTINCLINATION="795;544;"/>
|
|
<linktarget COLOR="#5260a0" DESTINATION="ID_778018274" ENDARROW="Default" ENDINCLINATION="-1217;51;" ID="Arrow_ID_597388409" SOURCE="ID_266745032" STARTARROW="None" STARTINCLINATION="686;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1519357238119" ID="ID_490731063" MODIFIED="1519357248970" TEXT="Namen sind Platzhalter-Symbole"/>
|
|
<node CREATED="1519357249702" ID="ID_1135871152" MODIFIED="1519357313101">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
um eine <i>Position</i> zu kennzeichnen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1519357262332" ID="ID_1067286247" MODIFIED="1519357267471" TEXT="sie sind generisch"/>
|
|
<node CREATED="1519357271642" ID="ID_693336166" MODIFIED="1519357284653" TEXT="werden lokal verstanden"/>
|
|
<node CREATED="1519357285265" ID="ID_1314676655" MODIFIED="1529077188628" TEXT="Schlüssel-Schloß-Prinzip">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354459978" ID="ID_1281610608" MODIFIED="1519354465459" TEXT="create or retrieve">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1519354633610" ID="ID_205066693" MODIFIED="1533608413750" TEXT="welches Limit ist notwendig?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1519354649560" ID="ID_1983794575" MODIFIED="1561827465134" TEXT="globales Limit">
|
|
<node CREATED="1519354660903" ID="ID_1601244663" MODIFIED="1519354670073" TEXT="Suche mit Zählen"/>
|
|
<node CREATED="1519354670949" ID="ID_803401695" MODIFIED="1519354673249" TEXT="Registry"/>
|
|
</node>
|
|
<node CREATED="1519354677373" ID="ID_1968452476" MODIFIED="1561827465134" TEXT="pro Fenster">
|
|
<node CREATED="1519354685828" ID="ID_966759751" MODIFIED="1519354691638" TEXT="genau wie global"/>
|
|
</node>
|
|
<node CREATED="1519354697578" ID="ID_1780825164" MODIFIED="1561827465134" TEXT="pro Endpunkt">
|
|
<node CREATED="1519354849469" ID="ID_1792932496" MODIFIED="1523752503840" TEXT="Variante des create-Mechanismus">
|
|
<arrowlink COLOR="#807e9b" DESTINATION="ID_321705251" ENDARROW="Default" ENDINCLINATION="127;-96;" ID="Arrow_ID_1030149985" STARTARROW="None" STARTINCLINATION="390;-188;"/>
|
|
</node>
|
|
<node CREATED="1519354723262" ID="ID_1902026620" MODIFIED="1519354929283" TEXT="erbt dessen mögliche Ausprägung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506181875481" ID="ID_941513985" MODIFIED="1518487921071" TEXT="AllocatorSpec">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515631937958" FOLDED="true" ID="ID_1051141312" MODIFIED="1561827465140" TEXT="partielle Funktions-Applikation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515725638196" ID="ID_919161877" MODIFIED="1525124215003" TEXT="geht das generisch...?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1515725146909" ID="ID_1363811781" MODIFIED="1515725162527" TEXT="lib::meta::func::PApply"/>
|
|
<node CREATED="1515725168850" ID="ID_612007718" MODIFIED="1515725199322" TEXT="analog zum applyLast() helper"/>
|
|
<node CREATED="1515725368856" ID="ID_194935085" MODIFIED="1515725407815" TEXT="PApply<SIG, ARGS>::bindBack"/>
|
|
<node CREATED="1515725202278" ID="ID_1268597725" MODIFIED="1515725220567" TEXT=""restliche Argumente" abgreifen"/>
|
|
<node CREATED="1515725440814" ID="ID_848138398" MODIFIED="1515725457544" TEXT="daraus Funktion fabrizieren, welche diese akzeptiert"/>
|
|
<node CREATED="1515725468723" ID="ID_1514420105" MODIFIED="1515725488084" TEXT="keine klassische partielle Applikation..."/>
|
|
<node CREATED="1515725488928" ID="ID_1084170574" MODIFIED="1515725505066" TEXT="sonder eine Art non-Standard currying"/>
|
|
</node>
|
|
<node CREATED="1515725713155" ID="ID_1250695567" MODIFIED="1525124215004" TEXT="würde schon gehen...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1515725719930" ID="ID_746038986" MODIFIED="1515725729012" TEXT="Aber man bekommt komplexere AlocSpec-Typen"/>
|
|
<node CREATED="1515726089841" ID="ID_527144420" MODIFIED="1576282358115" TEXT="der harte (technische) Teil ist bereits implementiert...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich in lib::meta::func::PApply::bindBack
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1515725834771" ID="ID_403863327" MODIFIED="1515725871768" TEXT="variadisch Template-Argumente">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1515725847329" ID="ID_1980343962" MODIFIED="1515725874461" TEXT="Wichtig: im ctor (Builder) statisch asserten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515726221600" ID="ID_1657507656" MODIFIED="1525124215006" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515726234742" ID="ID_95404514" MODIFIED="1533608413752" TEXT="Prinzip">
|
|
<node CREATED="1515726238061" ID="ID_1475189544" MODIFIED="1515726244416" TEXT="ctor nimmt beliebige Funktion"/>
|
|
<node CREATED="1515726245124" ID="ID_914794335" MODIFIED="1515726258014" TEXT="zerlegt und verifiziert Signatur"/>
|
|
<node CREATED="1515726258819" ID="ID_1930194336" MODIFIED="1561827465140" TEXT="generiert ein Lambda">
|
|
<node CREATED="1515726634601" ID="ID_41891466" MODIFIED="1515726639664" TEXT="geht das?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1515726644600" ID="ID_1701085444" MODIFIED="1576282358115" TEXT="C++14">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
// generic lambda, operator() is a template with one parameter
|
|
</p>
|
|
<p>
|
|
auto vglambda = [](auto printer) {
|
|
</p>
|
|
<p>
|
|
    return [=](auto&&... ts) // generic lambda, ts is a parameter pack
|
|
</p>
|
|
<p>
|
|
    {
|
|
</p>
|
|
<p>
|
|
        printer(std::forward<decltype(ts)>(ts)...);
|
|
</p>
|
|
<p>
|
|
        return [=] { printer(ts...); }; // nullary lambda (takes no parameters)
|
|
</p>
|
|
<p>
|
|
    };
|
|
</p>
|
|
<p>
|
|
};
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#ef5d2b" CREATED="1515726754041" ID="ID_315893428" LINK="http://en.cppreference.com/w/cpp/language/lambda" MODIFIED="1515726793618" TEXT="cppreference..."/>
|
|
<node COLOR="#ef5d2b" CREATED="1515726774055" ID="ID_1076829685" LINK="https://stackoverflow.com/questions/25885893/how-to-create-a-variadic-generic-lambda" MODIFIED="1515726793620" TEXT="stackoverflow..."/>
|
|
</node>
|
|
<node CREATED="1515726268721" ID="ID_243053845" MODIFIED="1515726329213" TEXT="welches intern PApply aufruft"/>
|
|
</node>
|
|
<node CREATED="1515732350136" ID="ID_1294398139" MODIFIED="1533608413754" TEXT="technisch....">
|
|
<node COLOR="#a41e57" CREATED="1515732356319" HGAP="25" ID="ID_1071937152" MODIFIED="1515800950319" TEXT="Problem: generisches Lambda in std::function binden">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1515732383331" ID="ID_1688687565" MODIFIED="1515797049652">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Vermutung: muß Lambda <b>instantiieren</b>...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1515797030493" ID="ID_973074141" MODIFIED="1561827465141" TEXT="Nein: es ist wohl ehr der Rückgabetyp">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515798991747" ID="ID_1053457138" MODIFIED="1515799030345" TEXT="Allocator erbt nur von function"/>
|
|
<node CREATED="1515799031197" ID="ID_516020279" MODIFIED="1515799045183" TEXT="Lambda liefert aber nur UICoord(UICoord)"/>
|
|
<node CREATED="1515799046027" ID="ID_1437287913" MODIFIED="1515799056910" TEXT="Lösung: Allocator als reine Typedef">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515801302955" ID="ID_208115762" MODIFIED="1561827465141" TEXT="Argument-Übergabe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515801313185" ID="ID_1411407565" MODIFIED="1515801322004" TEXT="Funktor bis in die Closure per Move"/>
|
|
<node CREATED="1515801324016" ID="ID_814347755" MODIFIED="1515801353352" TEXT="Closure an PApply per const& --> Binder erzeugen"/>
|
|
<node CREATED="1515801355124" ID="ID_1735797839" MODIFIED="1515801393059" TEXT="Lambda: Argumente in das Argument-Tupel per Move"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515631948148" ID="ID_1460703660" MODIFIED="1518487921071" TEXT="Funktor generieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515633963179" FOLDED="true" HGAP="-9" ID="ID_423312626" MODIFIED="1518487921071" TEXT="konkrete Bausteine" VSHIFT="34">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#4d316d" CREATED="1515633990048" ID="ID_750345391" MODIFIED="1518487921071" TEXT="komplett auf abstrakter Ebene zu implementieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1515634030562" ID="ID_662195926" MODIFIED="1522939171648" TEXT="Frage: geht das wirklich?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522939129671" ID="ID_905794690" MODIFIED="1522939133057" TEXT="Ja"/>
|
|
<node CREATED="1522939133701" ID="ID_1855483555" MODIFIED="1522939138277" TEXT="fast">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522939141372" ID="ID_767946441" MODIFIED="1522939169486" TEXT="wenn man "Dependencies" zuläßt">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522939154049" ID="ID_1331034331" MODIFIED="1522939163621" TEXT="LocationSolver"/>
|
|
<node CREATED="1522939164281" ID="ID_1465185092" MODIFIED="1522939166651" TEXT="Navigator"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515634054990" HGAP="44" ID="ID_146987308" MODIFIED="1518487921071" TEXT="Struktur-Lösung" VSHIFT="19">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1515634166656" ID="ID_760459550" MODIFIED="1518743424687" TEXT="UI-Coord-Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515634180942" ID="ID_1485314989" MODIFIED="1518487921071" TEXT="praktisch schon da">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1515634197876" ID="ID_731095389" MODIFIED="1518743462219" TEXT="Problem Asset-Tab...">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1515634208379" ID="ID_1341895683" MODIFIED="1518487921071" TEXT="Vermutung: auf backing service angewiesen"/>
|
|
<node CREATED="1518659373972" ID="ID_1782316588" MODIFIED="1518659386753" TEXT="ist eine Kontext-Auswertung/Bindung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1518659396385" ID="ID_986224819" MODIFIED="1518659504863" TEXT="in den Lösungsmechanismus zu integrieren">
|
|
<arrowlink COLOR="#967ea6" DESTINATION="ID_1831478029" ENDARROW="Default" ENDINCLINATION="-800;514;" ID="Arrow_ID_162294902" STARTARROW="None" STARTINCLINATION="693;-50;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515634249365" ID="ID_498582439" MODIFIED="1518487921071" TEXT="Allokator-Strategien">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1515634282345" ID="ID_788516837" MODIFIED="1518487921071" TEXT="klären, wer sie umsetzt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523752547477" ID="ID_1121433532" MODIFIED="1533608413756" TEXT="limitAllocation">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1523752559939" ID="ID_597346628" MODIFIED="1529079670933" TEXT="umsetzen auf ElementAccess-API">
|
|
<linktarget COLOR="#97cad5" DESTINATION="ID_597346628" ENDARROW="Default" ENDINCLINATION="126;9;" ID="Arrow_ID_89575203" SOURCE="ID_1979012219" STARTARROW="None" STARTINCLINATION="567;-16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1525567190247" ID="ID_42079899" MODIFIED="1561827465141" TEXT="Problem: API noch nicht vollständig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1525567207940" FOLDED="true" HGAP="76" ID="ID_1154047307" MODIFIED="1561827483832" TEXT="wirklich zwei Zugriffe?" VSHIFT="-9">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1525567242728" ID="ID_408728922" MODIFIED="1525567256385" TEXT="Finden / Allozieren">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1525567257934" ID="ID_756598430" MODIFIED="1525567271113" TEXT="Zugang zu diesem Element">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1525567314774" FOLDED="true" HGAP="-80" ID="ID_1634864230" MODIFIED="1561827482928" TEXT="warum?" VSHIFT="65">
|
|
<edge STYLE="linear"/>
|
|
<node CREATED="1525567347850" ID="ID_314618181" MODIFIED="1525567352685" TEXT="DSL sauber halten"/>
|
|
<node CREATED="1525567353825" ID="ID_729394034" MODIFIED="1525567362044" TEXT="Element-Access erfordert Visitor"/>
|
|
<node CREATED="1525567420608" ID="ID_1865194597" MODIFIED="1525567450407" TEXT="erscheint sinnvoll vom API her">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1525567432127" ID="ID_1190994966" MODIFIED="1528992332480" TEXT="aber dämlich in der Implementierung">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1525567474513" FOLDED="true" HGAP="136" ID="ID_492657286" MODIFIED="1561827483832" TEXT="ElementAccess-API umbauen" VSHIFT="5">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1529016810234" FOLDED="true" ID="ID_190701762" MODIFIED="1561827482928" TEXT="Möglichkeiten">
|
|
<node CREATED="1528988155980" FOLDED="true" ID="ID_425314989" MODIFIED="1561827469156" TEXT="Variante-1">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1528988234950" ID="ID_1668042554" MODIFIED="1528988252512" TEXT="UI-Coord zurückliefern"/>
|
|
<node CREATED="1528988263818" ID="ID_480404928" MODIFIED="1529016940289" TEXT="Element-Cache?"/>
|
|
<node CREATED="1529016904083" ID="ID_1517114370" MODIFIED="1529016934839" TEXT="API erweitern"/>
|
|
</node>
|
|
<node CREATED="1528988317699" FOLDED="true" ID="ID_1560503454" MODIFIED="1561827469156" TEXT="Variante-2 ">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1528988340425" ID="ID_1706382791" MODIFIED="1528988354569" TEXT="keine Erzeugung / Allokation"/>
|
|
<node CREATED="1528988355802" ID="ID_523121546" MODIFIED="1528988365328" TEXT="ElementAccess = reine Zugriffsfunktion"/>
|
|
<node CREATED="1528988379946" ID="ID_131306130" MODIFIED="1528988391702" TEXT="brauche anderweitige Abstraktion"/>
|
|
<node CREATED="1528988369596" ID="ID_1174830872" MODIFIED="1528988376583" TEXT="Allokator erzeugt anderweitig"/>
|
|
</node>
|
|
<node CREATED="1529016988678" FOLDED="true" ID="ID_1209500762" MODIFIED="1561827469156" TEXT="Variante-3">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1529017028938" ID="ID_359770283" MODIFIED="1529017068647" TEXT="Opaque Location Representation"/>
|
|
<node CREATED="1529017070019" ID="ID_57519695" MODIFIED="1529017101538" TEXT="Allocator-API darauf umstellen"/>
|
|
<node CREATED="1529017279135" ID="ID_707219104" MODIFIED="1529017285322" TEXT="(down)cast-Mechanismus"/>
|
|
</node>
|
|
<node CREATED="1529018080237" FOLDED="true" ID="ID_776753961" MODIFIED="1561827469156" TEXT="Variante-3b">
|
|
<icon BUILTIN="full-4"/>
|
|
<node CREATED="1529018093267" ID="ID_389715312" MODIFIED="1529018099078" TEXT="Hybrid-Lösung"/>
|
|
<node CREATED="1529018100234" ID="ID_1628139323" MODIFIED="1529018119792">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
als <i>Subklasse</i> von UICoord
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1529018125015" ID="ID_740978949" MODIFIED="1529018137465" TEXT="fügt den Variant-Record und den Konverter hinzu"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1529016854248" FOLDED="true" HGAP="37" ID="ID_1664191705" MODIFIED="1561827482928" TEXT="Abwägung" VSHIFT="5">
|
|
<node CREATED="1529016871262" ID="ID_957194065" MODIFIED="1529017825322" TEXT="Variante-2 verschiebt das Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das eigentliche Problem ist,
|
|
</p>
|
|
<p>
|
|
daß ich noch keinerlei Implementierung schreiben kann.
|
|
</p>
|
|
<p>
|
|
Mithin schiebe ich mir Platzhalter von der linken in die rechte Tasche
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1529017693432" ID="ID_70956393" MODIFIED="1529018209759" TEXT="Variante-3 verwendet zwei Repräsentationen für die gleiche Sache">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar für die abstrahierte GUI-Location
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
einmal symbolisch als UI-Koordinaten
|
|
</li>
|
|
<li>
|
|
einmal opaque als eingekapselte Lösung
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Und sowas ist verwirrend und verlockt gradezu, die Schachtel aufzumachen
|
|
</p>
|
|
<p>
|
|
und an der Implementierung zu kleben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1529018409007" ID="ID_1460094266" MODIFIED="1529018714798" TEXT="Variante-3b wäre nur interessant als eigenständige Entität">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was <i>bis jetzt</i> nicht gegeben ist!
|
|
</p>
|
|
<p>
|
|
Bis jetzt haben wir einen "Durchlauf-Erhitzer": letztlich will man nur die Referenz
|
|
</p>
|
|
<p>
|
|
auf das GUI-Element haben, und die dazwischenliegende symbolische Schicht
|
|
</p>
|
|
<p>
|
|
dient nur der Konfiguration und Lösungs-Suche.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wenn allerdings später mal diese <b>UILocation</b> == bereits decodierte UI-Koordinaten
|
|
</p>
|
|
<p>
|
|
ein eigenständiges Token wird, welches über mehrere Schnittstellen hinweg geschoben wird,
|
|
</p>
|
|
<p>
|
|
<i>dann und nur dann</i> würde die zusätzliche API-Komplexität Sinn machen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1529019621707" FOLDED="true" ID="ID_537306231" MODIFIED="1561827469156" TEXT="Beschluß">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1529019899294" ID="ID_514740736" MODIFIED="1529065532532" TEXT="Variante-3b wird als Option für später festgehalten"/>
|
|
<node CREATED="1529019931210" ID="ID_963819454" MODIFIED="1529065532532" TEXT="Variante-1 mit API-Erweiterung ist naheliegend"/>
|
|
<node CREATED="1529019962989" ID="ID_1964052993" MODIFIED="1529065532532">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die <b>verfickte</b> Performance wird ignoriert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1529073415777" FOLDED="true" HGAP="19" ID="ID_834523571" MODIFIED="1561827482928" TEXT="Lösung" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1529073429723" FOLDED="true" ID="ID_100395564" MODIFIED="1561827469156" TEXT="Funktion locate_or_create()">
|
|
<node CREATED="1529073456407" ID="ID_838325275" MODIFIED="1529073466881" TEXT="macht Zugriff und erzeugt ggfs neu"/>
|
|
<node CREATED="1529073467710" ID="ID_149127263" MODIFIED="1529073477217" TEXT="gibt UICoord::Builder nach unten"/>
|
|
<node CREATED="1529073477988" ID="ID_1842592627" MODIFIED="1529073484271" TEXT="dieser wird dort ggfs umgeschrieben"/>
|
|
<node CREATED="1529073485027" ID="ID_1766613398" MODIFIED="1529073496141" TEXT="gibt nur UICoord zurück"/>
|
|
</node>
|
|
<node CREATED="1529073497945" FOLDED="true" ID="ID_1104671546" MODIFIED="1561827469157" TEXT="Funktion access()">
|
|
<node CREATED="1529073503466" ID="ID_1047392798" MODIFIED="1529073510052" TEXT="darf niemals neu erzeugen"/>
|
|
<node CREATED="1529073510904" ID="ID_403151375" MODIFIED="1529073549243" TEXT="navigiert den vorbereiten Pfad nochmal hinunter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....jaaaaa, das ist verschwenderisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1529073559905" ID="ID_1370869277" MODIFIED="1529073571068" TEXT="liefert nun aber den verpackten Ergebnis-Zeiger"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523752571241" ID="ID_1806352950" MODIFIED="1523752593134" TEXT="Anzahl Instanzen herausfinden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529079675765" ID="ID_1441903624" MODIFIED="1529079695630" TEXT="Limit erzwingen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515634076196" HGAP="-17" ID="ID_1380959703" MODIFIED="1518487921071" TEXT="Implementierung" VSHIFT="20">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1515634129061" ID="ID_1554987217" MODIFIED="1518487921071" TEXT="locate">
|
|
<node CREATED="1515634129062" ID="ID_1263439663" MODIFIED="1518487921071" TEXT="firstWindow"/>
|
|
<node CREATED="1515634129062" ID="ID_935490983" MODIFIED="1518487921071" TEXT="currentWindow"/>
|
|
<node CREATED="1515634129062" ID="ID_115783898" MODIFIED="1518487921071" TEXT="perspective(id)"/>
|
|
<node CREATED="1515634129062" ID="ID_353316788" MODIFIED="1518487921071" TEXT="panel(id)"/>
|
|
<node CREATED="1515634129062" ID="ID_1180499191" MODIFIED="1518487921071" TEXT="existingPanel(id)"/>
|
|
<node CREATED="1515634129062" ID="ID_67330452" MODIFIED="1518487921071" TEXT="existingGroup WIP 9/17 not clear if possible"/>
|
|
</node>
|
|
<node CREATED="1515634129062" ID="ID_1198810867" MODIFIED="1518487921071" TEXT="alloc">
|
|
<node CREATED="1515634129063" ID="ID_299053476" MODIFIED="1518487921071" TEXT="unlimited"/>
|
|
<node CREATED="1515634129063" ID="ID_125752214" MODIFIED="1518487921071" TEXT="onlyOne"/>
|
|
<node CREATED="1515634129063" ID="ID_1164137116" MODIFIED="1518487921071" TEXT="limitPerWindow(cnt)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522940095319" HGAP="-87" ID="ID_257633825" MODIFIED="1522940111813" TEXT="Aufruf einbinden" VSHIFT="-1">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1522940113349" ID="ID_378188810" MODIFIED="1522940183464" TEXT="in ViewLocator">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522940118628" ID="ID_356408235" MODIFIED="1523752865657" TEXT="auf Typ getemplated">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1523750592900" ID="ID_266745032" MODIFIED="1529079925485" TEXT=""viewID" ist erst mal eine Typ-ID">
|
|
<arrowlink COLOR="#5260a0" DESTINATION="ID_778018274" ENDARROW="Default" ENDINCLINATION="-1217;51;" ID="Arrow_ID_597388409" STARTARROW="None" STARTINCLINATION="686;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1523750621640" ID="ID_776549392" MODIFIED="1529076554000" TEXT="wird aber ggfs noch dekoriert (wg. Multiplizität)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522940124932" FOLDED="true" ID="ID_636475854" MODIFIED="1525564213845" TEXT="Aufruf-Mechanismus">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522940151016" ID="ID_254319466" MODIFIED="1525564207503" TEXT="Strategy/Spezialisierungen in id-scheme.hpp">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1522940161655" ID="ID_1905184084" MODIFIED="1522940166466" TEXT="pro Typ spezialisiert">
|
|
<node COLOR="#338800" CREATED="1523752892269" ID="ID_1603142051" MODIFIED="1533608413761" TEXT="Problem: Instanzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1523752902739" ID="ID_1018267741" MODIFIED="1523752943957" TEXT="statische Felder gehen nicht ohne Weiteres">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1523752911010" ID="ID_1174940020" MODIFIED="1523752930531" TEXT="...also brauchen wir Instanzen der Deskriptoren"/>
|
|
<node CREATED="1523752932735" ID="ID_225005955" MODIFIED="1525564117580" TEXT="Familie von Meyer's Singletons"/>
|
|
<node CREATED="1525564118640" ID="ID_327931353" MODIFIED="1525564137811" TEXT="lebt in view-spec-dsl.hpp (inline)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522940167125" ID="ID_980922327" MODIFIED="1522940174904" TEXT="hält die konkrete ViewSpec-DSL"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1525564232321" FOLDED="true" ID="ID_46755801" MODIFIED="1529079723225" TEXT="konkrete Allokator-Strategien verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1525564255702" ID="ID_645519559" MODIFIED="1525564259768" TEXT="hinten rum">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1525564261653" ID="ID_1979012219" MODIFIED="1525564307309" TEXT="Interface ElementAccess">
|
|
<arrowlink COLOR="#97cad5" DESTINATION="ID_597346628" ENDARROW="Default" ENDINCLINATION="126;9;" ID="Arrow_ID_89575203" STARTARROW="None" STARTINCLINATION="567;-16;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1525565917296" ID="ID_174717640" MODIFIED="1525565932959" TEXT="Problem: resultierende UI-Coord">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1525565935350" ID="ID_252570354" MODIFIED="1525565950136" TEXT="Instanz-Limit"/>
|
|
<node CREATED="1525565950988" ID="ID_1233385790" MODIFIED="1525567162939">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann dazu führen,
|
|
</p>
|
|
<p>
|
|
daß etwas Bestehendes zurückgeliefert wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1529079727758" ID="ID_288941017" MODIFIED="1529079742349" TEXT="Lösung gefunden: ElementAccess gibt UICoord zurück">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522940203377" ID="ID_1539937928" MODIFIED="1522940298042" TEXT="Testabdeckung">
|
|
<arrowlink COLOR="#4c8891" DESTINATION="ID_1745396406" ENDARROW="Default" ENDINCLINATION="-828;-41;" ID="Arrow_ID_1830310728" STARTARROW="None" STARTINCLINATION="250;35;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506181908037" FOLDED="true" HGAP="-29" ID="ID_1925951134" MODIFIED="1518487921071" TEXT="Test" VSHIFT="21">
|
|
<icon BUILTIN="prepare"/>
|
|
<node CREATED="1506181922767" ID="ID_1642380411" MODIFIED="1518487921071" TEXT="UICoord_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506182009518" ID="ID_138248232" MODIFIED="1518487921071" TEXT="verify_basics">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506182009519" ID="ID_1637725534" MODIFIED="1518487921071" TEXT="verify_builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506182009519" ID="ID_542761230" MODIFIED="1518487921071" TEXT="verify_comparisons">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984579372" ID="ID_1752757359" MODIFIED="1518487921071" TEXT="verify_localPredicates">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506984614487" ID="ID_380908645" MODIFIED="1561827465158" TEXT="UICoordResolver_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1506984645745" ID="ID_244163155" MODIFIED="1518487921071" TEXT="verify_simpleUsage">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984645747" FOLDED="true" ID="ID_517262443" MODIFIED="1531584013579" TEXT="verify_backingQuery">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508809610790" ID="ID_1860790851" MODIFIED="1512926191814" TEXT="Builder-Syntax war falsch">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508809620762" ID="ID_236111511" MODIFIED="1508809630860" TEXT="muß die Attribute-Collection nutzen"/>
|
|
<node CREATED="1508809631448" ID="ID_956153388" MODIFIED="1508809644482" TEXT="Builder wohl noch nie für diesen Fall verwendet"/>
|
|
<node CREATED="1508809645470" ID="ID_1846245702" MODIFIED="1508809656617" TEXT="erlaube Move-Initialisierung"/>
|
|
</node>
|
|
<node CREATED="1508809657253" ID="ID_108704029" MODIFIED="1512926191815" TEXT="Segfault">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1508809662036" ID="ID_1522595538" MODIFIED="1508809674479" TEXT="sehe zwar die drei Window-Elemente"/>
|
|
<node CREATED="1508809674994" ID="ID_1781272984" MODIFIED="1533608413762" TEXT="aber die ID-Strings sind komisch">
|
|
<node CREATED="1508809684338" ID="ID_1268163778" MODIFIED="1508809688341" TEXT="erster String ist """/>
|
|
<node CREATED="1508809688881" ID="ID_1836564528" MODIFIED="1508809700115" TEXT="zweiter String hat richtigen Anfang..."/>
|
|
<node CREATED="1508809700919" ID="ID_733585050" MODIFIED="1508809716393" TEXT="aber wird mit nachfolgendem Müll angezeigt"/>
|
|
<node CREATED="1508809719165" ID="ID_1506398379" MODIFIED="1509064569893" TEXT="Segfault beim Initialisieren des Ergebnisses für extractKey"/>
|
|
</node>
|
|
<node CREATED="1508809741418" ID="ID_1013369537" MODIFIED="1509070755705" TEXT="Verdacht: irgendwo move mit dangling storage?"/>
|
|
<node CREATED="1509070756935" ID="ID_1331980374" MODIFIED="1576282358114" TEXT="nein! Nur eine Referenz vom Temporary">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...merke
|
|
</p>
|
|
<p>
|
|
die Spezialbehandlung für const& gilt nur, wenn wir direkt auch diesen Typ nehmen.
|
|
</p>
|
|
<p>
|
|
Im vorliegenden fall wird aber der conversion-Operator aufgerufen, um den Initializser zu erzeugen.
|
|
</p>
|
|
<p>
|
|
Daher denkt der Compiler, er kann das Ursprungsobjekt jezt wergwerfen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509142651113" ID="ID_99734013" MODIFIED="1512926191818">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Spezialbehandlung
|
|
</p>
|
|
<p>
|
|
Perspektive
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1509143055036" ID="ID_810015478" MODIFIED="1576282358114" TEXT="absichtlich unorthogonal repräsentiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um zu prüfen, ob das allgemeine Design
|
|
</p>
|
|
<p>
|
|
mit solchen Asymetrien umgehen kann,
|
|
</p>
|
|
<p>
|
|
welche ziemlich sicher noch viel mehr
|
|
</p>
|
|
<p>
|
|
bei der Navigation in einem realen GUI auftreten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509143404342" ID="ID_708195081" MODIFIED="1533608413762" TEXT="drillDown aufbohren">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1509143431491" ID="ID_1535839304" MODIFIED="1509143436685" TEXT="Pfad normal weiterverarbeiten"/>
|
|
<node CREATED="1509143437202" ID="ID_1489524396" MODIFIED="1509143442917" TEXT="aber Abstieg im Baum manipulieren"/>
|
|
<node CREATED="1509143453151" ID="ID_373632759" MODIFIED="1561827465158" TEXT="speziell...">
|
|
<node CREATED="1509143459519" FOLDED="true" ID="ID_1727095948" MODIFIED="1561827483832" TEXT="existenz-Check läuft anders">
|
|
<node CREATED="1509143492194" ID="ID_835507213" MODIFIED="1509143513852" TEXT="getType und stringvergleich"/>
|
|
<node CREATED="1509143514352" ID="ID_730111393" MODIFIED="1509143519963" TEXT="statt hasAttribute"/>
|
|
</node>
|
|
<node CREATED="1509143469429" ID="ID_1414723485" MODIFIED="1509143481984" TEXT="keinen Abstiegs-Schritt machen"/>
|
|
</node>
|
|
<node CREATED="1509143542611" ID="ID_114168871" MODIFIED="1576282358113" TEXT="Schwein gehabt, rekursiv programmiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und ich hab mir letzte Woche noch solche Vorwürfe gemacht,
|
|
</p>
|
|
<p>
|
|
daß ich mich wieder mal "akademisch" verspielt habe.... :-P
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1509151268071" ID="ID_38582779" MODIFIED="1533608413764" TEXT="getChildren aufbohren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1509151285749" ID="ID_1826645914" MODIFIED="1509287428715" TEXT="eigentlich einfach">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1509287527705" ID="ID_1588631568" MODIFIED="1509287562960" TEXT="muß bloß in einem Fall explizit was anderes liefern..."/>
|
|
<node CREATED="1509287541919" ID="ID_58868223" MODIFIED="1509287552668" TEXT="Aua! Iterator ist im weg">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1509151289637" ID="ID_892381116" MODIFIED="1561827465159" TEXT="brauche singletonIter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1509151296292" ID="ID_1050274308" MODIFIED="1509151411655" TEXT="liefert ein einziges Element"/>
|
|
<node CREATED="1509151305602" ID="ID_452317335" MODIFIED="1509287419861" TEXT="als IterSource verpackt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1509151309866" ID="ID_1109789284" MODIFIED="1576282358112" TEXT="sollte es als als Basis iter implementieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und die IterSource dann nur über WrapIter definieren.
|
|
</p>
|
|
<p>
|
|
Schichten-Prinzip...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1509151381113" ID="ID_779657015" MODIFIED="1509151411655" TEXT="brauche ItemWrapper für beliebiges Element"/>
|
|
<node CREATED="1509151390495" ID="ID_947844248" MODIFIED="1509285129251" TEXT="Idee: TransformIter aufbohren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1509285130478" ID="ID_1391664155" MODIFIED="1509285142156" TEXT="direkt coden ist am klarsten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984645748" FOLDED="true" ID="ID_1254044275" MODIFIED="1531584013581" TEXT="verify_queryAnchor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1513477632318" ID="ID_1636138355" MODIFIED="1515209155590" TEXT="setzt PathResolution voraus">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1513477685935" ID="ID_115330701" MODIFIED="1515209146174" TEXT="brauche layered pull-Evaluation">
|
|
<arrowlink COLOR="#786296" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="278;120;" ID="Arrow_ID_1919142695" STARTARROW="None" STARTINCLINATION="952;148;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477772387" ID="ID_1207553398" MODIFIED="1515209119633" TEXT="neu implementierter ChildIter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477790161" ID="ID_286375730" MODIFIED="1515209148753" TEXT="PathResolution implementieren">
|
|
<arrowlink COLOR="#653655" DESTINATION="ID_394904963" ENDARROW="Default" ENDINCLINATION="606;374;" ID="Arrow_ID_1674594671" STARTARROW="None" STARTINCLINATION="863;77;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1513477954730" ID="ID_1541867154" MODIFIED="1513478089188" TEXT="Fälle...">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1513477957584" ID="ID_862780828" MODIFIED="1515209246199" TEXT="Explizit: window("window-1").persp("perspective-A")">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477957585" ID="ID_992417953" MODIFIED="1515209244400" TEXT="Gibtsned: window("windows");">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477957586" ID="ID_1927496001" MODIFIED="1515209242711" TEXT="contextual state: firstWindow();">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477957586" ID="ID_519256473" MODIFIED="1515209240701" TEXT="context-relativ: currentWindow().persp("perspective-B");">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477957586" ID="ID_1636269470" MODIFIED="1533608413765" TEXT="context-relativ-unlösbar: currentWindow().panel("panelY");">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515209222726" ID="ID_959307669" MODIFIED="1515209232972" TEXT="aber ankerbar!">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1513477957586" ID="ID_1247686548" MODIFIED="1515209175737" TEXT="partiell-interpolierbar: view("someView");">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506984645748" FOLDED="true" ID="ID_670536416" MODIFIED="1518487921071" TEXT="verify_queryCoverage">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1515209280278" ID="ID_959372189" MODIFIED="1518487921071" TEXT="sinnlos, da man das Ergebnis nicht sieht"/>
|
|
<node CREATED="1515209292804" ID="ID_907780055" MODIFIED="1523750073991" TEXT="ansonsten redundant zur Mutation"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984645748" FOLDED="true" ID="ID_1171284706" MODIFIED="1531584013583" TEXT="verify_mutateAnchor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515287623841" ID="ID_11774693" MODIFIED="1518487921071" TEXT="explizit verankert: ändert sich nix">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287648717" ID="ID_293459284" MODIFIED="1518487921071" TEXT="firstWindow explizit machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515291045220" ID="ID_907726638" MODIFIED="1518487921071" TEXT="...selbst wenn sonst nicht lösbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287660188" ID="ID_811260333" MODIFIED="1518487921071" TEXT="currentWindow explizit machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515291071497" ID="ID_913736296" MODIFIED="1518487921071" TEXT="...und trägt auch zur Lösung bei">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287665939" ID="ID_525267705" MODIFIED="1518487921071" TEXT="lösbare coverage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515287701126" ID="ID_1257691503" MODIFIED="1533608413765" TEXT="noch nicht berechnet: errechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515291242698" ID="ID_512594119" MODIFIED="1518487921071" TEXT="muß re-normalisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1515291264591" ID="ID_250465802" MODIFIED="1561827465160" TEXT="sollte dann coverDepth neu errechnen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1515305853681" ID="ID_1757724837" MODIFIED="1515305908431" TEXT="nicht notwendig">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1515305858184" FOLDED="true" ID="ID_1728979618" MODIFIED="1561827483832">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist <i>immer</i> schon korrekt erledigt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1515305886989" ID="ID_877994644" MODIFIED="1515305894383" TEXT="entweder der Beginn ist explizit"/>
|
|
<node CREATED="1515305895307" ID="ID_371777501" MODIFIED="1515305899622" TEXT="oder wir haben eine Lösung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287694871" ID="ID_953283273" MODIFIED="1533608413767" TEXT="schon berechnet: eintragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515291343277" ID="ID_1704851738" MODIFIED="1518487921071" TEXT="explizites Cover machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515291350332" ID="ID_219986282" MODIFIED="1561827465161" TEXT="neue coverDepth muß sichtbar werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515298565483" ID="ID_719457405" MODIFIED="1515298571802" TEXT="Autsch">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515298572994" FOLDED="true" ID="ID_1082678541" MODIFIED="1561827483832" TEXT="Denkfehler im Builder-Konzept!">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1515298602326" ID="ID_13919667" MODIFIED="1515298692557" TEXT="Rückgabe ist Value...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das heißt.
|
|
</p>
|
|
<p>
|
|
ein Value wird auch sofort konstruiert,
|
|
</p>
|
|
<p>
|
|
egal, ob man den dann gleich wegwirft.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1515298698849" ID="ID_1957524269" MODIFIED="1515298709411" TEXT="Objekt wird nach erstem Aufruf tatsächlich zerstört"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515298710952" ID="ID_167586553" MODIFIED="1515298806412" TEXT="Lösung: && zurückgeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1515298722702" FOLDED="true" ID="ID_273407473" MODIFIED="1561827483832" TEXT="könnte gefährlich sein">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1515298735548" ID="ID_966210103" MODIFIED="1515298746799" TEXT="Stichwort: Sequence Points"/>
|
|
<node CREATED="1515298747531" ID="ID_1013710090" MODIFIED="1515298752254" TEXT="im Debugger beobachtet"/>
|
|
<node CREATED="1515298753074" ID="ID_5305718" MODIFIED="1515298776867" TEXT="Builder-Syntax scheint zu funktionieren, wie erwartet"/>
|
|
<node CREATED="1515298777551" ID="ID_1384914895" MODIFIED="1515298789593" TEXT="explizite Aufruf-Syntax ebenso"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515287717092" ID="ID_459525933" MODIFIED="1518487921071" TEXT="nicht coverbar: ändert sich nix">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984645748" ID="ID_1688800613" MODIFIED="1518487921071" TEXT="verify_mutateCoverage">
|
|
<arrowlink COLOR="#4b5c8d" DESTINATION="ID_1362494392" ENDARROW="Default" ENDINCLINATION="398;572;" ID="Arrow_ID_82261909" STARTARROW="None" STARTINCLINATION="1404;115;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506984645748" FOLDED="true" ID="ID_768385613" MODIFIED="1531584013584" TEXT="verify_mutateExtend">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515449655380" ID="ID_1282321814" MODIFIED="1518487921071" TEXT="expliziten Pfad erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515450991631" ID="ID_1736775031" MODIFIED="1518487921071" TEXT="Pfad durch partielle UI-Coord erweitern">
|
|
<arrowlink COLOR="#4f6f95" DESTINATION="ID_130067342" ENDARROW="Default" ENDINCLINATION="544;89;" ID="Arrow_ID_992203487" STARTARROW="None" STARTINCLINATION="704;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515451047192" ID="ID_554336668" MODIFIED="1525124215016" TEXT="erweitern scheitert wegen Überlapp">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515455278659" ID="ID_1749331083" MODIFIED="1515555648076" TEXT="präziser Anschluß funktioniert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515455289417" ID="ID_228177396" MODIFIED="1515555650682" TEXT="Überlapp == 1 scheitert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515455296784" ID="ID_957569216" MODIFIED="1533608413769" TEXT="sinnvolle Fehlermeldung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1515456807297" ID="ID_940232878" MODIFIED="1515555654366" TEXT="ausgehend von expliziter Spec">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515456817248" ID="ID_631326169" MODIFIED="1515555656365" TEXT="ausgehend von berechneter Coverage-Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515449669446" ID="ID_1747646759" MODIFIED="1518487921071" TEXT="partially covered erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515449719015" ID="ID_979130061" MODIFIED="1518487921071" TEXT="unlösbar -> truncate">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515449727142" ID="ID_1936618724" MODIFIED="1518487921071" TEXT="coverage kann dadurch anwachsen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506145618" ID="ID_718086573" MODIFIED="1561827465169" TEXT="UILocationSolver_test">
|
|
<linktarget COLOR="#465888" DESTINATION="ID_718086573" ENDARROW="Default" ENDINCLINATION="-185;-461;" ID="Arrow_ID_1844529849" SOURCE="ID_957265584" STARTARROW="None" STARTINCLINATION="-598;29;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1517506161024" ID="ID_21333166" MODIFIED="1518487921071" TEXT="Verdrahtung mit Test/Dummy-UI">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506256691" ID="ID_360871736" MODIFIED="1518487921071" TEXT="einfaches Anwendungs-Beispiel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506268969" FOLDED="true" ID="ID_1285475519" MODIFIED="1531584013587" TEXT="theoretische Grenzfälle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518220727527" ID="ID_935687591" MODIFIED="1518762392404" TEXT="leere Regel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518220764202" ID="ID_1551836374" MODIFIED="1518762392404" TEXT="geht nicht">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518220767426" ID="ID_1678897927" MODIFIED="1518762392404" TEXT="aber eine leere Klausel geht">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221630349" ID="ID_748354557" MODIFIED="1518762392404" TEXT="leere Klausel plus andere">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518220806629" ID="ID_1877537399" MODIFIED="1518762392404" TEXT="zu kurze Regel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518220812132" ID="ID_1855700910" MODIFIED="1518762392404" TEXT="zu lange Regel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1518221033294" ID="ID_379081230" MODIFIED="1531584013588" TEXT="Anfrage auf Window">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221041493" ID="ID_1938682325" MODIFIED="1518762392404" TEXT="existierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221057362" ID="ID_1276841328" MODIFIED="1518762392404" TEXT="generisch">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221047172" ID="ID_899404932" MODIFIED="1518762392404" TEXT="nicht existierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221069089" ID="ID_834357218" MODIFIED="1518762392404" TEXT="nicht existierend / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221069089" ID="ID_1759153588" MODIFIED="1518762392404" TEXT=" existierend / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518221096237" ID="ID_1538354349" MODIFIED="1531584013588" TEXT="Anfrage auf Perspektive">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221103372" ID="ID_4661652" MODIFIED="1518762392404" TEXT="existierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221109227" ID="ID_357379201" MODIFIED="1518762392404" TEXT="elided">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221115123" ID="ID_444249560" MODIFIED="1518762392404" TEXT="nicht exisitierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221121450" ID="ID_1105449946" MODIFIED="1518762392404" TEXT="nichte existierend / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518221188121" ID="ID_541455871" MODIFIED="1518762392404" TEXT="Anfrage auf (tiefen) Pfad">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518221206998" ID="ID_1900776687" MODIFIED="1533608413770" TEXT="komplett explizit">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221213277" ID="ID_1744618018" MODIFIED="1518762392404" TEXT="covered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221239058" ID="ID_1778260898" MODIFIED="1518762392404" TEXT="covered / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221217997" ID="ID_1478390273" MODIFIED="1518762392404" TEXT="partially covered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221217997" ID="ID_789039729" MODIFIED="1518762392404" TEXT="partially covered / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221264143" ID="ID_676167818" MODIFIED="1518762392404" TEXT="uncovered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221267862" ID="ID_637617629" MODIFIED="1518762392404" TEXT="uncovered / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518221321054" ID="ID_1884750439" MODIFIED="1533608413771" TEXT="Wildcard">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221328398" ID="ID_771962346" MODIFIED="1518762392404" TEXT="covered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221342140" ID="ID_1533800638" MODIFIED="1518762392404" TEXT="covered ohne Endelement">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221353130" ID="ID_786771733" MODIFIED="1518762392404" TEXT="create aber komplett existierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221365785" ID="ID_812801272" MODIFIED="1518762392404" TEXT="create ohne Endelement">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221374663" ID="ID_1846464761" MODIFIED="1518762392404" TEXT="partially covered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221380231" ID="ID_378548083" MODIFIED="1518762392404" TEXT="partially covered / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221386438" ID="ID_864741660" MODIFIED="1518762392404" TEXT="uncovered">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221398668" ID="ID_1119602753" MODIFIED="1518762392404" TEXT="uncovered / create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518221447093" ID="ID_1048302687" MODIFIED="1518762392404" TEXT="zwei Klauseln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221466779" ID="ID_1934359283" MODIFIED="1518762392404" TEXT="beide erfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221482345" ID="ID_867150257" MODIFIED="1518762392404" TEXT="erste unerfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1518221509805" ID="ID_1191463024" MODIFIED="1533608413771" TEXT="erste create">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221525891" ID="ID_395077893" MODIFIED="1518762392404" TEXT="erfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221539089" ID="ID_1046962094" MODIFIED="1518762392404" TEXT="nicht erfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518221571021" ID="ID_1917057944" MODIFIED="1533608413772" TEXT="zweite create">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518221582347" ID="ID_1796461457" MODIFIED="1518762392404" TEXT="erste erfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221587275" ID="ID_1141416112" MODIFIED="1518762392404" TEXT="zweite erfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518221593034" ID="ID_1276221189" MODIFIED="1518762392404" TEXT="auch zweite unerfüllbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1517506289222" FOLDED="true" ID="ID_1250541940" MODIFIED="1531584013594" TEXT="praktische Standard-Fälle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518575724831" ID="ID_712009155" MODIFIED="1518579539092" TEXT="Idee">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1518575730894" ID="ID_24825251" MODIFIED="1518575750656">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur <i>einen Satz</i> Klauseln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1518575751651" ID="ID_1423547228" MODIFIED="1518575765468" TEXT="stattdessen den Test-"Baum" variieren"/>
|
|
<node CREATED="1518575766889" ID="ID_1639479655" MODIFIED="1518575777979" TEXT="damit die Situationen der realen Regeln nachbilden"/>
|
|
<node CREATED="1518575779991" ID="ID_1194432520" MODIFIED="1518575791081" TEXT="und beweisen, daß die Ergebnisse eindeutig sind"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518579541832" ID="ID_512680632" MODIFIED="1518579550376" TEXT="flexibles Test-Setup hierfür">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1518221768370" ID="ID_958994214" MODIFIED="1518487921072" TEXT="match by">
|
|
<node COLOR="#338800" CREATED="1518223023735" ID="ID_1788599676" MODIFIED="1518739354202" TEXT="pespective + panel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223029399" ID="ID_1184092341" MODIFIED="1518739356121" TEXT="generic window + existing panel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223039229" ID="ID_427870686" MODIFIED="1518739358673" TEXT="panel alone">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1518223101637" ID="ID_481219776" MODIFIED="1518742835910" TEXT="wildcard view + specific tab">
|
|
<arrowlink COLOR="#b78791" DESTINATION="ID_1208480183" ENDARROW="Default" ENDINCLINATION="-1240;134;" ID="Arrow_ID_831550289" STARTARROW="None" STARTINCLINATION="1654;0;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223107508" ID="ID_254700276" MODIFIED="1518742616988" TEXT="wildcard panel + view appended">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1518223136888" ID="ID_373048163" MODIFIED="1518487921072" TEXT="create match">
|
|
<node COLOR="#338800" CREATED="1518223141623" ID="ID_1610919464" MODIFIED="1518742653179" TEXT="on wildcard">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223149750" ID="ID_1733413613" MODIFIED="1533608413772" TEXT="on wildcard fail">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1518742624742" ID="ID_1245433967" MODIFIED="1518742630585" TEXT="implizit mitgetestet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1518742642180" ID="ID_194206742" MODIFIED="1518742648655" TEXT="....indem die nächste Regel zieht"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223044301" ID="ID_1476637837" MODIFIED="1533608413772" TEXT="generic window + panel create">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1518762440997" ID="ID_606433871" MODIFIED="1518840066703" TEXT="ggfs auto-elided?">
|
|
<arrowlink COLOR="#8eacb9" DESTINATION="ID_214794727" ENDARROW="Default" ENDINCLINATION="-653;0;" ID="Arrow_ID_1678351989" STARTARROW="None" STARTINCLINATION="1400;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1518223201375" ID="ID_1794858276" MODIFIED="1518742656811" TEXT="complete create">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506182023288" FOLDED="true" ID="ID_1539184761" MODIFIED="1523118243889" STYLE="fork" TEXT="ViewSpecDSL_test">
|
|
<arrowlink COLOR="#43667c" DESTINATION="ID_1234019560" ENDARROW="Default" ENDINCLINATION="-338;-1489;" ID="Arrow_ID_839730277" STARTARROW="None" STARTINCLINATION="-530;453;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506182077694" ID="ID_839824654" MODIFIED="1523053425474" TEXT="verify_basicProperties">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1515633695710" ID="ID_1540478220" MODIFIED="1523053425474" TEXT="aus standardUsage ablzuleiten"/>
|
|
<node CREATED="1515633710396" ID="ID_335824710" MODIFIED="1523053425474" TEXT="spezifiziert die formalen Basis-Eigenschaften"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1506182037003" ID="ID_439307131" MODIFIED="1523053425474" TEXT="verify_standardUsage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515633645885" ID="ID_1659749577" MODIFIED="1523053425474" TEXT="einfaches Dummy-Setup"/>
|
|
<node CREATED="1515633651212" ID="ID_704575529" MODIFIED="1523053425474" TEXT="erlaubt, die Strukturen zu bauen"/>
|
|
<node CREATED="1515633658483" ID="ID_149158343" MODIFIED="1523053425474" TEXT="läuft ohne die UI-Backbone">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1506182087462" ID="ID_47070993" MODIFIED="1523053425474" TEXT="verify_alternatives">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1515633722883" ID="ID_9454050" MODIFIED="1523053425474" TEXT="rein technische Erweiterung"/>
|
|
<node CREATED="1515633737905" ID="ID_1500220475" MODIFIED="1523053425474" TEXT="Auswahl der ersten "passenden" Lösung"/>
|
|
<node CREATED="1515633770884" ID="ID_861669562" MODIFIED="1523053425474" TEXT="Dummy: GenNodeLocationQuery anstelle eines realen UI"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522940227022" ID="ID_1745396406" MODIFIED="1523746775368" TEXT="verify_genericInvocation">
|
|
<linktarget COLOR="#4c8891" DESTINATION="ID_1745396406" ENDARROW="Default" ENDINCLINATION="-828;-41;" ID="Arrow_ID_1830310728" SOURCE="ID_1539937928" STARTARROW="None" STARTINCLINATION="250;35;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#435e98" CREATED="1523746830877" ID="ID_179614354" MODIFIED="1523746850828" TEXT="Ziel ist ein Komponenten-Integrationstest">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1523727045276" ID="ID_1873415671" MODIFIED="1523727056587" TEXT="Problem: wie testen ohne UI-Context?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1523727057907" ID="ID_465631036" MODIFIED="1576282358112" TEXT="Ausweg">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn irgendwann wird's lächerlich mit der Unit-Testerei.
|
|
</p>
|
|
<p>
|
|
Oder zumindest Hexagonal.
|
|
</p>
|
|
<p>
|
|
Bedingt durch die ganzen rausgezogenen Interfaces hat jetzt bereits ViewLocator überhaupt keinen Gehalt mehr.
|
|
</p>
|
|
<p>
|
|
Wenn ich jetzt auch noch die einzige verbleibende Methode rausziehe, um sie testen zu können,
|
|
</p>
|
|
<p>
|
|
drehe ich mich komplett im Kreis. Schließlich kann ich diese Methode ja, genau genommen,
|
|
</p>
|
|
<p>
|
|
im Moment auch noch nicht wirklich testen, aus genau den gleichen Gründen,
|
|
</p>
|
|
<p>
|
|
warum ViewLocator so nebulös bleibt: <b>es gibt noch kein Lumiera GUI</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523746796508" ID="ID_1839059733" MODIFIED="1523746796508" TEXT="Aufruf nur nachbauen"/>
|
|
<node CREATED="1523746798210" ID="ID_1076120435" MODIFIED="1523746818187" TEXT="Fake-DSL-Definitionen verwenden"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1523749882439" ID="ID_1150944546" MODIFIED="1529079882713" TEXT="Schritt-1">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1523749910106" ID="ID_542105863" MODIFIED="1523750022741" TEXT="einfache direkte Erzeugung von einem View">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523749925224" ID="ID_1469440140" MODIFIED="1529079888021" TEXT="minimale Verifikation">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523749888005" ID="ID_1904054486" MODIFIED="1523749907772" TEXT="Schritt-2">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1523749931480" ID="ID_1388717184" MODIFIED="1523750026436" TEXT="komplexere Fake-DSL">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523749938023" ID="ID_873547886" MODIFIED="1529079897790" TEXT="Alternativen und wirkliche Lösung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523749952356" ID="ID_1622746609" MODIFIED="1523749963165" TEXT="Schritt-3">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1523749968914" ID="ID_998334237" MODIFIED="1523750029454" TEXT="Test-Mock verwendet GenNode-Tree-Repräsentation">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523749987776" ID="ID_1752498971" MODIFIED="1523750010189" TEXT="Allokations-Mechanismus genauer spezifizieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523750001990" ID="ID_1324123993" MODIFIED="1523750009285" TEXT="Allokation konkret abdecken">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1523746600925" HGAP="1" ID="ID_435582808" MODIFIED="1523746656723" VSHIFT="36">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das ursprüngliche Ziel für diesen Test
|
|
</p>
|
|
<p>
|
|
ist in unserem Test-Framework <b>nicht realisierbar</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#eff1e5" DESTINATION="ID_435582808" ENDARROW="Default" ENDINCLINATION="-1920;189;" ID="Arrow_ID_1348453991" SOURCE="ID_1022913151" STARTARROW="None" STARTINCLINATION="498;45;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1523746659654" ID="ID_1299891788" MODIFIED="1523746698882" TEXT="Das Ziel war: alle konkreten Standard-Fälle durchspielen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1523746674939" ID="ID_1008453652" MODIFIED="1523746693800" TEXT="dies erfordert, die realen WIdgets zu instantiieren">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1523746704479" ID="ID_462392796" MODIFIED="1576282358111" TEXT="...und das ist ausgeschlossen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Policy</u>: Unit-Tests dürfen keine GTK-Abhängigkeit haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1523748895111" ID="ID_613307109" MODIFIED="1523748953311" TEXT="später mal....">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1523748900655" ID="ID_1768095597" MODIFIED="1667166529999" TEXT="#1140 UI integration tests">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1523748905725" ID="ID_748849132" MODIFIED="1667166529999" TEXT="#1141 verify UI default view allocation">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667166492738" ID="ID_1938503803" MODIFIED="1667166529999" TEXT="#1257 provide test-session for GUI">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504479724869" HGAP="-123" ID="ID_637855369" MODIFIED="1518487921072" TEXT="Darstellung" VSHIFT="10">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1504479769415" HGAP="45" ID="ID_115454468" MODIFIED="1518487921072" TEXT="Maßstab" VSHIFT="-13">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1504479773327" ID="ID_874044841" MODIFIED="1518487921072" TEXT="muß lesbar sein"/>
|
|
<node CREATED="1504479778086" ID="ID_1867364946" MODIFIED="1518487921072" TEXT="wichtige Fälle abbilden"/>
|
|
<node CREATED="1504479801683" ID="ID_1408830980" MODIFIED="1518487921072" TEXT="Implementierung">
|
|
<node CREATED="1504479807066" ID="ID_1318651039" MODIFIED="1518487921072" TEXT="mäßig komplex"/>
|
|
<node CREATED="1504479813553" ID="ID_141842675" MODIFIED="1576282358111" TEXT="ehr effizient">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
wird mäßig häufig aufgerufen
|
|
</li>
|
|
<li>
|
|
beim "Öffnen" und zur Navigation
|
|
</li>
|
|
<li>
|
|
im Interaktions-Kontext
|
|
</li>
|
|
<li>
|
|
keinen Speicherdruck erzeugen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8e79a4" DESTINATION="ID_1229791291" ENDARROW="Default" ENDINCLINATION="16;-93;" ID="Arrow_ID_277133142" STARTARROW="None" STARTINCLINATION="133;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504479933641" FOLDED="true" ID="ID_686917529" MODIFIED="1561827465183" TEXT="DSL">
|
|
<cloud COLOR="#dac6a1"/>
|
|
<linktarget COLOR="#5e819b" DESTINATION="ID_686917529" ENDARROW="Default" ENDINCLINATION="-89;-122;" ID="Arrow_ID_1067086551" SOURCE="ID_1397553997" STARTARROW="None" STARTINCLINATION="-322;62;"/>
|
|
<linktarget COLOR="#b45c5a" DESTINATION="ID_686917529" ENDARROW="Default" ENDINCLINATION="-468;-196;" ID="Arrow_ID_1955094318" SOURCE="ID_1442345755" STARTARROW="None" STARTINCLINATION="360;85;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504479939664" ID="ID_1158508729" MODIFIED="1518487921072" TEXT="Term-Schreibweise"/>
|
|
<node CREATED="1504479950607" ID="ID_118638432" MODIFIED="1518487921072" TEXT="generiert Funktoren/Closures"/>
|
|
<node CREATED="1504480019182" ID="ID_1190390221" MODIFIED="1518487921072" TEXT="Problem: encapsulation">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1504480041315" ID="ID_535241643" MODIFIED="1518487921072" TEXT="DSL-Ausdrücke stehen in globalem Header"/>
|
|
<node CREATED="1504480172697" ID="ID_858936833" MODIFIED="1518487921073" TEXT="tatsächlich nur im ViewLocator zu interpretieren"/>
|
|
</node>
|
|
<node CREATED="1504480237649" FOLDED="true" HGAP="15" ID="ID_1076181034" MODIFIED="1518487921073" TEXT="Variation der Diff-Verben?" VSHIFT="11">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504480255374" ID="ID_869593955" MODIFIED="1518487921073" TEXT="Token + Argument"/>
|
|
<node CREATED="1504480260373" ID="ID_236748610" MODIFIED="1518487921073" TEXT="Funktor gebunden"/>
|
|
<node CREATED="1504480266909" ID="ID_1626606623" MODIFIED="1518487921073" TEXT="...an Interpreter">
|
|
<node CREATED="1504480363968" ID="ID_1701584915" MODIFIED="1518487921073" TEXT="legt die gültien Verben fest"/>
|
|
<node CREATED="1504480371070" ID="ID_505779360" MODIFIED="1518487921073" TEXT="ist ein Interface"/>
|
|
<node CREATED="1504480375006" ID="ID_1380298925" MODIFIED="1518487921073" STYLE="fork" TEXT="=> double-dispatch">
|
|
<arrowlink COLOR="#6b768e" DESTINATION="ID_1191902349" ENDARROW="Default" ENDINCLINATION="28;-22;" ID="Arrow_ID_1105816510" STARTARROW="None" STARTINCLINATION="113;3;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1504962176894" FOLDED="true" ID="ID_1173896337" MODIFIED="1518487921073" TEXT="Sprachdesign...?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504962191564" ID="ID_967497234" MODIFIED="1518487921073" TEXT="Basis">
|
|
<node CREATED="1504962330154" ID="ID_242817654" MODIFIED="1518487921073" TEXT="Zuweisung eines Tokens"/>
|
|
<node CREATED="1504962335321" ID="ID_1453600135" MODIFIED="1518487921073" TEXT="Token liegt als Konstante definiert vor"/>
|
|
<node CREATED="1504962353566" ID="ID_665223755" MODIFIED="1518487921073" TEXT="insgeheim ist das Token ein Funktor"/>
|
|
</node>
|
|
<node CREATED="1504962218409" ID="ID_1024382518" MODIFIED="1518487921073" TEXT="Eigenschaften">
|
|
<node CREATED="1504962376172" ID="ID_1142953512" MODIFIED="1518487921073" TEXT="geringe Komplexität"/>
|
|
<node CREATED="1504962382427" ID="ID_931743673" MODIFIED="1518487921073" TEXT="Token können konstante Parameter nehmen"/>
|
|
<node CREATED="1504962405768" ID="ID_1340772990" MODIFIED="1518487921073" TEXT="einseitg Implementierungs-gebunden"/>
|
|
<node CREATED="1504962420549" ID="ID_553833506" MODIFIED="1518487921073" TEXT="benötigt explizite Typedefs"/>
|
|
</node>
|
|
<node CREATED="1504962222248" ID="ID_1699830751" MODIFIED="1518487921073" TEXT="Implementierung">
|
|
<node CREATED="1504962230111" ID="ID_1779805843" MODIFIED="1518487921073" TEXT="interne DSL"/>
|
|
<node CREATED="1504962233718" ID="ID_949042440" MODIFIED="1518487921073" TEXT="ist opaque"/>
|
|
<node CREATED="1504962251844" ID="ID_1229791291" MODIFIED="1518487921073" TEXT="Effizienz">
|
|
<linktarget COLOR="#8e79a4" DESTINATION="ID_1229791291" ENDARROW="Default" ENDINCLINATION="16;-93;" ID="Arrow_ID_277133142" SOURCE="ID_141842675" STARTARROW="None" STARTINCLINATION="133;0;"/>
|
|
<node CREATED="1504831930030" ID="ID_1191902349" MODIFIED="1533608413773" TEXT="double dispatch?">
|
|
<linktarget COLOR="#6b768e" DESTINATION="ID_1191902349" ENDARROW="Default" ENDINCLINATION="28;-22;" ID="Arrow_ID_1105816510" SOURCE="ID_1380298925" STARTARROW="None" STARTINCLINATION="113;3;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1504832179925" ID="ID_878950103" MODIFIED="1518487921073" TEXT="wäre akzeptabel"/>
|
|
<node CREATED="1504831934790" ID="ID_1800843653" MODIFIED="1576282358110" TEXT="aber etwas übertrieben...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es ist im Rahmen;
|
|
</p>
|
|
<p>
|
|
denn wir akzeptieren <i>double dispatch</i> sogar in der Diff-Anwendung,
|
|
</p>
|
|
<p>
|
|
welche viel häufiger läuft, als dieser View-Zugriff hier.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings, die <i>doppelte</i> Indirektion ist nicht grundsätzlich notwendig hier,
|
|
</p>
|
|
<p>
|
|
da wir nur einen einzigen Anwendungsfall haben. Die zweite Indirektion in jedem Aufruf
|
|
</p>
|
|
<p>
|
|
bewirkt nur eine Entkoppelung vom Implementierungs-Kontext
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504832266793" ID="ID_1279692021" MODIFIED="1533608413774" TEXT="einfache Funktoren?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504832394952" ID="ID_85672659" MODIFIED="1518487921073">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir brauchen keine <i>Token</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1504832413997" ID="ID_439230153" MODIFIED="1576282358110" TEXT="namentlich bekannte Definitionen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....anders als im Diff-Framework
|
|
</p>
|
|
<p>
|
|
senden wir hier keine beliebigen Nachrichten,
|
|
</p>
|
|
<p>
|
|
sondern interpretieren jeweils nur eine einzige feste Konfiguration
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504832476365" ID="ID_799285654" MODIFIED="1518487921073" TEXT="mit der Implementierungsfunktion initialisiert"/>
|
|
<node CREATED="1504832511688" ID="ID_673872785" MODIFIED="1518487921073" TEXT="Voraussetzung: sinnvolle Primitive">
|
|
<arrowlink COLOR="#b16174" DESTINATION="ID_879982156" ENDARROW="Default" ENDINCLINATION="154;-219;" ID="Arrow_ID_1853267431" STARTARROW="None" STARTINCLINATION="-401;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504832752113" ID="ID_1801527547" MODIFIED="1518487921073" TEXT="Struktur">
|
|
<node CREATED="1504832762680" HGAP="68" ID="ID_879982156" MODIFIED="1518487921073" TEXT="Primitive" VSHIFT="-16">
|
|
<cloud COLOR="#ebd5a6"/>
|
|
<linktarget COLOR="#b16174" DESTINATION="ID_879982156" ENDARROW="Default" ENDINCLINATION="154;-219;" ID="Arrow_ID_1853267431" SOURCE="ID_673872785" STARTARROW="None" STARTINCLINATION="-401;0;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1504884422206" ID="ID_1738943559" MODIFIED="1518487921073" TEXT="Anforderungen">
|
|
<node CREATED="1504884432700" ID="ID_1124930479" MODIFIED="1533608413776" TEXT="wir brauchen">
|
|
<node CREATED="1504884465448" ID="ID_158939863" MODIFIED="1518487921073" TEXT="schließlich.... Aufruf an den PanelManager"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504884487533" ID="ID_1578364370" MODIFIED="1561827465183" TEXT="Art des Aufrufes">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1504885358585" ID="ID_1662504157" MODIFIED="1518487921073" TEXT="erzeuge neu in Panel(coord)"/>
|
|
<node CREATED="1504885435351" ID="ID_1583789854" MODIFIED="1518487921073" TEXT="ersetze in Panel(coord)"/>
|
|
<node CREATED="1504885503118" ID="ID_883040433" MODIFIED="1518487921073" TEXT="entferne view(ID) aus Panel(coord)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504885554399" ID="ID_1868485493" MODIFIED="1561827465183">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Allokator</i> pro Typ
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1504885680095" FOLDED="true" ID="ID_1828531407" MODIFIED="1561827483832" TEXT="sicherstellen">
|
|
<node CREATED="1504885686470" ID="ID_450596618" MODIFIED="1518487921073" TEXT="-- nix --"/>
|
|
<node CREATED="1504885692389" ID="ID_735840491" MODIFIED="1518487921073" TEXT="global einer"/>
|
|
<node CREATED="1504885708291" ID="ID_304260062" MODIFIED="1518487921073" TEXT="limit pro Fenster"/>
|
|
</node>
|
|
<node CREATED="1504886385928" ID="ID_894995512" MODIFIED="1518487921073" TEXT="Koordinaten finden...">
|
|
<arrowlink COLOR="#21428c" DESTINATION="ID_660502374" ENDARROW="Default" ENDINCLINATION="30;-48;" ID="Arrow_ID_900798705" STARTARROW="None" STARTINCLINATION="158;0;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504886036743" ID="ID_1013293844" MODIFIED="1561827465184" TEXT="UI-Koordinaten">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1504886051389" ID="ID_1177567162" MODIFIED="1518487921073" TEXT="Tupel {Fenster, Perspektive, Panel, Gruppe, Pfad}"/>
|
|
<node CREATED="1504886084393" ID="ID_28488269" MODIFIED="1576282358109" TEXT="optionale Komponenten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wir brauchen eine Repräsentation,
|
|
</p>
|
|
<p>
|
|
um auszudrücken, daß gewissen Angaben ausgelassen wurden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504886119604" ID="ID_206635297" MODIFIED="1518487921073" TEXT="komplexes Thema">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1504885799423" FOLDED="true" ID="ID_660502374" MODIFIED="1561827483833" TEXT="coordinate resolver">
|
|
<linktarget COLOR="#21428c" DESTINATION="ID_660502374" ENDARROW="Default" ENDINCLINATION="30;-48;" ID="Arrow_ID_900798705" SOURCE="ID_894995512" STARTARROW="None" STARTINCLINATION="158;0;"/>
|
|
<node CREATED="1504885810485" FOLDED="true" ID="ID_822801746" MODIFIED="1561827482928" TEXT="Fenster">
|
|
<node CREATED="1504885841193" ID="ID_202708982" MODIFIED="1518487921073" TEXT="by ID"/>
|
|
<node CREATED="1504885820724" ID="ID_1450511748" MODIFIED="1518487921073" TEXT="erstes"/>
|
|
<node CREATED="1504885827803" ID="ID_1198849275" MODIFIED="1518487921073" TEXT="aktuelles"/>
|
|
</node>
|
|
<node CREATED="1504885855551" ID="ID_812520157" MODIFIED="1518487921073" TEXT="match Perspektive"/>
|
|
<node CREATED="1504885875884" FOLDED="true" ID="ID_1808427553" MODIFIED="1561827482928" TEXT="Panel">
|
|
<node CREATED="1504885879652" ID="ID_1434158169" MODIFIED="1518487921073" TEXT="hasPanel(Window)"/>
|
|
<node CREATED="1504885976847" ID="ID_290757972" MODIFIED="1518487921073" TEXT="createPanel"/>
|
|
</node>
|
|
<node CREATED="1504886006459" FOLDED="true" ID="ID_1307875760" MODIFIED="1561827482928" TEXT="group">
|
|
<node CREATED="1504886010442" ID="ID_1660557914" MODIFIED="1518487921073" TEXT="panel has group"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1505420642387" ID="ID_9234158" MODIFIED="1522937622171" TEXT="UI-Koordinaten Builder-DSL">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504886210096" ID="ID_1980896942" MODIFIED="1533608413780" TEXT="locate ->">
|
|
<node CREATED="1504886227678" ID="ID_1936525982" MODIFIED="1518487921073" TEXT="existiert | machbar | unmöglich"/>
|
|
<node CREATED="1504959598053" ID="ID_952692651" MODIFIED="1518487921073" TEXT="Zielkoordinaten"/>
|
|
</node>
|
|
<node CREATED="1504959603212" ID="ID_627664382" MODIFIED="1533608413780" TEXT="alloc ->">
|
|
<node CREATED="1504959659068" ID="ID_389794808" MODIFIED="1518487921073" TEXT="allocator(Zielkoordinaten, managementScope, limit)"/>
|
|
<node CREATED="1504959829510" ID="ID_570145960" MODIFIED="1518487921073" TEXT="POST: neuer / alter View unter Zielkoordinaten erreichbar"/>
|
|
<node CREATED="1504959871472" ID="ID_864423184" MODIFIED="1518487921073" TEXT="ggfs rekonfigurieren..."/>
|
|
</node>
|
|
<node CREATED="1504961752279" ID="ID_361507996" MODIFIED="1533608413780" TEXT="Signaturen">
|
|
<node CREATED="1504961759077" ID="ID_627682268" MODIFIED="1518487921073" TEXT="locate: UICoord"/>
|
|
<node CREATED="1504961784098" ID="ID_268457753" MODIFIED="1518487921073" TEXT="count: UICoord(UICoord)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504962005981" ID="ID_1955013070" MODIFIED="1518487921073" TEXT="Spec.locate">
|
|
<node CREATED="1504962498963" ID="ID_1263067927" MODIFIED="1518487921073" TEXT="firstWindow"/>
|
|
<node CREATED="1504962486589" ID="ID_246663472" MODIFIED="1518487921073" TEXT="currentWindow"/>
|
|
<node CREATED="1504962506970" ID="ID_726895192" MODIFIED="1518487921073" TEXT="perspective(id)"/>
|
|
<node CREATED="1504962522800" ID="ID_224266262" MODIFIED="1518487921074" TEXT="panel(id)"/>
|
|
<node CREATED="1504962530335" ID="ID_465095301" MODIFIED="1518487921074" TEXT="existingPanel(id)"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504962643384" ID="ID_1610178620" MODIFIED="1533608413781" TEXT="existingGroup">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1504962664781" ID="ID_261278011" MODIFIED="1518487921074" TEXT="ist das implementierbar?"/>
|
|
<node CREATED="1504962671884" ID="ID_583107872" MODIFIED="1518487921074" TEXT="braucht verdeckten Parameter"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504962013068" ID="ID_1352068125" MODIFIED="1518487921074" TEXT="Spec.alloc">
|
|
<node CREATED="1504962685443" ID="ID_663273997" MODIFIED="1518487921074" TEXT="unlimited"/>
|
|
<node CREATED="1504962692881" ID="ID_261391829" MODIFIED="1518487921074" TEXT="onlyOne"/>
|
|
<node CREATED="1504962700536" ID="ID_1061344108" MODIFIED="1518487921074" TEXT="limitPerWindow(cnt)"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1506034501537" FOLDED="true" ID="ID_262802757" MODIFIED="1561827465188" TEXT="TODO">
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node CREATED="1506034518068" ID="ID_1413583873" MODIFIED="1518487921074" TEXT="ViewSpecDSL wird für Location Spec zuständig"/>
|
|
<node CREATED="1506034529729" ID="ID_1906856590" MODIFIED="1518487921074" TEXT="Keine Generics mehr notwendig"/>
|
|
<node CREATED="1506034536976" ID="ID_760545085" MODIFIED="1522937397270" TEXT="locationSpec ist direkt eine UICoord">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1506114845775" ID="ID_98017975" MODIFIED="1518487921074" TEXT="muß DSL-Elemente unterstützen"/>
|
|
<node CREATED="1506034566805" ID="ID_726919191" MODIFIED="1533608413782" TEXT="ODER-Behandlung wandert in UICoord">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1515632006668" ID="ID_1085098385" MODIFIED="1518487921074" TEXT="wirklich?">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1515632050143" ID="ID_1858706501" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Alternative: wrap UI-Coord,
|
|
</p>
|
|
<p>
|
|
thin augmentation layer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506114863020" ID="ID_1749053457" MODIFIED="1518487921074" TEXT="Problem: existingPanel(id)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522937399796" ID="ID_257379896" MODIFIED="1522937420005" TEXT="locationSpec wrappt">
|
|
<node CREATED="1522937421353" ID="ID_1526265712" MODIFIED="1522937428532" TEXT="LocationRule"/>
|
|
<node CREATED="1522937429384" ID="ID_159014153" MODIFIED="1522937437674" TEXT="Satz von Einzelregeln"/>
|
|
<node CREATED="1522937438358" ID="ID_1221727561" MODIFIED="1522937444145" TEXT="jede von diesen ist ein UICoord"/>
|
|
</node>
|
|
<node CREATED="1506120453114" ID="ID_1626834388" MODIFIED="1518487921074" TEXT="abgekürzte Schreibweise für Allocator-Spec"/>
|
|
<node CREATED="1506034548376" ID="ID_36109866" MODIFIED="1522937474269" TEXT="count -> umbenennen in alloc">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522937492519" ID="ID_996676171" MODIFIED="1522937502079" TEXT="generischen Aufrufmechanismus klären">
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833110793" ID="ID_10881417" MODIFIED="1518487921074" TEXT="Ausdrücke">
|
|
<node CREATED="1504833126079" FOLDED="true" ID="ID_286801467" MODIFIED="1561827465196" TEXT="konkret">
|
|
<cloud COLOR="#e6d0a4"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1504833146196" ID="ID_278904211" MODIFIED="1533608413783" TEXT="Timeline">
|
|
<node CREATED="1504833174961" ID="ID_1294462811" MODIFIED="1518487921074" TEXT="im Timeline-Panel der Gruppe hinzufügen"/>
|
|
<node CREATED="1504882791007" ID="ID_1520721786" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alloc = unlimited
|
|
</p>
|
|
<p>
|
|
locate = panel(timeline)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833569692" ID="ID_1069272084" MODIFIED="1533608413809" TEXT="Viewer">
|
|
<node CREATED="1504834559240" ID="ID_423545167" MODIFIED="1518487921074" TEXT="nur ein einziger(global)"/>
|
|
<node CREATED="1504883102734" ID="ID_81147050" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alloc = onlyOne
|
|
</p>
|
|
<p>
|
|
locate = external(beamer)
|
|
</p>
|
|
<p>
|
|
               or perspective(mediaView).panel(viewer)
|
|
</p>
|
|
<p>
|
|
               or existingPanel(viewer)
|
|
</p>
|
|
<p>
|
|
               or firstWindow().panel(viewer)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504834569831" ID="ID_1909335075" MODIFIED="1518487921074" TEXT="maximal 2 Viewer Panel"/>
|
|
<node CREATED="1504883107916" ID="ID_1351734300" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alloc = limitPerWindow(2)
|
|
</p>
|
|
<p>
|
|
locate = perspective(edit).existingPanel(viewer)
|
|
</p>
|
|
<p>
|
|
               or currentWindow().existingPanel(viewer)
|
|
</p>
|
|
<p>
|
|
               or existingPanel(viewer)
|
|
</p>
|
|
<p>
|
|
               or panel(viewer)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833572687" ID="ID_715257949" MODIFIED="1533608413811" TEXT="(Asset)Bin">
|
|
<node CREATED="1504834228100" ID="ID_189081279" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Asset-Panel der <i>jeweiligen</i> Gruppe hinzufügen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504883110076" ID="ID_199732103" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alloc = unlimited
|
|
</p>
|
|
<p>
|
|
locate = currentWindow().perspective(edit).existingPanel(asset).existingGroup()
|
|
</p>
|
|
<p>
|
|
               or perspective(asset)panel(asset)
|
|
</p>
|
|
<p>
|
|
               or firstWindow().panel(asset)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833574246" ID="ID_1680764695" MODIFIED="1533608413812" TEXT="FehlerLog">
|
|
<node CREATED="1504834859584" ID="ID_693499241" MODIFIED="1518487921074" TEXT="im aktuellen Infobox-Panel"/>
|
|
<node CREATED="1504883112068" ID="ID_308640581" MODIFIED="1518487921074">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alloc = limitPerWindow(1)
|
|
</p>
|
|
<p>
|
|
locate = currentWindow().existingPanel(infobox)
|
|
</p>
|
|
<p>
|
|
               or firstWindow().panel(infobox)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833575700" ID="ID_1341951504" MODIFIED="1533608413812" TEXT="Playcontrol">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504883115283" ID="ID_236325043" MODIFIED="1518487921075" TEXT="?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504880643748" ID="ID_1148134938" MODIFIED="1518487921075" TEXT="Design">
|
|
<node CREATED="1504880653395" ID="ID_110525549" MODIFIED="1518487921075" TEXT="Regel-artig"/>
|
|
<node CREATED="1504880660666" ID="ID_959703053" MODIFIED="1533608413814" TEXT="mit Präzedenz">
|
|
<node CREATED="1504880672873" ID="ID_355744291" MODIFIED="1518487921075" TEXT="Liste von Definitionen"/>
|
|
<node CREATED="1504880685783" ID="ID_1363213536" MODIFIED="1518487921075" TEXT="vom Speziellsten zum Allgemeinen"/>
|
|
<node CREATED="1504880722394" ID="ID_1620814124" MODIFIED="1561827465196">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Voraussetzung: <i>Anwendbarkeit</i> erkennen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1515632134915" ID="ID_1701452111" MODIFIED="1518487921075" TEXT="UICoordResolver kann das">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504881079778" FOLDED="true" ID="ID_1944767932" MODIFIED="1518487921075" TEXT="Form">
|
|
<node CREATED="1504881091345" ID="ID_453622973" MODIFIED="1518487921075" TEXT="Menge von Spezifikationen"/>
|
|
<node CREATED="1504881104919" ID="ID_1302649814" MODIFIED="1518487921075" TEXT="diese sind inhärent getypt"/>
|
|
<node CREATED="1504881124612" ID="ID_41842721" MODIFIED="1518487921075" TEXT="Spezifikation per Zuweisung"/>
|
|
<node CREATED="1504881139794" FOLDED="true" ID="ID_1982949721" MODIFIED="1518487921075" TEXT="zugewiesener Ausdruck ist passend getypt">
|
|
<node CREATED="1506120341257" ID="ID_1629432417" MODIFIED="1533608413815" TEXT="Loaction-Spec">
|
|
<node CREATED="1506120349336" ID="ID_1516960868" MODIFIED="1518487921075" TEXT="Menge von UI-Koordinaten"/>
|
|
<node CREATED="1506120361846" ID="ID_1024931059" MODIFIED="1518487921075" TEXT="unterstützt Alternativen"/>
|
|
<node CREATED="1506120367605" ID="ID_1489367458" MODIFIED="1518487921075" TEXT="wählt den ersten anwendbaren"/>
|
|
</node>
|
|
<node CREATED="1506120374116" ID="ID_1552148308" MODIFIED="1533608413815" TEXT="Allocator-Def">
|
|
<node CREATED="1506120380940" ID="ID_1553891423" MODIFIED="1518487921075" TEXT="ein Funktor UICorrd(UIcoord)"/>
|
|
<node CREATED="1506120391506" ID="ID_1217740236" MODIFIED="1518487921075" TEXT="Semantik: nimmt Spec und erzeugt konkretes Ziel"/>
|
|
<node CREATED="1506120410863" ID="ID_1205747223" MODIFIED="1561827465197" TEXT="Allocaotor-Specs">
|
|
<node CREATED="1506120420910" ID="ID_6299376" MODIFIED="1518487921075" TEXT="Hilfs-Tokens"/>
|
|
<node CREATED="1506120425773" ID="ID_195710124" MODIFIED="1518487921075" TEXT="partielle Funktionsanwendung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504881149417" ID="ID_178442113" MODIFIED="1518487921075" TEXT="Alternativen">
|
|
<node CREATED="1504881193043" FOLDED="true" ID="ID_1759689335" MODIFIED="1533608413816" TEXT="Komma-Operator">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1504881756073" ID="ID_1341009121" MODIFIED="1518487921075" TEXT="niedrigere Präzedenz als ="/>
|
|
<node CREATED="1504882453091" ID="ID_870917199" MODIFIED="1561827465198" TEXT="damit sehr einfach zu implementieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504882554718" ID="ID_744764331" MODIFIED="1518487921075" TEXT="weil auf dem DSL-Proxy"/>
|
|
<node CREATED="1504882560202" ID="ID_1190541919" MODIFIED="1518487921075" TEXT="egal, wenn beide Seiten der Zuweisung DSL sind"/>
|
|
<node CREATED="1504882584218" ID="ID_790570102" MODIFIED="1518487921075">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was hier <i>vielleicht</i> der Fall sein könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504882467714" ID="ID_759428035" MODIFIED="1518487921075" TEXT="bedeutet "and then" in Logik-Programmierung">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504881197490" ID="ID_1696182789" MODIFIED="1533608413818" TEXT="Oder-Operator">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504882423975" ID="ID_884614259" MODIFIED="1518487921075" TEXT="höhere Präzedenz als ="/>
|
|
<node CREATED="1504882434846" ID="ID_1018309959" MODIFIED="1561827465198" TEXT="zwei Alternativen">
|
|
<arrowlink COLOR="#1f6dc8" DESTINATION="ID_986692736" ENDARROW="Default" ENDINCLINATION="-13;-31;" ID="Arrow_ID_1057642367" STARTARROW="None" STARTINCLINATION="88;6;"/>
|
|
<node CREATED="1504882621302" ID="ID_1942501913" MODIFIED="1518487921075" TEXT="or"/>
|
|
<node CREATED="1504882633268" ID="ID_1285507370" MODIFIED="1518487921075" TEXT="|"/>
|
|
</node>
|
|
<node CREATED="1504882529890" ID="ID_233096485" MODIFIED="1561827465198" TEXT="semantisch klar">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1504882657576" ID="ID_986692736" MODIFIED="1518487921075" TEXT="beide Alternativen bieten">
|
|
<linktarget COLOR="#1f6dc8" DESTINATION="ID_986692736" ENDARROW="Default" ENDINCLINATION="-13;-31;" ID="Arrow_ID_1057642367" SOURCE="ID_1018309959" STARTARROW="None" STARTINCLINATION="88;6;"/>
|
|
</node>
|
|
<node CREATED="1504882665519" ID="ID_590443599" MODIFIED="1518487921075" TEXT="numerische Auswertung auszuschließen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1517970380222" ID="ID_1663499246" MODIFIED="1561827465199" TEXT="trickreich zu implementieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1517970403323" ID="ID_676104700" MODIFIED="1518487921075" TEXT="...wofern überhaupt möglich"/>
|
|
<node CREATED="1517970410690" ID="ID_1716625175" MODIFIED="1576282358109" TEXT="Problem sind die LocationClauses">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir haben nicht einfach UI-Coordinaten als DSl-Elemente,
|
|
</p>
|
|
<p>
|
|
sondern einzelne Klauseln, die allerdings jeweils eine UI-Coord wrappen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wenn man jedoch, rein syntaktisch zu schreiben beginnt "UICoord::window()"
|
|
</p>
|
|
<p>
|
|
dann bekommt man einen UICoord::Builder  und das ist noch keine Klausel!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#281977" CREATED="1517971193343" ID="ID_1413272427" MODIFIED="1518487921075" TEXT="vielleicht mit freiem OR-Operator?">
|
|
<arrowlink COLOR="#55618e" DESTINATION="ID_1299498209" ENDARROW="Default" ENDINCLINATION="115;1000;" ID="Arrow_ID_1706569145" STARTARROW="None" STARTINCLINATION="561;-39;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522937551446" ID="ID_1652249088" MODIFIED="1522937563222" TEXT="genau dieses + implizite Umwandlung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504831421266" ID="ID_1792240475" MODIFIED="1518487921075" TEXT="Zweck und Ziel">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1504831462636" ID="ID_252411082" MODIFIED="1518487921075" TEXT="Verhaltensmuster in ein Layout einbringen"/>
|
|
<node CREATED="1504831510806" ID="ID_834114445" MODIFIED="1518487921075" TEXT="zunächst sind Layouts eine fest vorgegeben"/>
|
|
<node CREATED="1504831537746" ID="ID_692369391" MODIFIED="1518487921075" TEXT="später könnte das user-Konfigurierbar werden">
|
|
<node CREATED="1504831564095" ID="ID_1860813217" MODIFIED="1518487921075" TEXT="per Einrichtungs UI"/>
|
|
<node CREATED="1504831577317" ID="ID_1281872136" MODIFIED="1518487921075" TEXT="als textuelle Konfiguration"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523019202064" FOLDED="true" HGAP="-88" ID="ID_1224438713" MODIFIED="1561827465213" TEXT="Low-Level-Zugriff" VSHIFT="93">
|
|
<arrowlink COLOR="#48678b" DESTINATION="ID_435980488" ENDARROW="Default" ENDINCLINATION="-1768;-2819;" ID="Arrow_ID_689216354" STARTARROW="Default" STARTINCLINATION="309;919;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1523023060481" ID="ID_1061103814" MODIFIED="1523023064036" TEXT="Zweck">
|
|
<node CREATED="1523020311838" ID="ID_118722698" MODIFIED="1523020315553" TEXT="Bindeglied">
|
|
<node CREATED="1523020317117" ID="ID_36029855" MODIFIED="1523020327967" TEXT="UI-Koordinaten"/>
|
|
<node CREATED="1523020328651" ID="ID_57107983" MODIFIED="1523020334087" TEXT="Component Views"/>
|
|
<node CREATED="1523020334770" ID="ID_1169326637" MODIFIED="1523020339014" TEXT="konkrete Widgets"/>
|
|
</node>
|
|
<node CREATED="1523023241752" ID="ID_1541233512" MODIFIED="1523023254890">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Schicht <i>unter</i> dem ViewLocator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1523023256246" ID="ID_1600604589" MODIFIED="1523023271295" TEXT="UI-Koordinaten ->">
|
|
<node CREATED="1523023272292" ID="ID_81266590" MODIFIED="1523023288805" TEXT="konkretes Element erreichen"/>
|
|
<node CREATED="1523023289345" ID="ID_625415004" MODIFIED="1523023295980" TEXT="konkretes Element erzeugen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523028361507" ID="ID_393788551" MODIFIED="1523028366222" TEXT="Abstraktion">
|
|
<node CREATED="1523028367338" ID="ID_204804362" MODIFIED="1523051167969" TEXT="ElementAccess">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1523028460629" ID="ID_683539946" MODIFIED="1523028462433" TEXT="Service">
|
|
<node CREATED="1523028463213" ID="ID_795295203" MODIFIED="1523030738854" TEXT="lib::Depend<ElementAccess>"/>
|
|
<node CREATED="1523030678458" ID="ID_1970353135" MODIFIED="1523030681637" TEXT="mockbar"/>
|
|
</node>
|
|
<node CREATED="1523055325343" ID="ID_1512953348" MODIFIED="1523055328331" TEXT="Dienste">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1523055329159" ID="ID_1316858206" MODIFIED="1523055337404" TEXT="noch nicht wirklich klar">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1523118112181" HGAP="58" ID="ID_1335551290" MODIFIED="1523118278708" TEXT="noch nicht klar, wer diesen Dienst bieten kann" VSHIFT="2">
|
|
<arrowlink COLOR="#ef9f88" DESTINATION="ID_1743128010" ENDARROW="Default" ENDINCLINATION="-2099;1258;" ID="Arrow_ID_175864704" STARTARROW="Default" STARTINCLINATION="-20;-1838;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node CREATED="1523055339293" ID="ID_805375580" MODIFIED="1523055357236" TEXT="erst mal ein Hilfsmittel für das Design">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523055360002" ID="ID_1183834156" MODIFIED="1523055363894" TEXT="yet another abstraction"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523059565187" ID="ID_685856143" MODIFIED="1523059569334" TEXT="Implementierung">
|
|
<node COLOR="#435e98" CREATED="1523059570619" FOLDED="true" ID="ID_1720611397" MODIFIED="1525124215025" TEXT="Problem: Typisierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1523059593831" ID="ID_1175935224" MODIFIED="1576282358108" TEXT="will mich nicht auf eine Basisklasse festlegen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
model::Tangible ist schön,
|
|
</p>
|
|
<p>
|
|
aber ich weiß nicht, ob das nicht zu eingeschränkt ist.
|
|
</p>
|
|
<p>
|
|
Beispielsweise werden Panel oder WorkspaceWindow ganz sicher keine Tangibles sein,
|
|
</p>
|
|
<p>
|
|
aber es könnte durchaus sein, daß man auf sie generisch zugreifen möchte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1523059669693" ID="ID_11075132" MODIFIED="1523227985279" STYLE="fork" TEXT="lib::AccessCasted">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1523227992122" ID="ID_1284848955" MODIFIED="1523227996485" TEXT="geht nicht direkt"/>
|
|
<node CREATED="1523227997217" ID="ID_82006262" MODIFIED="1523228003188" TEXT="void* hat kein RTTI"/>
|
|
<node CREATED="1523228003896" ID="ID_1572923964" MODIFIED="1523228016741" TEXT="es gibt keine gemeinsame Basisklasse">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523229374586" ID="ID_1962044591" MODIFIED="1523229381985" TEXT="sigc::trackable">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1523229383305" ID="ID_1786273483" MODIFIED="1523229392595" TEXT="hat kein RTTI"/>
|
|
<node CREATED="1523229393567" ID="ID_1067337253" MODIFIED="1523229403706" TEXT="wohl bewußte Design-Entscheidung"/>
|
|
</node>
|
|
<node CREATED="1523228995279" ID="ID_924400738" MODIFIED="1523229065936" TEXT="muß mich wohl auf eine Menge von Basis-Typen festlegen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1523229075403" ID="ID_808081590" MODIFIED="1523229080671" TEXT="model::Tangible"/>
|
|
<node CREATED="1523229081683" ID="ID_766417564" MODIFIED="1523229084838" TEXT="Gtk::Widget"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1523059717622" FOLDED="true" ID="ID_598506387" MODIFIED="1525124215028" TEXT="Grundstruktur">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1523059685611" ID="ID_1274858318" MODIFIED="1523059711165" TEXT="lib::Result">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523222317789" ID="ID_223201063" MODIFIED="1523222325262" TEXT="ist ein Either-Typ">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1523222326668" ID="ID_1906453858" MODIFIED="1523222336646" TEXT="bietet bereits bool-Abfrage / Exception"/>
|
|
<node CREATED="1523222338258" ID="ID_1400754551" MODIFIED="1523224303183" TEXT="paßt perfekt">
|
|
<arrowlink COLOR="#97db97" DESTINATION="ID_1568226158" ENDARROW="Default" ENDINCLINATION="226;0;" ID="Arrow_ID_26754858" STARTARROW="None" STARTINCLINATION="277;-10;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523224208591" FOLDED="true" ID="ID_1896914767" MODIFIED="1523225015564" TEXT="geht's noch einfacher?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1523224222477" ID="ID_769675431" MODIFIED="1523224258636" TEXT="reinen Pointer liefern?"/>
|
|
<node CREATED="1523224259839" ID="ID_1984912464" MODIFIED="1576282358108" TEXT="wer braucht Fehler?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zwei Fälle sind hier zu unterscheiden:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
der gewünschte Wert existiert nicht, und das ist auch das Ergebnis der Anfrage
|
|
</li>
|
|
<li>
|
|
es liegt eine Fehleinschätzung der Situation vor, insofern fest mit einem Ergebnis gerechnet wurde
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
In Fall-1 wird man eine bool-Abfrage machen wollen, und man kann auch mit einer false-Antwort umgehen. In Fall-2 dagegen bleibt nur noch der Tod. Und davon ist im Regelfall nicht auszugehen. Im Moment sehe ich Fall-2 als den <b>standard-use-Case</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1523224898647" ID="ID_1600596253" MODIFIED="1576282358107" TEXT="zwei nicht-kongruente Fälle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
im Fall-1 weiß der Client, daß er prüfen muß
|
|
</li>
|
|
<li>
|
|
im Fall-2 marschiert der Client einfach durch
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1523224938633" ID="ID_1168693432" MODIFIED="1523225005333" TEXT="SEGFAULT droht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1523224949440" ID="ID_1408830480" MODIFIED="1523224963825" TEXT="Option/Maybe-Typ notwendig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523059729276" ID="ID_117320755" MODIFIED="1523059751029" TEXT="sollte auf die Struktur von LocationQuery hinauslaufen"/>
|
|
<node CREATED="1523059751905" ID="ID_345254237" MODIFIED="1523059757668" TEXT="aber mit zusätzlichen Operationen...."/>
|
|
</node>
|
|
<node CREATED="1523118465853" ID="ID_1546860746" MODIFIED="1523118472608" TEXT="Differenzierung">
|
|
<node CREATED="1523118474171" ID="ID_96237584" MODIFIED="1523118480758" TEXT="verschiedene Typen von Aufgaben">
|
|
<node CREATED="1523118482458" ID="ID_1606478842" MODIFIED="1523118484694" TEXT="Zugriff"/>
|
|
<node CREATED="1523118485802" ID="ID_1745902381" MODIFIED="1523118494781" TEXT="Zugriff + Erzeugen"/>
|
|
<node CREATED="1523118498760" ID="ID_290260966" MODIFIED="1523118517809" TEXT="multiplicity kontrollieren"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523205852655" ID="ID_101568597" MODIFIED="1523205860142" TEXT="Zugriffs-Mechanik">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523222428901" ID="ID_1793979710" MODIFIED="1523222512561" TEXT="ein rekursiver drill-Down">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523222444467" ID="ID_770319889" MODIFIED="1523222512562" TEXT="der Endpunkt wird zugänglich gemacht">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523222481262" ID="ID_1485862182" MODIFIED="1523222512562" TEXT="allerdings nur zur Anwendung einer Strategie">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523222204556" ID="ID_1018012203" MODIFIED="1525124215030" TEXT="Ergebnis-Ausgabe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1523222214579" ID="ID_1568226158" MODIFIED="1576282358106" STYLE="fork" TEXT="Feststellung: keine Status-Rückmeldung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das mag überraschend klingen,
|
|
</p>
|
|
<p>
|
|
aber in der (zu erwartenden) Nutzsituation interessiert sich <i>keine Sau</i> dafür,
|
|
</p>
|
|
<p>
|
|
was denn nun konkret gemacht wurde, um den Dienst zu erbringen.
|
|
</p>
|
|
<p>
|
|
Die einzig interessante Information ist, ob es <b>gelungen</b> ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#97db97" DESTINATION="ID_1568226158" ENDARROW="Default" ENDINCLINATION="226;0;" ID="Arrow_ID_26754858" SOURCE="ID_1400754551" STARTARROW="None" STARTINCLINATION="277;-10;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523222380124" FOLDED="true" ID="ID_1101595897" MODIFIED="1561827465216" TEXT="muß prüfen, ob der Cast möglich ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1523229139923" ID="ID_636796034" MODIFIED="1531584013596" TEXT="Variant?">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1523229483619" ID="ID_1116388815" MODIFIED="1523587648174" TEXT="wohl einzige Lösung?">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#6c2525" CREATED="1523232748878" ID="ID_153055029" MODIFIED="1523587755516" TEXT="AUA --- geht auch nicht ohne Weiteres">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1523232788680" ID="ID_849117954" MODIFIED="1523232797628" TEXT="Ändert nix am Grundproblem">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1523232798911" ID="ID_351873038" MODIFIED="1523232810481" TEXT="AccessCasted für Zieltyp"/>
|
|
<node CREATED="1523232811805" ID="ID_577095101" MODIFIED="1523232886443" TEXT="läßt sich nur bei kompatiblem Basistyp überhaupt instantiieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1523232888115" ID="ID_800807629" MODIFIED="1523232908023">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber genau das ist hier jeweils nur <i>in einem Fall</i> gegeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1523232932724" ID="ID_386898631" MODIFIED="1533608413821" TEXT="Runtime-Compiletime-Problem">
|
|
<node CREATED="1523232945043" ID="ID_45452812" MODIFIED="1523232954053" TEXT="erst zur Laufzeit wissen wir, was zurückkommt"/>
|
|
<node CREATED="1523233007258" ID="ID_1076174983" MODIFIED="1523233019060" TEXT="aber zur Compilezeit müssen wir schon den Cast vorbereiten"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523233031479" ID="ID_1135973571" MODIFIED="1533608413821" TEXT="Idee: Visitor spezialisieren">
|
|
<linktarget COLOR="#3f6796" DESTINATION="ID_1135973571" ENDARROW="Default" ENDINCLINATION="-62;1;" ID="Arrow_ID_290291364" SOURCE="ID_1510464943" STARTARROW="None" STARTINCLINATION="8;-34;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1523233049316" ID="ID_278890079" MODIFIED="1523396787384" TEXT="er implementiert überhaupt nur den Fall, der geht">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1523587774453" ID="ID_887720572" MODIFIED="1523587792039" TEXT="in allen anderen Fällen bleibt der Result-Proxy leer"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523229496001" ID="ID_190653452" MODIFIED="1523229516738" TEXT="bedeutet...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1523229517523" ID="ID_1510464943" MODIFIED="1523587856731" TEXT="Variant-Visitor">
|
|
<arrowlink COLOR="#3f6796" DESTINATION="ID_1135973571" ENDARROW="Default" ENDINCLINATION="-62;1;" ID="Arrow_ID_290291364" STARTARROW="None" STARTINCLINATION="8;-34;"/>
|
|
</node>
|
|
<node CREATED="1523587686010" ID="ID_533196954" MODIFIED="1523587697908" TEXT="trickreiches Metaprogramming"/>
|
|
<node CREATED="1523229519846" ID="ID_307916731" MODIFIED="1523229533208" TEXT="Einschränkungen für die Test-Dummies"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523229147593" ID="ID_1510668106" MODIFIED="1523229476684" TEXT="if-else-Kaskade?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523225025493" ID="ID_1731501078" MODIFIED="1523225070764" TEXT="der interne Aufruf kann einen Pointer liefern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523225052314" ID="ID_271482556" MODIFIED="1523587734563" TEXT="die Aufrufschnittstelle stellt NULL-Check sicher">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523053331956" ID="ID_563797148" MODIFIED="1523053334615" TEXT="Test">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523053336219" ID="ID_1234019560" MODIFIED="1525124215034" TEXT="ElementAccess_test">
|
|
<linktarget COLOR="#43667c" DESTINATION="ID_1234019560" ENDARROW="Default" ENDINCLINATION="-338;-1489;" ID="Arrow_ID_839730277" SOURCE="ID_1539184761" STARTARROW="None" STARTINCLINATION="-530;453;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523118534675" ID="ID_669651266" MODIFIED="1523663819813" TEXT="Mock-Implementierung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1523118577557" ID="ID_1246038265" MODIFIED="1523118589479" TEXT="Mock-Prinzip">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1523118591395" ID="ID_1571065062" MODIFIED="1523118636465" TEXT="vorgefertigter Response">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1523118640980" ID="ID_866333439" MODIFIED="1523118644680" TEXT="billig"/>
|
|
<node CREATED="1523118645363" ID="ID_620926078" MODIFIED="1523118650798" TEXT="bringt mit jetzt schnell weiter"/>
|
|
</node>
|
|
<node CREATED="1523118600186" ID="ID_1717703636" MODIFIED="1523118638974" TEXT="emulierte Auswertung">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1523118604809" ID="ID_224206639" MODIFIED="1523118612228" TEXT="GenNodeLocationQuery aufbohren?"/>
|
|
<node CREATED="1523118613096" ID="ID_169844591" MODIFIED="1523118623074" TEXT="== Vorarbeit für die spätere Implementierung"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523663840577" ID="ID_1523982995" MODIFIED="1523670899095" TEXT="Mock-Widget-Erzeugung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1523663862182" ID="ID_937721725" MODIFIED="1523670907629" TEXT="besser in die Mock-Service-Impl verlegen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523663880731" ID="ID_1244735047" MODIFIED="1523670903598" TEXT="von dort nachprüfbar machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1523118660882" ID="ID_1452843558" MODIFIED="1523725214734" TEXT="Testfälle">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1523205670160" ID="ID_649704431" MODIFIED="1523663805752" TEXT="einfacher Zugriff auf existierendes Objekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1523205706547" ID="ID_210608554" MODIFIED="1523670915381" TEXT="Zugriff auf Parent-Ebene, ein Kind-Knoten wird erzeugt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523205752509" ID="ID_212194424" MODIFIED="1523205775730" TEXT="partielle oder komplette Erzeugung eines Pfades">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523205740998" ID="ID_1828083346" MODIFIED="1523205777745" TEXT="Limitierte Erzeugung von Kindern">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523725217249" ID="ID_168041841" MODIFIED="1523725232375" TEXT="bleibt halbfertig liegen">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1523726928069" ID="ID_1480266497" MODIFIED="1523726945723" TEXT="#1036 low-level Access implementieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1523055378032" ID="ID_406286329" MODIFIED="1525124215035" TEXT="Test-Hilfsmittel">
|
|
<linktarget COLOR="#eff1e5" DESTINATION="ID_406286329" ENDARROW="Default" ENDINCLINATION="-2304;344;" ID="Arrow_ID_1832343822" SOURCE="ID_1022913151" STARTARROW="None" STARTINCLINATION="498;45;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1523055393950" ID="ID_62932320" MODIFIED="1523055412955" TEXT="TestElementAccess">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1523055422074" ID="ID_1765892157" MODIFIED="1523055430229" TEXT="Fake-Implementierung des Interfaces">
|
|
<node CREATED="1523055519972" ID="ID_52044142" MODIFIED="1523055528879" TEXT="könnte sich mal zu einem Test-Framework auswachsen"/>
|
|
<node CREATED="1523055529443" ID="ID_567387345" MODIFIED="1523055536280" TEXT="...aber nicht jetzt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523055431649" ID="ID_1190698125" MODIFIED="1523055442076" TEXT="kein GTK dahinter">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1523055476638" ID="ID_1252887483" MODIFIED="1523055485333" TEXT="verwende Marker-Dummy-Typen"/>
|
|
<node CREATED="1523055489736" ID="ID_1578213763" MODIFIED="1523055499219" TEXT="um polymorphen und generischen Zugang zu prüfen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489777673022" HGAP="-43" ID="ID_873069403" MODIFIED="1557498707220" TEXT="Zugang zu Proc-Commands" VSHIFT="34">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1489777702971" HGAP="125" ID="ID_1780068142" MODIFIED="1557498707220" TEXT="Framework muß geschaffen werden" VSHIFT="-42">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1489777783120" ID="ID_1439783231" MODIFIED="1557498707220" TEXT="Protokoll für den Zugang">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489777837120" ID="ID_466927949" MODIFIED="1557498707220" TEXT="Ort für Command-Definitionen"/>
|
|
<node COLOR="#338800" CREATED="1489777846095" ID="ID_1401258681" MODIFIED="1575131582794" TEXT="Design Proc-Command-Framework vorantreiben">
|
|
<arrowlink COLOR="#352c7d" DESTINATION="ID_1622574347" ENDARROW="Default" ENDINCLINATION="-461;-3358;" ID="Arrow_ID_1512127407" STARTARROW="None" STARTINCLINATION="1819;0;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489777738462" ID="ID_733673713" MODIFIED="1557498707220" TEXT="angebunden an den InteractionDirector"/>
|
|
<node CREATED="1489777748748" ID="ID_1098831130" MODIFIED="1557498707220" TEXT="statisches Front-End: CmdAccessor"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1486763185746" FOLDED="true" HGAP="33" ID="ID_362749694" MODIFIED="1557498707220" TEXT="InteractionDirector" VSHIFT="21">
|
|
<arrowlink COLOR="#3b4877" DESTINATION="ID_700485676" ENDARROW="Default" ENDINCLINATION="430;-874;" ID="Arrow_ID_454081114" STARTARROW="Default" STARTINCLINATION="-170;534;"/>
|
|
<linktarget COLOR="#798eba" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-218;-590;" ID="Arrow_ID_757867749" SOURCE="ID_1440190469" STARTARROW="None" STARTINCLINATION="15;121;"/>
|
|
<linktarget COLOR="#5e4463" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-57;-739;" ID="Arrow_ID_1847127764" SOURCE="ID_474441211" STARTARROW="None" STARTINCLINATION="73;95;"/>
|
|
<linktarget COLOR="#683c5b" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-394;0;" ID="Arrow_ID_1979576517" SOURCE="ID_113005643" STARTARROW="None" STARTINCLINATION="-24;-159;"/>
|
|
<linktarget COLOR="#1b3863" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-518;1012;" ID="Arrow_ID_959577029" SOURCE="ID_735655054" STARTARROW="Default" STARTINCLINATION="-376;-568;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1486763268223" ID="ID_199328732" MODIFIED="1557498707220" TEXT="nicht der Meister">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1486763278189" ID="ID_330558344" MODIFIED="1557498707220" TEXT="aber ein zentrales Bindeglied"/>
|
|
<node CREATED="1486763287244" ID="ID_1712681910" MODIFIED="1557498707220" TEXT="zwei Welten">
|
|
<node CREATED="1486763292028" ID="ID_1224392598" MODIFIED="1557498707220" TEXT="Modell-struktur == Hierarchie"/>
|
|
<node CREATED="1486763303066" ID="ID_1274975607" MODIFIED="1557498707220" TEXT="Interaktion == Fokus und Kontext"/>
|
|
</node>
|
|
<node CREATED="1486763350764" ID="ID_1309124609" MODIFIED="1557498707220" TEXT="Aufgaben">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1486763355739" ID="ID_745725927" MODIFIED="1557498707220" TEXT="Bindung für Aktionen bereitstellen"/>
|
|
<node CREATED="1488566356774" FOLDED="true" ID="ID_969011841" MODIFIED="1557498707220" TEXT="Ankerpunkt zum Bilden der Commands">
|
|
<arrowlink COLOR="#706a9a" DESTINATION="ID_1461875887" ENDARROW="Default" ENDINCLINATION="-923;-789;" ID="Arrow_ID_457540370" STARTARROW="None" STARTINCLINATION="867;304;"/>
|
|
<node CREATED="1488566405248" ID="ID_355508260" MODIFIED="1557498707220" TEXT="auffinden der Command-IDs">
|
|
<node CREATED="1489191528425" ID="ID_1331796226" MODIFIED="1582931241668" TEXT="Neuer Service hierfür in Proc">
|
|
<arrowlink COLOR="#584d79" DESTINATION="ID_341428100" ENDARROW="Default" ENDINCLINATION="1864;-1272;" ID="Arrow_ID_879741123" STARTARROW="None" STARTINCLINATION="769;78;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1488677809297" ID="ID_1520540731" MODIFIED="1557498707220" TEXT="Problem: Zugang / Wiring">
|
|
<arrowlink DESTINATION="ID_850989325" ENDARROW="Default" ENDINCLINATION="183;-575;" ID="Arrow_ID_1002016515" STARTARROW="None" STARTINCLINATION="624;264;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488566427445" ID="ID_567418101" MODIFIED="1557498707220" TEXT="InteractionStateManager">
|
|
<node CREATED="1488566447466" ID="ID_1978593319" MODIFIED="1557498707220" TEXT="hängen darunter"/>
|
|
<node CREATED="1488566452538" ID="ID_1569803797" MODIFIED="1557498707220" TEXT="werden transient gebilet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486763376960" ID="ID_1618020758" MODIFIED="1557498707220" TEXT="Zugang zu den Timelines">
|
|
<node COLOR="#338800" CREATED="1480694550601" FOLDED="true" ID="ID_810032444" MODIFIED="1557498707220" TEXT="Timeline injizieren">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_810032444" ENDARROW="Default" ENDINCLINATION="-451;-531;" ID="Arrow_ID_1378803021" SOURCE="ID_1375216048" STARTARROW="None" STARTINCLINATION="345;28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539141031692" ID="ID_224638279" MODIFIED="1557498707220" TEXT="Aufruf aus dem TreeMutator-Binding"/>
|
|
<node COLOR="#338800" CREATED="1539141043842" FOLDED="true" ID="ID_1475393315" MODIFIED="1557498707220" TEXT="brauche Allocator für Timelines">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1539141064760" ID="ID_807914812" MODIFIED="1557498707220" TEXT="wo Service ansiedeln">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1539394478891" ID="ID_1478223120" MODIFIED="1557498707220" TEXT="analog zum Error-Log"/>
|
|
<node CREATED="1539394483610" ID="ID_847301374" MODIFIED="1557498707221" TEXT="vorläufig: WindowLocator -> PanelLoactor"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539141076630" ID="ID_399959646" MODIFIED="1557498707221" TEXT="Ausprägung / Platzierung festlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539388923323" ID="ID_585499856" MODIFIED="1557498707221" TEXT="Frage: wann wird eine Timeline im GUI repräsentiert?">
|
|
<arrowlink COLOR="#c8a1fe" DESTINATION="ID_430199880" ENDARROW="Default" ENDINCLINATION="-629;0;" ID="Arrow_ID_1293894659" STARTARROW="None" STARTINCLINATION="-505;56;"/>
|
|
<node CREATED="1539389169498" ID="ID_1287197830" MODIFIED="1557498707221" TEXT="immer?"/>
|
|
<node CREATED="1539389172250" ID="ID_1511105173" MODIFIED="1557498707221" TEXT="nur machmal?"/>
|
|
<node CREATED="1539389178833" ID="ID_1726056610" MODIFIED="1557498707221" TEXT="wer entscheidet?"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539389184120" ID="ID_1773551633" MODIFIED="1557498707221" TEXT="vorläufig: immer">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539389396443" ID="ID_1588695969" MODIFIED="1557498707221" TEXT="Konsequenz: Inaktiv == reine UI-Logik">
|
|
<node CREATED="1539389417033" ID="ID_1789060953" MODIFIED="1557498707221" TEXT="Schließen eines Tab"/>
|
|
<node CREATED="1539389434086" ID="ID_1428746299" MODIFIED="1557498707221" TEXT="muß das Widget zerstören"/>
|
|
<node CREATED="1539389442477" ID="ID_803437655" MODIFIED="1557498707221" TEXT="TimelineGui wird inaktiv"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539394521229" ID="ID_1457306650" MODIFIED="1557498707221" TEXT="den Rest überlassen wir dem TimelinePanel">
|
|
<arrowlink COLOR="#6bb2d4" DESTINATION="ID_50363803" ENDARROW="Default" ENDINCLINATION="381;11;" ID="Arrow_ID_1031630897" STARTARROW="None" STARTINCLINATION="-27;76;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539141131742" ID="ID_1557130599" MODIFIED="1557498707221" TEXT="WLink baut TimelineWidget und verdrahtet Controller">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539141115961" ID="ID_50363803" MODIFIED="1557498707221" TEXT="TimelineWidget installieren">
|
|
<arrowlink COLOR="#7882c8" DESTINATION="ID_1510868551" ENDARROW="Default" ENDINCLINATION="-587;-51;" ID="Arrow_ID_206932394" STARTARROW="None" STARTINCLINATION="-699;0;"/>
|
|
<linktarget COLOR="#6bb2d4" DESTINATION="ID_50363803" ENDARROW="Default" ENDINCLINATION="381;11;" ID="Arrow_ID_1031630897" SOURCE="ID_1457306650" STARTARROW="None" STARTINCLINATION="-27;76;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1539141189855" ID="ID_1121710933" MODIFIED="1557498707221" TEXT="Achtung: GUI lebt woanders...">
|
|
<arrowlink COLOR="#732647" DESTINATION="ID_385121370" ENDARROW="Default" ENDINCLINATION="93;-27;" ID="Arrow_ID_384022851" STARTARROW="None" STARTINCLINATION="-2;36;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539258904290" FOLDED="true" ID="ID_803293419" MODIFIED="1557498707221" TEXT="hier ein Platzhalter">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539258936270" FOLDED="true" ID="ID_966612516" MODIFIED="1557498707221" TEXT="was ist eine Timeline hier?">
|
|
<node CREATED="1539261019926" ID="ID_566230935" MODIFIED="1557498707221" TEXT="Empfangs-Gegenstelle"/>
|
|
<node CREATED="1539261038923" ID="ID_1048882319" MODIFIED="1557498707221" TEXT="diffMutable">
|
|
<node CREATED="1539261161651" ID="ID_833363023" MODIFIED="1557498707221" TEXT="forwarding">
|
|
<arrowlink DESTINATION="ID_1657820556" ENDARROW="Default" ENDINCLINATION="36;0;" ID="Arrow_ID_149841651" STARTARROW="None" STARTINCLINATION="36;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539261148341" ID="ID_1657820556" MODIFIED="1557498707221" TEXT="Zugang zum UI-Widget">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1657820556" ENDARROW="Default" ENDINCLINATION="36;0;" ID="Arrow_ID_149841651" SOURCE="ID_833363023" STARTARROW="None" STARTINCLINATION="36;0;"/>
|
|
</node>
|
|
<node CREATED="1539261050602" ID="ID_1069671492" MODIFIED="1557498707221" TEXT="Lebenszyklus-Proxy">
|
|
<node CREATED="1539261081830" ID="ID_1986320634" MODIFIED="1557498707221" TEXT="zerstört UI-Repräsentation kaskadierend"/>
|
|
<node CREATED="1539261110498" ID="ID_98327658" MODIFIED="1557498707221" TEXT="wird zum reine Platzhalter wenn UI-Widget verschwindet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539258947005" ID="ID_1624061939" MODIFIED="1557498707221" TEXT="Thema: Slave-Timeline (vertagt)">
|
|
<arrowlink COLOR="#bfb5ce" DESTINATION="ID_1028434909" ENDARROW="Default" ENDINCLINATION="-1311;-1012;" ID="Arrow_ID_1339464508" STARTARROW="None" STARTINCLINATION="505;-47;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539262387431" FOLDED="true" ID="ID_385121370" MODIFIED="1557498707221" TEXT="TimelineGui">
|
|
<linktarget COLOR="#732647" DESTINATION="ID_385121370" ENDARROW="Default" ENDINCLINATION="93;-27;" ID="Arrow_ID_384022851" SOURCE="ID_1121710933" STARTARROW="None" STARTINCLINATION="-2;36;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539262834731" ID="ID_1647910407" MODIFIED="1557498707221" TEXT="basiert auf WLink">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539262840962" ID="ID_1624846094" MODIFIED="1557498707221" TEXT="delegiert diffMutable">
|
|
<arrowlink DESTINATION="ID_1352270227" ENDARROW="Default" ENDINCLINATION="117;0;" ID="Arrow_ID_1672775567" STARTARROW="None" STARTINCLINATION="117;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1539262860719" ID="ID_113907558" MODIFIED="1557498707221" TEXT="ist ein smart-ptr<TimelineWidget>">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539382633847" ID="ID_376948699" MODIFIED="1557498707221" TEXT="hällt die Timeline-ID bereit">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539270786646" FOLDED="true" ID="ID_1019344552" MODIFIED="1557498707221" TEXT="delegierenden Mutator implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539270801572" ID="ID_1535443502" MODIFIED="1557498707221" TEXT="für InteractionDirector">
|
|
<node CREATED="1539270491013" ID="ID_1136748343" MODIFIED="1576203555715" TEXT="Problem der korrekten Diff-Struktur">
|
|
<arrowlink COLOR="#cbada9" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="1135;-119;" ID="Arrow_ID_46239762" STARTARROW="None" STARTINCLINATION="-408;50;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1539382792997" ID="ID_1411304100" MODIFIED="1557498707221" TEXT="im Diff muß jeweils die Root-Track-ID mitkommen"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1539270808827" FOLDED="true" ID="ID_1352270227" MODIFIED="1557498707221" TEXT="für TimelineGui">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1352270227" ENDARROW="Default" ENDINCLINATION="117;0;" ID="Arrow_ID_1672775567" SOURCE="ID_1624846094" STARTARROW="None" STARTINCLINATION="117;0;"/>
|
|
<node COLOR="#435e98" CREATED="1539294555064" HGAP="45" ID="ID_1365984217" MODIFIED="1557498707221" TEXT="Problem: diff ignorieren" VSHIFT="23">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1539294576338" ID="ID_485684974" MODIFIED="1557498707221" TEXT="kann das auftreten....?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1539294589200" ID="ID_1206613848" MODIFIED="1557498707221" TEXT="ja">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1539294594367" ID="ID_451112886" MODIFIED="1576282358106" TEXT="wenn InteractionDirector selber ein Diff empfängt...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welches in eine Kind-Timeline absteigt,
|
|
</p>
|
|
<p>
|
|
welche gegenwärtig im GUI nicht existiert
|
|
</p>
|
|
<p>
|
|
und daher auf "inaktiv" geschaltet ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539294678444" ID="ID_934706379" MODIFIED="1557498707221" TEXT="TreeMutator scheitert per Default">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539294698801" FOLDED="true" ID="ID_1533611583" MODIFIED="1561827465218" TEXT="also brauche ich einen /dev/null-Mutator">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539294727470" ID="ID_1958316881" MODIFIED="1539299017213" TEXT="speziellen Binding-Layer fabrizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1539294807066" ID="ID_1137741867" MODIFIED="1539294809654" TEXT="wie?"/>
|
|
<node CREATED="1539294812306" ID="ID_1564927840" MODIFIED="1539302566302" TEXT="muß das Standard-Mapping anschauen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1539294846845" ID="ID_1839295475" MODIFIED="1539294935855" TEXT="TreeDiffMutatorBinding">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1539294859537" ID="ID_637091190" MODIFIED="1539294928138" TEXT="__expect_further_elements -> immer true">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1539294892879" ID="ID_642349797" MODIFIED="1539294931009" TEXT="__expect_end_of_scope -> auch immer true">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1539294909749" ID="ID_1965063755" MODIFIED="1539294918319" TEXT="Impl in tree-diff.cpp">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539294950567" ID="ID_1321971857" MODIFIED="1539298935822" TEXT="alle Fälle durchklappern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539302456636" ID="ID_809868228" MODIFIED="1539302478177" TEXT="Idee: mit anderen Layern kombinieren...">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1539302481080" ID="ID_126724611" MODIFIED="1576282358105" TEXT="static_assertion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit es nicht versehentlich über einen anderen Layer gelegt wird,
|
|
</p>
|
|
<p>
|
|
welchen es dann überdecken und außer Gefecht setzen würde.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Habe verifiziert, daß diese Assertion tatsächlich greift
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539294743739" ID="ID_1596076772" MODIFIED="1539294758145" TEXT="Builder().ignoreAll()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539294760464" ID="ID_1376112641" MODIFIED="1539302371782" TEXT="DiffIgnoreChanges_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539298953819" ID="ID_1706428916" MODIFIED="1539298972769" TEXT="leerer TreeMutator produziert Fehler">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539298974312" ID="ID_986781359" MODIFIED="1539298992271" TEXT="BlackHoleMutation frißt alles">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539298993222" ID="ID_647799125" MODIFIED="1539302373522" TEXT="Kombinieren mit speziellem Overlay">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486763385591" ID="ID_6651258" MODIFIED="1557498707221" TEXT="Zugang zum Asset-Management"/>
|
|
<node CREATED="1486763391862" ID="ID_1568245541" MODIFIED="1557498707221" TEXT="Zugang zur Konfiguration"/>
|
|
<node CREATED="1486763408780" ID="ID_520762274" MODIFIED="1557498707221" TEXT="Zugang zum persistenten Interface-State"/>
|
|
<node CREATED="1504371285442" ID="ID_634013434" MODIFIED="1557498707221" TEXT="Allokation von ComponentViews">
|
|
<arrowlink DESTINATION="ID_948587913" ENDARROW="Default" ENDINCLINATION="87;-34;" ID="Arrow_ID_1863964331" STARTARROW="None" STARTINCLINATION="157;10;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1486768073223" FOLDED="true" HGAP="38" ID="ID_1457876217" MODIFIED="1561827465223" TEXT="konkret" VSHIFT="16">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1486768080502" ID="ID_1759740464" MODIFIED="1518487921076" TEXT="Binde-Kontext für globale Aktionen"/>
|
|
<node CREATED="1486768086869" ID="ID_173538981" MODIFIED="1518487921076" TEXT="Idee/Konzept für kontextabhängige Aktionen">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1487119208622" ID="ID_728171298" MODIFIED="1518487921076" TEXT="Analyse anhand einiger Beispiele">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1488419440935" ID="ID_802346253" MODIFIED="1518487921076" TEXT="add Sequence">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1488419450812" ID="ID_179687468" MODIFIED="1518487921076" TEXT="add Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487119230659" ID="ID_651577067" MODIFIED="1518487921076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Frage: wieviel Interaction Control
|
|
</p>
|
|
<p>
|
|
müssen wir sofort jetzt implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487208182655" ID="ID_1220225827" MODIFIED="1518487921076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauche ein <i>aktuelles</i> Modell-Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487208211131" ID="ID_31351462" MODIFIED="1518487921076" TEXT="...und ein Konzept, wie man das gewinnen kann">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487208260557" ID="ID_1057793058" MODIFIED="1518487921076" TEXT="und wer dafür zuständig sein wird">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1493852906845" HGAP="24" ID="ID_1176492517" MODIFIED="1533684335148" TEXT="siehe auch #1097 clarify the role of the panels in the UI" VSHIFT="9">
|
|
<arrowlink COLOR="#636eac" DESTINATION="ID_429407869" ENDARROW="Default" ENDINCLINATION="650;-595;" ID="Arrow_ID_1361390047" STARTARROW="None" STARTINCLINATION="1465;0;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1176492517" ENDARROW="Default" ENDINCLINATION="-68;-316;" ID="Arrow_ID_1083220093" SOURCE="ID_1375700494" STARTARROW="None" STARTINCLINATION="550;-23;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504193112577" ID="ID_1851236797" MODIFIED="1518487921076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: Zusammenarbeit
|
|
</p>
|
|
<p>
|
|
mit docking panels
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193163264" ID="ID_1943521361" MODIFIED="1533608449611" TEXT="#1104 how to instruct actions through panels">
|
|
<arrowlink COLOR="#806893" DESTINATION="ID_1020871440" ENDARROW="Default" ENDINCLINATION="-3;460;" ID="Arrow_ID_412107208" STARTARROW="Default" STARTINCLINATION="-618;-18;"/>
|
|
<arrowlink COLOR="#b37033" DESTINATION="ID_945788817" ENDARROW="None" ENDINCLINATION="-255;-86;" ID="Arrow_ID_61914" STARTARROW="Default" STARTINCLINATION="-618;-18;"/>
|
|
<linktarget COLOR="#9e99b7" DESTINATION="ID_1943521361" ENDARROW="Default" ENDINCLINATION="-1423;-376;" ID="Arrow_ID_779469840" SOURCE="ID_1446703192" STARTARROW="None" STARTINCLINATION="920;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1533608904623" HGAP="23" ID="ID_1433582308" MODIFIED="1533608919938" TEXT="Anforderungen" VSHIFT="-13">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533608945321" ID="ID_585599427" MODIFIED="1533608961747" TEXT="Zugang via ViewLocator"/>
|
|
<node CREATED="1533608737142" ID="ID_752377318" MODIFIED="1533608980481" TEXT="der ausführende View-Erzeuger braucht Zugang zum UI-Bus"/>
|
|
<node CREATED="1533608822826" ID="ID_1500698931" MODIFIED="1533608834604" TEXT="Schema zur reproduzierbaren ID-Generierung ist notwendig">
|
|
<node CREATED="1533609015728" ID="ID_808376623" MODIFIED="1533609027770" TEXT="der nominelle Typ ergibt sich aus der Art der View"/>
|
|
<node CREATED="1533609029094" ID="ID_1039386191" MODIFIED="1533609047527" TEXT="der Symbol-Teil der ID muß vorhersagbar sein"/>
|
|
<node CREATED="1533609056050" ID="ID_1606983628" MODIFIED="1533609064701" TEXT="oder explizit anzufordern"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193392483" ID="ID_912677550" MODIFIED="1518487921076" TEXT="PanelManager muß umgeschrieben werden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193400426" ID="ID_1575758873" MODIFIED="1518487921076" TEXT="PanelManager muß umgezogen werden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193443636" ID="ID_1002171467" MODIFIED="1518487921076" TEXT="Abstraktion herausdestilieren">
|
|
<arrowlink COLOR="#4f6595" DESTINATION="ID_385011645" ENDARROW="Default" ENDINCLINATION="377;-49;" ID="Arrow_ID_1185839720" STARTARROW="None" STARTINCLINATION="-267;66;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672665626" ID="ID_590886664" MODIFIED="1518487921076" TEXT="Grundlagen für Command-handling"/>
|
|
<node CREATED="1487313769425" ID="ID_728232011" MODIFIED="1518487921076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Grundlagen für <b>InteractionControl</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1488419854029" ID="ID_932507511" MODIFIED="1566955621428" TEXT="erst mal: Konzept">
|
|
<arrowlink COLOR="#715f85" DESTINATION="ID_329609486" ENDARROW="Default" ENDINCLINATION="-368;-2533;" ID="Arrow_ID_575977434" STARTARROW="None" STARTINCLINATION="1641;-256;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1487313191100" ID="ID_1619021408" MODIFIED="1561827465228" TEXT="Fazit(TODO)">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1487313203254" ID="ID_573801539" MODIFIED="1518487921076" TEXT="Klassen anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1487313231355" ID="ID_1566121505" MODIFIED="1518487921076" TEXT="WorkSite">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313293850" ID="ID_1237669879" MODIFIED="1518487921076" TEXT="WorkSiteTrail">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313234714" ID="ID_1600517388" MODIFIED="1518487921076" TEXT="SpotLocator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313246333" ID="ID_1397075016" MODIFIED="1518487921076" TEXT="FocusTracker">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313253432" ID="ID_1727250153" MODIFIED="1518487921076" TEXT="Navigator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313374879" ID="ID_604164603" MODIFIED="1518487921076" TEXT="UiState">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1487313454220" FOLDED="true" ID="ID_640048374" MODIFIED="1518487921076" TEXT="Abgriff in CoreServices">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1487313462963" ID="ID_342355040" MODIFIED="1518487921076" TEXT="injizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487313475593" ID="ID_951423078" MODIFIED="1518487921076" TEXT="über Lifecycle nachdenken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1487472682881" ID="ID_1575753680" MODIFIED="1518487921076" TEXT="UI-Bus zuerst"/>
|
|
<node CREATED="1487472687641" ID="ID_731426548" MODIFIED="1518487921076" TEXT="dann Ui-Manager -> InteractionDirector -> Ui-State"/>
|
|
<node CREATED="1487472711453" ID="ID_759583421" MODIFIED="1518487921076" TEXT="beim Zerstören von GtkLumiera">
|
|
<node CREATED="1487472720476" ID="ID_1676214656" MODIFIED="1518487921076" TEXT="sollte die Event-Loop bereits beendet sein"/>
|
|
<node CREATED="1487472730667" ID="ID_1826692985" MODIFIED="1518487921076" TEXT="können aber noch Fenster existieren"/>
|
|
<node CREATED="1487472757439" ID="ID_977443666" MODIFIED="1518487921076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wird der Link zwischen CoreService und UI-State <i>dangling</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#659ba4" DESTINATION="ID_977443666" ENDARROW="None" ENDINCLINATION="552;26;" ID="Arrow_ID_1335141107" SOURCE="ID_1261936534" STARTARROW="Default" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1487472781532" ID="ID_957134114" MODIFIED="1518487921076" TEXT="kurz darauf wird auch CoreService + Nexus zerstört"/>
|
|
</node>
|
|
<node CREATED="1487472971330" ID="ID_81364279" MODIFIED="1518487921076" TEXT="grundsätzliches Shutdown-Problem">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1487472987984" ID="ID_1443542622" MODIFIED="1518487921076" TEXT="aber harmlos">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1487472993439" ID="ID_310404379" MODIFIED="1518487921076" TEXT="unter der Annahme, daß das UI wirklich single-threaded läuft"/>
|
|
<node CREATED="1487473004949" ID="ID_1092623141" MODIFIED="1518487921076" TEXT="wenn wir die Garantie haben, daß die Event-Loop nichts mehr macht"/>
|
|
<node CREATED="1487473038377" ID="ID_393673106" MODIFIED="1576282358105" TEXT="Policy: kein Tangible darf im dtor mit dem UI-Bus reden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...mit der Ausnahme des Automatismus,
|
|
</p>
|
|
<p>
|
|
der es selbst vom Bus abkoppelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487475679257" ID="ID_1700311138" MODIFIED="1518487921076" TEXT="wir injizieren anders herum">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1487475695910" ID="ID_1341876014" MODIFIED="1518487921076" TEXT="StateManager als sub-Service"/>
|
|
<node CREATED="1487475711092" ID="ID_838045301" MODIFIED="1518487921076" TEXT="gehört CoreService"/>
|
|
<node CREATED="1487475720363" ID="ID_693101732" MODIFIED="1518487921076" TEXT="läuft immer"/>
|
|
<node CREATED="1487475723771" ID="ID_959927308" MODIFIED="1518487921076" TEXT="wird in UiState injiziert"/>
|
|
<node CREATED="1487475738369" ID="ID_1261936534" MODIFIED="1518487921076" TEXT="harmloses Problem beseitigt">
|
|
<arrowlink COLOR="#659ba4" DESTINATION="ID_977443666" ENDARROW="None" ENDINCLINATION="552;26;" ID="Arrow_ID_1335141107" STARTARROW="Default" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1487475796409" ID="ID_49608905" MODIFIED="1518487921076" TEXT="StateRecorder nun angeschlossen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487313659680" ID="ID_1420397002" MODIFIED="1518487921076" TEXT="FocusTap">
|
|
<node CREATED="1487313668423" ID="ID_1248049801" MODIFIED="1518487921076" TEXT="Signal in model::Tangible"/>
|
|
<node CREATED="1487313680053" ID="ID_1563882406" MODIFIED="1518487921076" TEXT="Methode zum Installieren"/>
|
|
<node CREATED="1487313691644" ID="ID_1797207964" MODIFIED="1518487921076" TEXT="Verbindung zum FocusTracker herstellen (automatisch)"/>
|
|
<node CREATED="1487313717368" ID="ID_1638145586" MODIFIED="1518487921076" TEXT="entsprechend auch in WorkplaceWindow"/>
|
|
</node>
|
|
<node CREATED="1487313566901" ID="ID_268630370" MODIFIED="1518487921076" TEXT="Methoden">
|
|
<node CREATED="1487313570932" ID="ID_1733821258" MODIFIED="1518487921076" TEXT="getCurrentWorkSite"/>
|
|
<node CREATED="1487313578555" ID="ID_671600782" MODIFIED="1518487921076" TEXT="getCurrentMO">
|
|
<node CREATED="1487313612063" ID="ID_1795028934" MODIFIED="1518487921076" TEXT="ggfs.sinnvollen Dummy hier"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487461242609" ID="ID_164538059" MODIFIED="1557498707221" TEXT="Struktur">
|
|
<node CREATED="1487461304560" ID="ID_349728972" MODIFIED="1557498707221" TEXT="betreibt">
|
|
<node CREATED="1487273437019" ID="ID_1653934212" MODIFIED="1557498707221" TEXT="Navigator">
|
|
<node CREATED="1515879320297" ID="ID_1194515598" MODIFIED="1557498707221" TEXT="(abstrahierte) Baum-Struktur"/>
|
|
<node CREATED="1506957512565" ID="ID_1256149179" MODIFIED="1557498707221" TEXT="dient als Resolver">
|
|
<arrowlink COLOR="#3f4b87" DESTINATION="ID_848105210" ENDARROW="Default" ENDINCLINATION="-1260;542;" ID="Arrow_ID_1760927309" STARTARROW="None" STARTINCLINATION="1244;-591;"/>
|
|
<linktarget COLOR="#5068a8" DESTINATION="ID_1256149179" ENDARROW="Default" ENDINCLINATION="-104;99;" ID="Arrow_ID_1490250373" SOURCE="ID_650732591" STARTARROW="None" STARTINCLINATION="225;-6;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487270206369" ID="ID_1888334597" MODIFIED="1557498707221" TEXT="SpotLocator"/>
|
|
<node CREATED="1487275297855" ID="ID_898365328" MODIFIED="1557498707221" TEXT="FocusTracker"/>
|
|
<node CREATED="1504368969990" ID="ID_948587913" MODIFIED="1557498707221" TEXT="ViewLocator">
|
|
<arrowlink COLOR="#9da9b7" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-96;-128;" ID="Arrow_ID_17315740" STARTARROW="None" STARTINCLINATION="-94;5;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_948587913" ENDARROW="Default" ENDINCLINATION="87;-34;" ID="Arrow_ID_1863964331" SOURCE="ID_634013434" STARTARROW="None" STARTINCLINATION="157;10;"/>
|
|
<node CREATED="1504370345039" ID="ID_1018366676" MODIFIED="1557498707221" TEXT="Service"/>
|
|
<node CREATED="1504373189956" ID="ID_1625042163" MODIFIED="1557498707221" TEXT="intern direkt verdrahtet mit dem PanelLocator"/>
|
|
<node CREATED="1504370354446" ID="ID_1714266927" MODIFIED="1557498707221" TEXT="findet, ggfs alloziert einen ComponentView"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487461353681" ID="ID_1117222917" MODIFIED="1557498707221" TEXT="Modell">
|
|
<node CREATED="1487461361688" ID="ID_1787396394" MODIFIED="1557498707221" TEXT="Attrib">
|
|
<node CREATED="1487461413145" ID="ID_816848691" MODIFIED="1557498707221" TEXT="ctrl::UiState">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_816848691" ENDARROW="Default" ENDINCLINATION="111;0;" ID="Arrow_ID_792016162" SOURCE="ID_1032977850" STARTARROW="None" STARTINCLINATION="111;0;"/>
|
|
</node>
|
|
<node CREATED="1488492205990" ID="ID_1793304375" MODIFIED="1557498707221" TEXT="AssetController"/>
|
|
</node>
|
|
<node CREATED="1488492229939" ID="ID_996547800" MODIFIED="1557498707221" TEXT="Children">
|
|
<node CREATED="1488492233826" ID="ID_1743746426" MODIFIED="1557498707221" TEXT="Timelines"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487461436006" ID="ID_1721976078" MODIFIED="1557498707221" TEXT="Kooperation">
|
|
<node CREATED="1487461440509" ID="ID_1663368282" MODIFIED="1557498707221" TEXT="CoreService">
|
|
<node CREATED="1487461456739" ID="ID_1032977850" MODIFIED="1557498707221" TEXT="delegiert UiState">
|
|
<arrowlink DESTINATION="ID_816848691" ENDARROW="Default" ENDINCLINATION="111;0;" ID="Arrow_ID_792016162" STARTARROW="None" STARTINCLINATION="111;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487461476736" ID="ID_912393863" MODIFIED="1557498707221" TEXT="Actions">
|
|
<node CREATED="1487461484935" ID="ID_951148221" MODIFIED="1557498707221" TEXT="Kontext für globale Aktionen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506956798915" HGAP="-73" ID="ID_1897228503" MODIFIED="1557498707221" TEXT="Services" VSHIFT="32">
|
|
<node CREATED="1506956866802" ID="ID_652269096" MODIFIED="1557498707221" TEXT="Navigator">
|
|
<node CREATED="1507935433543" ID="ID_239254800" MODIFIED="1557498707221">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in <i>generischer UI-Struktur</i> bewegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1507935461787" ID="ID_1244300168" MODIFIED="1557498707221" TEXT="bietet command-and-query-Interface"/>
|
|
<node CREATED="1507935474273" ID="ID_650732591" MODIFIED="1557498707221" TEXT="dient als (Pfad-)Resolver für UI-Coord">
|
|
<arrowlink COLOR="#5068a8" DESTINATION="ID_1256149179" ENDARROW="Default" ENDINCLINATION="-104;99;" ID="Arrow_ID_1490250373" STARTARROW="None" STARTINCLINATION="225;-6;"/>
|
|
</node>
|
|
<node CREATED="1507935538409" ID="ID_1407528424" MODIFIED="1557498707221" TEXT="stützt sich auf ViewLocator ab">
|
|
<arrowlink COLOR="#89919c" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="90;-49;" ID="Arrow_ID_1845784021" STARTARROW="None" STARTINCLINATION="-22;31;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504368969990" ID="ID_344392695" MODIFIED="1557498707221" TEXT="ViewLocator">
|
|
<linktarget COLOR="#3b6680" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-269;-228;" ID="Arrow_ID_408957918" SOURCE="ID_1356241564" STARTARROW="Default" STARTINCLINATION="-858;0;"/>
|
|
<linktarget COLOR="#9da9b7" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-96;-128;" ID="Arrow_ID_17315740" SOURCE="ID_948587913" STARTARROW="None" STARTINCLINATION="-94;5;"/>
|
|
<linktarget COLOR="#89919c" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="90;-49;" ID="Arrow_ID_1845784021" SOURCE="ID_1407528424" STARTARROW="None" STARTINCLINATION="-22;31;"/>
|
|
<linktarget COLOR="#7c8aa8" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-676;143;" ID="Arrow_ID_1224269755" SOURCE="ID_869653682" STARTARROW="None" STARTINCLINATION="641;-106;"/>
|
|
<linktarget COLOR="#7f97bd" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-977;81;" ID="Arrow_ID_1627222173" SOURCE="ID_1747666798" STARTARROW="None" STARTINCLINATION="1159;303;"/>
|
|
<node CREATED="1504387078950" ID="ID_1433555277" MODIFIED="1557498707221" TEXT="bietet Komponenten-Management">
|
|
<node CREATED="1504387105363" ID="ID_631730744" MODIFIED="1557498707221" TEXT="neue Komponente"/>
|
|
<node CREATED="1504387110866" ID="ID_879632055" MODIFIED="1557498707221" TEXT="Komponente löschen"/>
|
|
<node CREATED="1504387189744" ID="ID_934669703" MODIFIED="1557498707221" TEXT="notwendig für Kind-Mutation">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1504368969990" ID="ID_1346454848" MODIFIED="1557498707221" TEXT="impl delegiert an den PanelLocator">
|
|
<linktarget COLOR="#7c8aa8" DESTINATION="ID_1346454848" ENDARROW="Default" ENDINCLINATION="22;11;" ID="Arrow_ID_1776804306" SOURCE="ID_1606296935" STARTARROW="Default" STARTINCLINATION="313;-14;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506956871401" ID="ID_1817966830" MODIFIED="1557498707221" TEXT="SpotLocator"/>
|
|
<node CREATED="1506956892303" ID="ID_238906242" MODIFIED="1557498707221" TEXT="FocusTracker"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485126466520" FOLDED="true" ID="ID_717310004" MODIFIED="1557498707221" TEXT="WindowManager" VSHIFT="34">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1485457325724" ID="ID_1954589768" MODIFIED="1557498707221" TEXT="nur für die Hauptfenster zuständig"/>
|
|
<node CREATED="1485457328043" ID="ID_1787642462" MODIFIED="1576282358104" TEXT="wir haben kein ApplicationWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das ist das vereinfachte Setup für "einfache" Applikationen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485457370310" ID="ID_1931452525" MODIFIED="1557498707221" TEXT="GtkWindow sind völlig ausreichend"/>
|
|
<node CREATED="1485546285407" ID="ID_1129769291" MODIFIED="1557498707221">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß kein <b>Manager</b> sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1485546319434" ID="ID_1592361314" MODIFIED="1557498707222" TEXT="macht nur eine Sache">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1485546325993" ID="ID_1335197005" MODIFIED="1557498707222" TEXT="nämlich eine Liste der Fenster verwalten"/>
|
|
<node CREATED="1504368623492" ID="ID_1993615747" MODIFIED="1557498707222" TEXT="und Zugang zu diesen Fenster bieten"/>
|
|
</node>
|
|
<node CREATED="1485546344471" ID="ID_582242471" MODIFIED="1557498707222" TEXT="WindowLocator">
|
|
<arrowlink DESTINATION="ID_298060478" ENDARROW="Default" ENDINCLINATION="25;-40;" ID="Arrow_ID_683571287" STARTARROW="None" STARTINCLINATION="-62;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1485546396952" FOLDED="true" ID="ID_298060478" MODIFIED="1557498707222" TEXT="WindowLocator">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_298060478" ENDARROW="Default" ENDINCLINATION="25;-40;" ID="Arrow_ID_683571287" SOURCE="ID_582242471" STARTARROW="None" STARTINCLINATION="-62;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1485546400807" ID="ID_1118405222" MODIFIED="1557498707222" TEXT="macht, was vom großen Manager übrig blieb"/>
|
|
<node CREATED="1485546425452" ID="ID_1088557274" MODIFIED="1557498707222" TEXT="wird von GtkLumiera gehalten und verdrahtet"/>
|
|
<node CREATED="1485548669665" ID="ID_285796853" MODIFIED="1557498707222" TEXT="Problem: wie erreichbar?">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485548702476" ID="ID_1295550090" MODIFIED="1557498707222" TEXT="Aufgabe: new_window">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1485548713610" ID="ID_1984416789" MODIFIED="1557498707222" TEXT="wird als Action verdrahtet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1485548727401" ID="ID_1344937285" MODIFIED="1557498707222" TEXT="was ist die Closure">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538942597728" ID="ID_539326328" MODIFIED="1557498707222" TEXT="globale Aktionen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" ID="ID_1992201258" MODIFIED="1557498707222" TEXT="re-locate Timeline View">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_1992201258" ENDARROW="Default" ENDINCLINATION="-784;-81;" ID="Arrow_ID_126634995" SOURCE="ID_1325225528" STARTARROW="None" STARTINCLINATION="651;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1538942638306" ID="ID_1819831711" MODIFIED="1557498707222" TEXT="View für ein (weiterhin) bestehendes Model-Element in ein anderes Fenster umziehen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193329508" FOLDED="true" ID="ID_629544763" MODIFIED="1561827465241" TEXT="Aufgabe: docking panels">
|
|
<linktarget COLOR="#b0466a" DESTINATION="ID_629544763" ENDARROW="Default" ENDINCLINATION="-849;-1967;" ID="Arrow_ID_1826422316" SOURCE="ID_1922506931" STARTARROW="None" STARTINCLINATION="690;23;"/>
|
|
<linktarget COLOR="#d65a8e" DESTINATION="ID_629544763" ENDARROW="Default" ENDINCLINATION="-176;0;" ID="Arrow_ID_232994989" SOURCE="ID_196345177" STARTARROW="None" STARTINCLINATION="-162;-93;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1504193340786" ID="ID_751993082" MODIFIED="1518487921077" TEXT="PanelLocator hier integrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504370542909" ID="ID_1318769916" MODIFIED="1518487921077" TEXT="Query-Front-end"/>
|
|
<node CREATED="1504371342426" ID="ID_1606296935" MODIFIED="1534517606904" TEXT="wird benötigt vom ViewLocator (InteractionDirector)">
|
|
<arrowlink COLOR="#7c8aa8" DESTINATION="ID_1346454848" ENDARROW="Default" ENDINCLINATION="22;11;" ID="Arrow_ID_1776804306" STARTARROW="Default" STARTINCLINATION="313;-14;"/>
|
|
<arrowlink COLOR="#546195" DESTINATION="ID_1633069135" ENDARROW="Default" ENDINCLINATION="-329;-257;" ID="Arrow_ID_1665485418" STARTARROW="None" STARTINCLINATION="273;0;"/>
|
|
</node>
|
|
<node CREATED="1504370524687" ID="ID_816760158" MODIFIED="1518487921077" TEXT="PanelManager in den einzelnen Fenstern"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534510952804" HGAP="21" ID="ID_1335931102" MODIFIED="1534511409140" TEXT="#1026 cleanup PanelManager" VSHIFT="1">
|
|
<arrowlink COLOR="#ce6b5f" DESTINATION="ID_1249897876" ENDARROW="Default" ENDINCLINATION="1299;0;" ID="Arrow_ID_1635700276" STARTARROW="Default" STARTINCLINATION="-1412;-1014;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534510993903" ID="ID_1287156693" MODIFIED="1534511005821" TEXT="Müllhaufen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1534515750767" HGAP="258" ID="ID_1360472787" MODIFIED="1534519968433" TEXT="bestehende Anforderungen" VSHIFT="-4">
|
|
<linktarget COLOR="#99a7bd" DESTINATION="ID_1360472787" ENDARROW="Default" ENDINCLINATION="772;-6907;" ID="Arrow_ID_1137118362" SOURCE="ID_592805858" STARTARROW="None" STARTINCLINATION="698;1616;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1534515787114" ID="ID_1305719148" MODIFIED="1534515800828" TEXT="Standard-Ausstattung mit Panels in jedem Fenster erzeugen"/>
|
|
<node CREATED="1534515801632" ID="ID_1919529189" MODIFIED="1534515823721" TEXT="Panel-Description-Index verwenden"/>
|
|
<node CREATED="1534515812439" ID="ID_1980530420" MODIFIED="1534515817842" TEXT="Liste aller Panels verwalten"/>
|
|
<node CREATED="1534515834947" ID="ID_510158797" MODIFIED="1534515927180" TEXT="gewünschtes Panel anzeigen, ggfs erstellen">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_510158797" ENDARROW="Default" ENDINCLINATION="104;0;" ID="Arrow_ID_161519533" SOURCE="ID_819902852" STARTARROW="None" STARTINCLINATION="83;0;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_510158797" ENDARROW="Default" ENDINCLINATION="68;0;" ID="Arrow_ID_970402595" SOURCE="ID_747338376" STARTARROW="None" STARTINCLINATION="89;0;"/>
|
|
</node>
|
|
<node CREATED="1534515873606" ID="ID_819902852" MODIFIED="1534515892457" TEXT="Referenz auf ein Panel beziehen">
|
|
<arrowlink DESTINATION="ID_510158797" ENDARROW="Default" ENDINCLINATION="104;0;" ID="Arrow_ID_161519533" STARTARROW="None" STARTINCLINATION="83;0;"/>
|
|
</node>
|
|
<node CREATED="1534515905714" ID="ID_747338376" MODIFIED="1534515927180" TEXT="Menü-Aktionen: bestimmtes Panel anzeigen">
|
|
<arrowlink DESTINATION="ID_510158797" ENDARROW="Default" ENDINCLINATION="68;0;" ID="Arrow_ID_970402595" STARTARROW="None" STARTINCLINATION="89;0;"/>
|
|
</node>
|
|
<node CREATED="1534515935653" ID="ID_1660813925" MODIFIED="1534516000145" TEXT="Panel durch ein Panel anderen Typs ersetzen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1534510983624" ID="ID_1587195721" MODIFIED="1534511031983" TEXT="setzt Konzept voraus">
|
|
<arrowlink COLOR="#202e48" DESTINATION="ID_1526164022" ENDARROW="Default" ENDINCLINATION="7;-78;" ID="Arrow_ID_1840345516" STARTARROW="None" STARTINCLINATION="-84;65;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529240056019" HGAP="33" ID="ID_1526164022" MODIFIED="1534511028176" TEXT="#1144 refactor dock handling" VSHIFT="-6">
|
|
<linktarget COLOR="#202e48" DESTINATION="ID_1526164022" ENDARROW="Default" ENDINCLINATION="7;-78;" ID="Arrow_ID_1840345516" SOURCE="ID_1587195721" STARTARROW="None" STARTINCLINATION="-84;65;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#435e98" CREATED="1534511467567" HGAP="37" ID="ID_358403014" MODIFIED="1534512921306" TEXT="Möglichkeiten der libGDL" VSHIFT="19">
|
|
<arrowlink COLOR="#39478f" DESTINATION="ID_833641481" ENDARROW="Default" ENDINCLINATION="-1307;0;" ID="Arrow_ID_214595057" STARTARROW="None" STARTINCLINATION="-2073;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533609225355" ID="ID_1031484560" MODIFIED="1534513589857" TEXT="Definitionen festlegen">
|
|
<linktarget COLOR="#8a9dae" DESTINATION="ID_1031484560" ENDARROW="Default" ENDINCLINATION="1135;-5718;" ID="Arrow_ID_1369217030" SOURCE="ID_1371608668" STARTARROW="None" STARTINCLINATION="1238;-672;"/>
|
|
<node CREATED="1533609236849" ID="ID_429407869" MODIFIED="1533684335148" TEXT="was ist ein Panel?">
|
|
<linktarget COLOR="#636eac" DESTINATION="ID_429407869" ENDARROW="Default" ENDINCLINATION="650;-595;" ID="Arrow_ID_1361390047" SOURCE="ID_1176492517" STARTARROW="None" STARTINCLINATION="1465;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533609255486" ID="ID_540986387" MODIFIED="1533609275839" TEXT="identifizierbarer Teilraum im UI"/>
|
|
<node CREATED="1533609277164" ID="ID_1581083802" MODIFIED="1533609290461" TEXT="ID ist Benennung + Typ"/>
|
|
<node CREATED="1533609292426" ID="ID_50953202" MODIFIED="1533609315339" TEXT="Typ legt aber auch teilw. die Platzierung/Präsentation fest"/>
|
|
<node CREATED="1533609332484" ID="ID_68265965" MODIFIED="1533609346342" TEXT="Panel selber ist "substanzlos"">
|
|
<node CREATED="1533609349730" ID="ID_1199787724" MODIFIED="1533609376170" TEXT="es wird durch seinen Inhalt mit geschaffen"/>
|
|
<node CREATED="1533609378773" ID="ID_896598248" MODIFIED="1533609383161" TEXT="Fallunterscheidung">
|
|
<node CREATED="1533609385005" HGAP="22" ID="ID_323786393" MODIFIED="1533609406631" TEXT="instruiert">
|
|
<node CREATED="1533609411841" ID="ID_1992759255" MODIFIED="1533609416652" TEXT="View-Anforderung"/>
|
|
<node CREATED="1533609417360" ID="ID_1927712425" MODIFIED="1533609433146" TEXT="die ViewSpect-DSL bestimmt, in welchem Panel er erzeugt wird"/>
|
|
</node>
|
|
<node CREATED="1533609393060" ID="ID_1618346972" MODIFIED="1533609401687" TEXT="per UI-Aktion erzeugt">
|
|
<node CREATED="1533609456899" ID="ID_1800763961" MODIFIED="1533609480660" TEXT="erzugt Panel mit seinem Standard-Inhalt (gemäß Panel-Typ)"/>
|
|
<node CREATED="1533609484543" ID="ID_381189275" MODIFIED="1533609505632" TEXT="dieser Standard-Inhalt wird generisch/per-default generiert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1529235573383" HGAP="36" ID="ID_1156887553" MODIFIED="1529235603008" TEXT="Aufteilen" VSHIFT="9">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1529235578053" ID="ID_1913662480" MODIFIED="1529235582697" TEXT="lokale UI-Mechanik">
|
|
<node CREATED="1531407468053" ID="ID_56121895" MODIFIED="1531407487128" TEXT="DockArea">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1531407492468" ID="ID_1972848436" MODIFIED="1531407498111" TEXT="Neue Entität"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531407498771" ID="ID_579294659" MODIFIED="1531414297601" TEXT="bestehenden Code porten">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1531414268783" ID="ID_1591679803" MODIFIED="1531414276500" TEXT="PanelManager macht bisher alles">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531414277462" ID="ID_438558819" MODIFIED="1531414290061" TEXT="bestehenden Code nachvollziehen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531414284237" ID="ID_242501935" MODIFIED="1531414288949" TEXT="sauber neu coden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1531407473064" ID="ID_1423333582" MODIFIED="1531407481582" TEXT="Einbindung der libGDL">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1529235583621" ID="ID_627187553" MODIFIED="1529235589904" TEXT="übergreifende Steuerung">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529240710412" HGAP="79" ID="ID_1137103744" MODIFIED="1529240803601" TEXT="Kontroll-Struktur einrichten" VSHIFT="-15">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1529240725545" ID="ID_1633069135" MODIFIED="1534517606904" TEXT="PanelLocator">
|
|
<linktarget COLOR="#546195" DESTINATION="ID_1633069135" ENDARROW="Default" ENDINCLINATION="-329;-257;" ID="Arrow_ID_1665485418" SOURCE="ID_1606296935" STARTARROW="None" STARTINCLINATION="273;0;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529240729817" ID="ID_899357717" MODIFIED="1529240766068" TEXT="hält Kontakt zu allen Docks">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529240757677" ID="ID_1894889790" MODIFIED="1529240766845" TEXT="Lebenszyklus-Signale">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1534519634333" ID="ID_298940282" MODIFIED="1534519643957" TEXT="vorläufig">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1534519645420" ID="ID_1509280168" MODIFIED="1576282358104" TEXT="übernimmt Funktionen vom ViewLocator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil ich Stand 8/2018 nicht im Stande bin,
|
|
</p>
|
|
<p>
|
|
den ViewLocator wirklich soweit fertig zu coden, daß er schon einsetzbar ist.
|
|
</p>
|
|
<p>
|
|
Problem ist die ganze abstrahierte Widget-Access-Schicht, die sich erst sinnvoll bauen läßt,
|
|
</p>
|
|
<p>
|
|
wenn es schon wirkliche und funktionierende Widgets im System gibt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534515750767" FOLDED="true" ID="ID_1614049284" MODIFIED="1561827465242" TEXT="Panel-Lookup/Allocation">
|
|
<linktarget COLOR="#aab7cb" DESTINATION="ID_1614049284" ENDARROW="Default" ENDINCLINATION="772;-6907;" ID="Arrow_ID_139428133" SOURCE="ID_1131466377" STARTARROW="None" STARTINCLINATION="676;1738;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534520212473" ID="ID_172585735" MODIFIED="1534526235983" TEXT="durch alle WorkspaceWindows iterieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534520223304" ID="ID_605426716" MODIFIED="1534526241279" TEXT="jeden lokalen PanelManager fragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534520258251" ID="ID_634139165" MODIFIED="1534526246434" TEXT="wenn nicht gefunden, dann erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534520271354" ID="ID_1722998809" MODIFIED="1576282358103" TEXT="PanelManager: reine Anfrage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bisher erzeugt die lookup-Operation automatisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534520304493" ID="ID_1795676672" MODIFIED="1534522378245" TEXT="wo erzeugen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1534520344584" ID="ID_637468747" MODIFIED="1534520371103" TEXT="im primary window">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1534520354510" ID="ID_1031648158" MODIFIED="1534520366567" TEXT="im aktuellen Fenster">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534520233134" ID="ID_1625789153" MODIFIED="1534522425348" TEXT="typsicheres Front-end vorschalten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1529240774003" ID="ID_1594029670" MODIFIED="1529240795457" TEXT="Zugriff auf Dock-Master">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504193354056" FOLDED="true" ID="ID_385011645" MODIFIED="1518487921077">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Abstraktion</b> zur Steuerung schaffen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#524f7b" DESTINATION="ID_385011645" ENDARROW="Default" ENDINCLINATION="353;-22;" ID="Arrow_ID_186523581" SOURCE="ID_65709251" STARTARROW="None" STARTINCLINATION="1270;350;"/>
|
|
<linktarget COLOR="#4f6595" DESTINATION="ID_385011645" ENDARROW="Default" ENDINCLINATION="377;-49;" ID="Arrow_ID_1185839720" SOURCE="ID_1002171467" STARTARROW="None" STARTINCLINATION="-267;66;"/>
|
|
<node CREATED="1504307876270" HGAP="80" ID="ID_714147133" MODIFIED="1518487921077" TEXT="Anforderungen" VSHIFT="-7">
|
|
<node CREATED="1504307921993" ID="ID_774956517" MODIFIED="1518487921077" TEXT="bestimmtes Element...">
|
|
<node CREATED="1504307933535" ID="ID_220451742" MODIFIED="1518487921077" TEXT="ansprechen">
|
|
<node CREATED="1504308372668" ID="ID_1978317777" MODIFIED="1518487921077" TEXT="Referenz für direkte Aufrufe"/>
|
|
<node CREATED="1504308379891" ID="ID_829774303" MODIFIED="1518487921077" TEXT="ID für UI-Bus-Kommunikation"/>
|
|
</node>
|
|
<node CREATED="1504307929599" ID="ID_1927494491" MODIFIED="1518487921077" TEXT="neu erzeugen"/>
|
|
<node CREATED="1504307954292" ID="ID_1658958044" MODIFIED="1518487921077" TEXT="löschen"/>
|
|
</node>
|
|
<node CREATED="1504308024282" ID="ID_1154461573" MODIFIED="1518487921077">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie <i>bestimmt?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1504308038873" ID="ID_1384201938" MODIFIED="1518487921077" TEXT="es gibt nur eines"/>
|
|
<node CREATED="1504308044016" ID="ID_1655384159" MODIFIED="1518487921077" TEXT="von bestimmter Art"/>
|
|
<node CREATED="1504308073444" ID="ID_1584894553" MODIFIED="1518487921077" TEXT="Typ + ID"/>
|
|
<node CREATED="1504308256876" ID="ID_733625102" MODIFIED="1518487921077" TEXT="Problem: View-Instanzen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1504308268370" ID="ID_1644215776" MODIFIED="1518487921077" TEXT="wie die ID festlegen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1504308288056" ID="ID_919032583" MODIFIED="1518487921077" TEXT="wer weiß von diesen Instanzen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1504308295190" ID="ID_981780857" MODIFIED="1518487921077" TEXT="wie werden sie im Model dargestellt?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504308325682" ID="ID_168204060" MODIFIED="1518487921077" TEXT="wer verfolgt die Lebensdauer?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504479018947" HGAP="185" ID="ID_88064796" MODIFIED="1518487921078" TEXT="folgt aus dem View-Zugriff" VSHIFT="11">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1531412797044" ID="ID_251560954" MODIFIED="1531412802639" TEXT="gebraucht wird...">
|
|
<node CREATED="1531412841422" ID="ID_701193023" MODIFIED="1531412940797" TEXT="Panel platzieren">
|
|
<node CREATED="1531412942145" ID="ID_1174626592" MODIFIED="1531412950131" TEXT="Panel in Fenster"/>
|
|
<node CREATED="1531412950839" ID="ID_1293555405" MODIFIED="1531413115821" TEXT="nur eine DockArea pro Fenster"/>
|
|
<node CREATED="1531413165251" ID="ID_1180700051" MODIFIED="1531413181908" TEXT="Panel hat Platzierungs-Default"/>
|
|
<node CREATED="1531413538025" ID="ID_1625813136" MODIFIED="1531413544964" TEXT="kann dann aber rearrangiert werden">
|
|
<node CREATED="1531413554415" ID="ID_1325622114" MODIFIED="1531413562449" TEXT="GDL selber ist sehr flexibel"/>
|
|
<node CREATED="1531413563662" ID="ID_329874195" MODIFIED="1531413568089" TEXT="kann mehrfach schachteln"/>
|
|
<node CREATED="1531413571197" ID="ID_1093029020" MODIFIED="1531413577359" TEXT="und Tabbed Notebooks bilden"/>
|
|
</node>
|
|
<node CREATED="1531413758804" ID="ID_914627458" MODIFIED="1531413769750" TEXT="Details des Platzierungs-Verhaltens">
|
|
<node CREATED="1531413770770" ID="ID_484369837" MODIFIED="1531413795844" TEXT="noch nicht klar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531413774745" ID="ID_1438103076" MODIFIED="1531413792505" TEXT="mehrere gleichartige Panel?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1531413838456" ID="ID_1565164486" MODIFIED="1531413845763" TEXT="nebeneinander einfügen?"/>
|
|
<node CREATED="1531413846704" ID="ID_157037460" MODIFIED="1531413852418" TEXT="ineinander einfügen?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1531413901368" ID="ID_375388369" MODIFIED="1531413905347" TEXT="Panel wiederherstellen">
|
|
<node CREATED="1531413950369" ID="ID_518996776" MODIFIED="1531413959020" TEXT="gegeben: Menge von UI-Koordinaten"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531413980270" ID="ID_1914402851" MODIFIED="1531413994427" TEXT="Frage: was genau kann GDL wiederherstellen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504194145622" ID="ID_511626836" MODIFIED="1518487921078" TEXT="Addressieren einzelner Kind-Komponenten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020429008" FOLDED="true" ID="ID_8715605" MODIFIED="1678461929265">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>UIStyle</b>: der »<u><font color="#2f297a">StyleManager</font></u>«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#6179b8" DESTINATION="ID_8715605" ENDARROW="Default" ENDINCLINATION="-946;80;" ID="Arrow_ID_1659593372" SOURCE="ID_873763889" STARTARROW="None" STARTINCLINATION="-1586;131;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1537743634839" ID="ID_390066923" MODIFIED="1563020438839" TEXT="#1169 Style Manager">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1563020456445" ID="ID_134906113" MODIFIED="1563020474783" TEXT="Stand 2019: weitgehend Funktionen von Joel Holdsworth"/>
|
|
<node CREATED="1678460345115" ID="ID_354436354" MODIFIED="1678460348702" TEXT="Aufgaben">
|
|
<node CREATED="1563020407852" ID="ID_280366952" MODIFIED="1678462193702" TEXT="Style / CSS">
|
|
<linktarget COLOR="#454571" DESTINATION="ID_280366952" ENDARROW="Default" ENDINCLINATION="234;-533;" ID="Arrow_ID_1461427805" SOURCE="ID_1512492571" STARTARROW="None" STARTINCLINATION="748;60;"/>
|
|
<linktarget COLOR="#4369a6" DESTINATION="ID_280366952" ENDARROW="Default" ENDINCLINATION="-566;432;" ID="Arrow_ID_1332353653" SOURCE="ID_1339380234" STARTARROW="None" STARTINCLINATION="-931;-99;"/>
|
|
<node CREATED="1563019888259" FOLDED="true" ID="ID_1755242650" MODIFIED="1678462202854" TEXT="UiManager: CSS-Pfad bereitstellen">
|
|
<linktarget COLOR="#4b31cd" DESTINATION="ID_1755242650" ENDARROW="Default" ENDINCLINATION="-1211;105;" ID="Arrow_ID_847790641" SOURCE="ID_331912016" STARTARROW="Default" STARTINCLINATION="-1782;0;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1562844888515" ID="ID_1004783054" MODIFIED="1678460298646" TEXT="#1171 investigate virtual widget path">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1563020407043" ID="ID_1465497201" MODIFIED="1678460384399" TEXT="Proof-of-Concept im Zusammenhang mit #1201">
|
|
<arrowlink COLOR="#2a7734" DESTINATION="ID_121593395" ENDARROW="Default" ENDINCLINATION="1608;-100;" ID="Arrow_ID_1114940878" STARTARROW="None" STARTINCLINATION="1991;114;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020493385" ID="ID_393380948" MODIFIED="1563020503179" TEXT="publiziert via Advice-System"/>
|
|
<node CREATED="1563020504983" ID="ID_743553538" MODIFIED="1563020535783" TEXT="Topics">
|
|
<node CREATED="1563020586598" ID="ID_71417902" MODIFIED="1563020586598" TEXT="style(trackBody)"/>
|
|
</node>
|
|
<node CREATED="1563020595314" HGAP="39" ID="ID_517868337" MODIFIED="1575052603900" TEXT="CSS-Pfad initial">
|
|
<linktarget COLOR="#3976e4" DESTINATION="ID_517868337" ENDARROW="Default" ENDINCLINATION="-1204;103;" ID="Arrow_ID_1481718697" SOURCE="ID_1653425334" STARTARROW="None" STARTINCLINATION="928;72;"/>
|
|
<node CREATED="1563020651779" ID="ID_64689753" MODIFIED="1563020660375" TEXT="wenn sich das erste TimelineWidget meldet"/>
|
|
<node CREATED="1563020662916" ID="ID_87556518" MODIFIED="1563020678127" TEXT="von diesem den konkreten Pfad zum BodyCanvasWidget beziehen"/>
|
|
<node CREATED="1563020681159" ID="ID_1474481449" MODIFIED="1563020687466" TEXT="diesen Pfad virtuell ausbauen">
|
|
<node CREATED="1563020689334" ID="ID_1244087719" MODIFIED="1563020703963" TEXT="Knoten: fork.timeline"/>
|
|
</node>
|
|
<node CREATED="1563020712094" ID="ID_363709831" MODIFIED="1563020720694" TEXT="Gtk::StyleKontext damit populieren"/>
|
|
<node CREATED="1563020723228" ID="ID_710572596" MODIFIED="1563020736448" TEXT="und per Advice-Provision publizieren">
|
|
<node CREATED="1563022011347" ID="ID_1677449627" MODIFIED="1563022020514" TEXT="nur beim ersten Mal">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022850037" ID="ID_1908316447" MODIFIED="1575240116524" TEXT="kann das Advice-System das?">
|
|
<arrowlink COLOR="#1dba57" DESTINATION="ID_1996378025" ENDARROW="Default" ENDINCLINATION="3933;-460;" ID="Arrow_ID_1546347584" STARTARROW="None" STARTINCLINATION="2753;244;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020737596" ID="ID_79793328" MODIFIED="1563020874158" TEXT="Ablauf/Timings">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1563020748317" ID="ID_1777148552" MODIFIED="1563020773686" TEXT="getriggert von InteractionDirector::injectTimeline()"/>
|
|
<node CREATED="1563020775222" ID="ID_234951225" MODIFIED="1563020785721" TEXT="zu dem Zeitpunkt ist das TimelineWidget komplett konstruiert"/>
|
|
<node CREATED="1563020786593" ID="ID_306641433" MODIFIED="1563020795432" TEXT="und in der übergordneten TimelinePane verankter"/>
|
|
<node CREATED="1563020796267" ID="ID_714522948" MODIFIED="1563020804769" TEXT="aber noch nicht realisiert / gezeichnet"/>
|
|
<node CREATED="1563020808469" ID="ID_1476613816" MODIFIED="1563020824176" TEXT="der Advice wird frühestens beim ersten draw()-Aufruf gebraucht"/>
|
|
<node CREATED="1563020836874" ID="ID_729790149" MODIFIED="1563020858525" TEXT="der Advice wird beim Shutdown des globalen UI-Kontext zurückgezogen"/>
|
|
<node COLOR="#435e98" CREATED="1563020825077" ID="ID_1941111431" MODIFIED="1563020864694" TEXT="garantiert wasserdicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563020603946" ID="ID_717062852" MODIFIED="1563020609158" TEXT="aktualisiert">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1563020611154" ID="ID_1878310069" MODIFIED="1563020617763" TEXT="7/2019 noch gar nicht"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563020618619" ID="ID_1265253347" MODIFIED="1563020633923" TEXT="Plan: beim Laden eines neuen Stylesheet">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1662052275502" ID="ID_297910960" MODIFIED="1665346725923" TEXT="Icons verwalten / Ressourcen bereitstellen">
|
|
<linktarget COLOR="#864e7a" DESTINATION="ID_297910960" ENDARROW="Default" ENDINCLINATION="-843;-48;" ID="Arrow_ID_154615679" SOURCE="ID_1280255371" STARTARROW="None" STARTINCLINATION="695;60;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1662151277190" ID="ID_1508158518" MODIFIED="1662151299801" TEXT="bestehender Code">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...stammt im Kern noch von Joel Holdsworth < 2012
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1662151302627" ID="ID_442009739" MODIFIED="1662151321940" TEXT="verwendet einen "Suchpfad" aus der Lumiera setup.ini"/>
|
|
<node CREATED="1662151324313" ID="ID_1725316253" MODIFIED="1662151341612" TEXT="normalerweise $ORIGIN/gui sowie $ORIGIN/gui/icons"/>
|
|
<node CREATED="1662151365635" ID="ID_1658097871" MODIFIED="1662151366575" TEXT="UiStyle::registerStockItems()"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1662151474747" ID="ID_127382457" MODIFIED="1662151477893" TEXT="#1030 : use "icon names" instead of Gtk::StockItem">
|
|
<linktarget COLOR="#7f668c" DESTINATION="ID_127382457" ENDARROW="Default" ENDINCLINATION="629;-31;" ID="Arrow_ID_1767981957" SOURCE="ID_719864598" STARTARROW="None" STARTINCLINATION="560;80;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485555987832" ID="ID_313705636" MODIFIED="1557498707222" TEXT="Wiring">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1485555999110" ID="ID_376092703" MODIFIED="1557498707222" TEXT="top-level macht GtkLumiera im ctor"/>
|
|
<node CREATED="1485556011260" ID="ID_1618308499" MODIFIED="1557498707222" TEXT="backlink zum Manager"/>
|
|
<node CREATED="1486943522965" FOLDED="true" ID="ID_36527267" MODIFIED="1557498707222" TEXT="top-level-Kontext">
|
|
<linktarget COLOR="#4f547b" DESTINATION="ID_36527267" ENDARROW="Default" ENDINCLINATION="-424;-2038;" ID="Arrow_ID_134552555" SOURCE="ID_984712012" STARTARROW="None" STARTINCLINATION="2547;286;"/>
|
|
<linktarget COLOR="#8c95b2" DESTINATION="ID_36527267" ENDARROW="Default" ENDINCLINATION="138;-548;" ID="Arrow_ID_1284182756" SOURCE="ID_576215675" STARTARROW="None" STARTINCLINATION="883;143;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node COLOR="#338800" CREATED="1678459444870" ID="ID_546190730" MODIFIED="1678459579081" TEXT="UI-top-Level wird direkt verdrahtet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. „konventionell“, per ctor-Parameter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#23d63e" DESTINATION="ID_576215675" ENDARROW="Default" ENDINCLINATION="-930;90;" ID="Arrow_ID_638247395" STARTARROW="None" STARTINCLINATION="801;59;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1488494592496" ID="ID_1586259377" MODIFIED="1557498707222" TEXT="UI-Bus"/>
|
|
<node CREATED="1488494579346" ID="ID_1182508289" MODIFIED="1557498707222" TEXT="UiManager"/>
|
|
<node CREATED="1486943529763" ID="ID_1188971928" MODIFIED="1557498707222" TEXT="WindowLocator"/>
|
|
<node CREATED="1486943607120" ID="ID_1101577688" MODIFIED="1557498707222" TEXT="InteractionDirector">
|
|
<node CREATED="1486943922541" ID="ID_646168152" MODIFIED="1557498707222" TEXT="Entspricht Model Root"/>
|
|
<node CREATED="1486943614039" ID="ID_1354424043" MODIFIED="1557498707222" TEXT="AssetController"/>
|
|
<node CREATED="1486943634229" ID="ID_1217772313" MODIFIED="1557498707222" TEXT="Kinder: Timelines">
|
|
<node CREATED="1486943640004" ID="ID_1237613626" MODIFIED="1557498707222" TEXT="Preferences"/>
|
|
<node CREATED="1486943643179" ID="ID_463409583" MODIFIED="1557498707222" TEXT="Assets"/>
|
|
<node CREATED="1486943645554" ID="ID_1803125679" MODIFIED="1557498707222" TEXT="Timeline"/>
|
|
</node>
|
|
<node CREATED="1488494646129" HGAP="34" ID="ID_1817005014" MODIFIED="1557498707222" TEXT="InteractionControl" VSHIFT="11">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1488494665798" ID="ID_1228864928" MODIFIED="1557498707222" TEXT="SpotLocator"/>
|
|
<node CREATED="1488494689843" ID="ID_1519420241" MODIFIED="1557498707222" TEXT="Navigator"/>
|
|
<node CREATED="1488494692802" ID="ID_1706374538" MODIFIED="1557498707222" TEXT="FocusTracker"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486943969999" ID="ID_1823284637" MODIFIED="1557498707222" TEXT="Wizzard">
|
|
<node CREATED="1533688038820" ID="ID_70134302" MODIFIED="1576202124808" TEXT="Fehlerlog (notification display)">
|
|
<linktarget COLOR="#a9aac1" DESTINATION="ID_70134302" ENDARROW="Default" ENDINCLINATION="-1984;0;" ID="Arrow_ID_1885125683" SOURCE="ID_361019548" STARTARROW="None" STARTINCLINATION="807;-66;"/>
|
|
</node>
|
|
<node CREATED="1486943974590" ID="ID_1603501979" MODIFIED="1557498707222" TEXT="Hilfe (Website?)"/>
|
|
<node CREATED="1486944977005" ID="ID_811162889" MODIFIED="1557498707222" TEXT="kontextsensitive Hilfe"/>
|
|
<node CREATED="1488494783190" ID="ID_1886731977" MODIFIED="1557498707222" TEXT="Assistenten"/>
|
|
<node CREATED="1488494785774" ID="ID_167814846" MODIFIED="1557498707222" TEXT="About"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488422770096" ID="ID_286551569" MODIFIED="1557498707222" TEXT="#1085 solve setup of top-level menu actions">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485556027322" FOLDED="true" ID="ID_196345177" MODIFIED="1557498707222" TEXT="Problem: Docking panels">
|
|
<arrowlink COLOR="#d65a8e" DESTINATION="ID_629544763" ENDARROW="Default" ENDINCLINATION="-176;0;" ID="Arrow_ID_232994989" STARTARROW="None" STARTINCLINATION="-162;-93;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1485556037465" ID="ID_1657490812" MODIFIED="1557498707222" TEXT="brauchen typischerweise eine Querverbindung"/>
|
|
<node CREATED="1485556046703" ID="ID_50463095" MODIFIED="1557498707222" TEXT="geht das über den Bus alleine?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1504386565227" ID="ID_889188219" MODIFIED="1557498707222" TEXT="nein">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1504386568907" ID="ID_792633121" MODIFIED="1557498707222" TEXT="Referenz notwendig"/>
|
|
</node>
|
|
<node CREATED="1485556056206" ID="ID_509456873" MODIFIED="1557498707222" TEXT="...sonst muß der PanelManager helfen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1504386527936" ID="ID_307889825" MODIFIED="1557498707222" TEXT="muß ID finden können"/>
|
|
<node CREATED="1504386535447" ID="ID_426578263" MODIFIED="1557498707222" TEXT="brauche Service zum Erzeugen/Löschen"/>
|
|
<node CREATED="1504386595679" ID="ID_1383687482" MODIFIED="1576282358103" TEXT="Mutation: brauche Model-Platzhalter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Diff wird auf den Platzhalter angewendet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504386636074" ID="ID_1996752633" MODIFIED="1576282358102" TEXT="automatisches Management vonöten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn das Diff ein Element aus einer Kind-Menge <i>wegfallen läßt,</i>
|
|
</p>
|
|
<p>
|
|
dann muß dieses automatisch deregistriert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504371342426" ID="ID_869653682" MODIFIED="1557498707222">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vermittelt über den <b>ViewLocator</b> (InteractionDirector)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7c8aa8" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-676;143;" ID="Arrow_ID_1224269755" STARTARROW="None" STARTINCLINATION="641;-106;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1488677721565" FOLDED="true" ID="ID_850989325" MODIFIED="1557498707222" TEXT="Problem: Zugang">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_850989325" ENDARROW="Default" ENDINCLINATION="183;-575;" ID="Arrow_ID_1002016515" SOURCE="ID_1520540731" STARTARROW="None" STARTINCLINATION="624;264;"/>
|
|
<linktarget COLOR="#9f5680" DESTINATION="ID_850989325" ENDARROW="Default" ENDINCLINATION="211;189;" ID="Arrow_ID_1007188680" SOURCE="ID_827179653" STARTARROW="None" STARTINCLINATION="963;-965;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node CREATED="1488677729388" ID="ID_764102285" MODIFIED="1557498707222" TEXT="grundsätziches Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1488678069565" ID="ID_346104238" MODIFIED="1557498707222" TEXT="explizite Verdrahtung scheidet aus"/>
|
|
<node CREATED="1488678077236" ID="ID_1536759032" MODIFIED="1557498707222" TEXT="klassisches Inversion-Of-Control">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1488678106024" ID="ID_1242521430" MODIFIED="1557498707222" TEXT="access by name">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488677737419" ID="ID_1621219441" MODIFIED="1557498707222" TEXT="einfach gelöst für top-Level">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1488677751537" ID="ID_75445042" MODIFIED="1557498707222" TEXT="schwierig für Widgets">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node COLOR="#338800" CREATED="1520721624161" ID="ID_1714114896" MODIFIED="1557498707222" TEXT="DependencyFactory">
|
|
<arrowlink COLOR="#5c71a3" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="767;-2073;" ID="Arrow_ID_1454095581" STARTARROW="None" STARTINCLINATION="1892;380;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520721630328" ID="ID_1547268458" MODIFIED="1557498707222" TEXT="wir haben schon eine Lösung für Singletons"/>
|
|
<node CREATED="1520721638143" ID="ID_1691402961" MODIFIED="1557498707222" TEXT="diese kann auf Services erweitert werden"/>
|
|
<node CREATED="1520721647670" ID="ID_1649501241" MODIFIED="1557498707222" TEXT="sollte auch Lösung für Tests beinhalten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533688118209" ID="ID_143545012" MODIFIED="1557498707222" TEXT="Use cases">
|
|
<node CREATED="1533688144038" ID="ID_745583947" MODIFIED="1557498707222" TEXT="bekannte dedizierte Services">
|
|
<node CREATED="1533688177913" FOLDED="true" ID="ID_1972484306" MODIFIED="1561827465244" TEXT="Fehlerlog">
|
|
<linktarget COLOR="#9c95b1" DESTINATION="ID_1972484306" ENDARROW="Default" ENDINCLINATION="-3826;-1250;" ID="Arrow_ID_1735504887" SOURCE="ID_528918224" STARTARROW="None" STARTINCLINATION="2269;1167;"/>
|
|
<node CREATED="1533688203118" ID="ID_1499180551" MODIFIED="1533688211792" TEXT="angesprochen via UI-Bus"/>
|
|
<node CREATED="1533688212380" ID="ID_1473874751" MODIFIED="1533688216672" TEXT="hat eine global bekannte ID"/>
|
|
<node CREATED="1533688218380" ID="ID_1933065721" MODIFIED="1533688232662" TEXT="ist ein Controller">
|
|
<node CREATED="1533688634514" ID="ID_1485276432" MODIFIED="1533688640867" TEXT="NotificationController"/>
|
|
<node CREATED="1533688235977" ID="ID_242586172" MODIFIED="1533688243228" TEXT="wird verwaltet vom Wizard"/>
|
|
<node CREATED="1533688244128" ID="ID_1500614464" MODIFIED="1533688252139" TEXT="wird von diesem an den Bus angebunden"/>
|
|
<node CREATED="1533688254935" ID="ID_1266070525" MODIFIED="1533688263201" TEXT="ist nicht notwendig sichtbar"/>
|
|
<node CREATED="1533688263837" ID="ID_132068126" MODIFIED="1533688274600" TEXT="greift sich ein delegate-Display">
|
|
<node CREATED="1533688280947" ID="ID_1196135465" MODIFIED="1533688286918" TEXT="im Infobox-Panel"/>
|
|
<node CREATED="1533688287890" ID="ID_425331660" MODIFIED="1533688294453" TEXT="alloziert per ViewLocator"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533688318950" ID="ID_995283229" MODIFIED="1533688332784" TEXT="macht bei Bedarf ein Widget sichtbar">
|
|
<node CREATED="1533688335907" ID="ID_111071026" MODIFIED="1533688351621" TEXT="vorläufig: Infobox anzeigen"/>
|
|
<node CREATED="1533688352161" ID="ID_1123594451" MODIFIED="1533688365595" TEXT="später: nur Warnlampe blinken">
|
|
<node CREATED="1533688366799" ID="ID_1664513873" MODIFIED="1533688369651" TEXT="wie in Ardour"/>
|
|
<node CREATED="1533688370311" ID="ID_395456237" MODIFIED="1533688381209" TEXT="nur bei schwerwiegenden Problemen aufploppen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533688162891" ID="ID_781003637" MODIFIED="1557498707222" TEXT="ein Kind in einen bekannten Ort pflanzen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1486520281897" FOLDED="true" ID="ID_827558797" MODIFIED="1557498707222" TEXT="Problem: zwei Inseln" VSHIFT="16">
|
|
<arrowlink COLOR="#5d6386" DESTINATION="ID_1847844548" ENDARROW="Default" ENDINCLINATION="35;-168;" ID="Arrow_ID_1483178089" STARTARROW="Default" STARTINCLINATION="-2;95;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1486520289382" ID="ID_1944158920" MODIFIED="1557498707222" TEXT="CoreService + UI-Bus"/>
|
|
<node CREATED="1486520303173" ID="ID_306583765" MODIFIED="1557498707222" TEXT="UiManager, Actions etc"/>
|
|
<node CREATED="1486521232144" HGAP="44" ID="ID_1816242514" MODIFIED="1557498707222" TEXT="Fragen" VSHIFT="16">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1486521810252" ID="ID_728134375" MODIFIED="1557498707222" TEXT="wer verkörpert den Sesison-Root?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521250790" ID="ID_447470270" MODIFIED="1557498707222" TEXT="haben wir einen globalen Controller?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521269531" ID="ID_1633937799" MODIFIED="1557498707222" TEXT="was ist das Modell des globalen Controllers?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521285069" ID="ID_410780953" MODIFIED="1557498707222" TEXT="wie hängt das mit persistentem UI-State zusammen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521317725" ID="ID_1502356505" MODIFIED="1557498707222" TEXT="welche Aktionen löst der globale Controller aus?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521369166" ID="ID_1068454326" MODIFIED="1557498707222" TEXT="wie werden die mit dem Menü verbunden?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521449835" ID="ID_236689642" MODIFIED="1557498707222" TEXT="wo hängt der InvocationStateManager?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521478792" ID="ID_235720883" MODIFIED="1557498707222" TEXT="wie redet man mit dem InvocationStateManager?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521492102" ID="ID_339608490" MODIFIED="1557498707222" TEXT="kann man Fragen via Bus stellen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521526105" ID="ID_1872187260" MODIFIED="1557498707222" TEXT="nutzen wir das Advice-System?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1486521980109" ID="ID_1036025143" MODIFIED="1557498707222" TEXT="wer beendet das UI?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1486751116251" HGAP="140" ID="ID_113005643" MODIFIED="1557498707222" VSHIFT="61">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Brücke: <i>gemeinsamer</i> Controller
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#683c5b" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-394;0;" ID="Arrow_ID_1979576517" STARTARROW="None" STARTINCLINATION="-24;-159;"/>
|
|
<node CREATED="1486751221990" ID="ID_563286868" MODIFIED="1557498707223" TEXT="ist Bindeglied für globale Aktionen"/>
|
|
<node CREATED="1486751233315" ID="ID_1611855815" MODIFIED="1557498707223" TEXT="verkörpert den Model-Root"/>
|
|
<node CREATED="1486751248097" ID="ID_1313868100" MODIFIED="1557498707223" TEXT="ist Vollmitglied am Bus"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485126481023" ID="ID_943652445" MODIFIED="1557498707223" TEXT="pro Fenster">
|
|
<node CREATED="1485126488981" ID="ID_1346100835" MODIFIED="1557498707223" TEXT="WorkspaceWindow"/>
|
|
<node CREATED="1485126494621" ID="ID_923407468" MODIFIED="1557498707223" TEXT="PanelManager"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1476376882857" HGAP="193" ID="ID_1420903777" MODIFIED="1557498707223" TEXT="Kern-Elemente" VSHIFT="-34">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1480639237820" HGAP="-42" ID="ID_138717265" MODIFIED="1557498707223" TEXT="Bausteine" VSHIFT="-11">
|
|
<node CREATED="1480639254498" ID="ID_601165955" MODIFIED="1557498707223" TEXT="Placement"/>
|
|
<node CREATED="1480639279591" ID="ID_887618627" MODIFIED="1557498707223" TEXT="Timecode"/>
|
|
<node CREATED="1480639276064" ID="ID_1418536459" MODIFIED="1557498707223" TEXT="Fader"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541089187808" FOLDED="true" ID="ID_368245484" MODIFIED="1666368514934" TEXT="ElementBoxWidget">
|
|
<linktarget COLOR="#f6cca4" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-599;39;" ID="Arrow_ID_1199047781" SOURCE="ID_1032237384" STARTARROW="None" STARTINCLINATION="-698;-271;"/>
|
|
<linktarget COLOR="#f6cca4" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-599;39;" ID="Arrow_ID_703893400" SOURCE="ID_1437927701" STARTARROW="None" STARTINCLINATION="42;-316;"/>
|
|
<linktarget COLOR="#406d5c" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-469;652;" ID="Arrow_ID_264431308" SOURCE="ID_485594461" STARTARROW="None" STARTINCLINATION="-1674;133;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1541095743511" ID="ID_96949358" MODIFIED="1661616404971" TEXT="#1185 ElementBoxWidget">
|
|
<linktarget COLOR="#541915" DESTINATION="ID_96949358" ENDARROW="Default" ENDINCLINATION="-1458;130;" ID="Arrow_ID_1319876475" SOURCE="ID_1038790770" STARTARROW="None" STARTINCLINATION="818;-68;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661616390134" ID="ID_416292634" MODIFIED="1661616398305" TEXT="#1219 draft framework for ElementBoxWidget">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1664029665088" ID="ID_1662487522" MODIFIED="1666316031015" TEXT="grundsätzlich verwendbar als Custom-Widget-Basisklasse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664029678375" ID="ID_653676253" MODIFIED="1664029703892" TEXT="Erweiterungspunkt für nach Zeit geeichter Ausdehnung vorhanden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664029710578" ID="ID_305388477" MODIFIED="1664029721290" TEXT="Erweiterungspunkt für Content-Renderer-Framework angelegt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664029748803" ID="ID_1871953284" MODIFIED="1664029762517" TEXT="Label mit Name-ID und Standard-Icon">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1664029766091" ID="ID_114718570" MODIFIED="1664029869992" TEXT="nicht notwendig....">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1664029774074" ID="ID_759551039" MODIFIED="1664029785708" TEXT="Pop-Up-Menü(s)"/>
|
|
<node CREATED="1664029786417" ID="ID_969568366" MODIFIED="1664029794056" TEXT="Integration mit Placement-Editor"/>
|
|
<node CREATED="1664029794831" ID="ID_438082684" MODIFIED="1664029806526" TEXT="Expand/Collapse-Mechanismus"/>
|
|
<node CREATED="1664029817508" ID="ID_1473132270" MODIFIED="1664029823930" TEXT="konkretes Typ-Management"/>
|
|
<node CREATED="1664029807640" ID="ID_365033048" MODIFIED="1664029816608" TEXT="konkrete Content-Renderer"/>
|
|
<node CREATED="1664029840817" ID="ID_1206826425" MODIFIED="1664029866386" TEXT="dynamic Head-Placement"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664132799979" ID="ID_1304690112" MODIFIED="1664133192469" TEXT="#1239 consider Policy Based Design for ElementBoxWidget">
|
|
<linktarget COLOR="#8d81ac" DESTINATION="ID_1304690112" ENDARROW="Default" ENDINCLINATION="654;32;" ID="Arrow_ID_1945811186" SOURCE="ID_1356714491" STARTARROW="None" STARTINCLINATION="942;-96;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1541087843514" ID="ID_1798999985" MODIFIED="1557498707223" TEXT="weit verbreiteter Grundbaustein">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1541087865477" ID="ID_1163649496" MODIFIED="1557498707223" TEXT="für Marker"/>
|
|
<node CREATED="1541087870503" ID="ID_1325112319" MODIFIED="1557498707223" TEXT="abridged Clip"/>
|
|
<node CREATED="1541087879886" ID="ID_979570785" MODIFIED="1557498707223" TEXT="Effekt-Balken"/>
|
|
<node CREATED="1541087988423" ID="ID_1910744352" MODIFIED="1557498707223" TEXT="Elemente in den Bins"/>
|
|
<node CREATED="1541088003117" ID="ID_1033651238" MODIFIED="1557498707223" TEXT="Track-Heads"/>
|
|
<node CREATED="1541088007644" ID="ID_613037557" MODIFIED="1557498707223" TEXT="Clip-Placement und Name"/>
|
|
</node>
|
|
<node CREATED="1541088033426" ID="ID_1557673770" MODIFIED="1557498707223" TEXT="besteht aus drei Komponenten">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1541088065655" ID="ID_1906795297" MODIFIED="1557498707223" TEXT="ein Icon"/>
|
|
<node CREATED="1541088069333" ID="ID_387176460" MODIFIED="1557498707223" TEXT="ein Menü-Knopf"/>
|
|
<node CREATED="1541088076739" ID="ID_1484330559" MODIFIED="1557498707223" TEXT="ein Text-Label"/>
|
|
</node>
|
|
<node CREATED="1541088109169" ID="ID_12349251" MODIFIED="1557498707223" TEXT="Eigenschaften">
|
|
<node CREATED="1541088143435" ID="ID_1434785926" MODIFIED="1557498707223" TEXT="Icon einfach vorwählbar">
|
|
<node CREATED="1541089389797" ID="ID_311117611" MODIFIED="1557498707223" TEXT="Placement"/>
|
|
<node CREATED="1541089394205" ID="ID_1611263820" MODIFIED="1557498707223" TEXT="Stock"/>
|
|
</node>
|
|
<node CREATED="1541088360999" ID="ID_1860524548" MODIFIED="1557498707223" TEXT="horizontale Ausdehnung steuerbar">
|
|
<node CREATED="1541088395516" ID="ID_122658669" MODIFIED="1576282358102" TEXT="natürlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. das Widget unternimmt selber nichts, und überläßt GTK die Größenbestimmung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1541088402105" ID="ID_857510555" MODIFIED="1576282358101" TEXT="feste Längenvorgabe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. das Text-Label bekommt ggfs. eine Längenbeschränkung.
|
|
</p>
|
|
<p>
|
|
Und sonst wird der Körper/Hintergrund ausgedehnt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_857510555" ENDARROW="Default" ENDINCLINATION="390;43;" ID="Arrow_ID_817703923" SOURCE="ID_153982067" STARTARROW="None" STARTINCLINATION="474;-38;"/>
|
|
</node>
|
|
<node CREATED="1541088480846" ID="ID_6642470" MODIFIED="1576282358101" TEXT="Kopf proportional platzierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Vorgabe ist ein Fenster(=Intervall) und dessen Position relativ zum Widget-Start.
|
|
</p>
|
|
<p>
|
|
Das Widget bestimmt daraus selbständig
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wie das Fenster relativ zu seiner eigenen Ausdehnung liegt (Logik von Intervallen ist komplex!)
|
|
</li>
|
|
<li>
|
|
ob es im Besonderen in seinem Inneren liegt, und proportional wo
|
|
</li>
|
|
<li>
|
|
und wählt dem entsprechend die Platzierung des "Kopf"-Handles (Icon+Label)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Das Resultat ist, daß der Kopf dynamisch und proportional mitrollt,
|
|
</p>
|
|
<p>
|
|
ähnlich wie das Handle einer Scrollbar. Damit bleibt der Kopf
|
|
</p>
|
|
<p>
|
|
stets zugreifbar, und gibt einen Hinweis auf die Gesamtlage.
|
|
</p>
|
|
<p>
|
|
<b>Sehr wichtig</b> für die Anzeige von <b>langen Clips</b> und Effekten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541095770851" ID="ID_1856155420" MODIFIED="1557498707223" TEXT="#1186 proportional Head placement">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541089256961" ID="ID_1928362240" MODIFIED="1557498707223" TEXT="der Body kann optoinal ein anderes Widget halten"/>
|
|
<node CREATED="1541089279788" ID="ID_798853169" MODIFIED="1557498707223" TEXT="Standard-Verdrahtung">
|
|
<node CREATED="1541089452455" ID="ID_1363384956" MODIFIED="1557498707223" TEXT="Icon == Placement">
|
|
<node CREATED="1541089459079" ID="ID_1295238871" MODIFIED="1557498707223" TEXT="Klick auf Placement"/>
|
|
<node CREATED="1541089468035" ID="ID_1760862573" MODIFIED="1557498707223" TEXT="führt in den Placement-Editor"/>
|
|
<node CREATED="1541089480558" ID="ID_562547203" MODIFIED="1557498707223" TEXT="kann Pop-Up sein, oder im Property-Grid"/>
|
|
</node>
|
|
<node CREATED="1541089502918" ID="ID_1500762782" MODIFIED="1557498707223" TEXT="nur ein (gemeinsames) Binding">
|
|
<node CREATED="1541089526108" ID="ID_1032155020" MODIFIED="1557498707223" TEXT="Signal"/>
|
|
</node>
|
|
<node CREATED="1541089531186" ID="ID_1668113871" MODIFIED="1557498707223" TEXT="zwei Bindings">
|
|
<node CREATED="1541089538704" ID="ID_454635570" MODIFIED="1557498707223" TEXT="Icon-Signal"/>
|
|
<node CREATED="1541089542345" ID="ID_1226950315" MODIFIED="1557498707223" TEXT="Arrow-Signal"/>
|
|
</node>
|
|
<node CREATED="1541089600063" ID="ID_1799506646" MODIFIED="1557498707223" TEXT="Expander mit Arrow verbunden"/>
|
|
<node CREATED="1541089613961" ID="ID_857454578" MODIFIED="1557498707223" TEXT="jedes Binding kann dürch ein Pop-Up-Menü ersetzt werden"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625072684078" FOLDED="true" ID="ID_1863177537" MODIFIED="1625072724798" TEXT="als CustomWidget realisieren">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_1863177537" ENDARROW="Default" ENDINCLINATION="-366;30;" ID="Arrow_ID_1412423566" SOURCE="ID_1875608147" STARTARROW="None" STARTINCLINATION="-2400;-277;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1624118406176" ID="ID_589554755" MODIFIED="1664836982291" TEXT="Festlegungen">
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1624118413444" FOLDED="true" ID="ID_525135958" MODIFIED="1625072535770" TEXT="Basis-Widget">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1624118429389" ID="ID_875793943" MODIFIED="1664836954095" TEXT="Ansatzpunkte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1624118435548" ID="ID_683607951" MODIFIED="1624118442679" TEXT="es ist ein Container"/>
|
|
<node CREATED="1624118448617" ID="ID_855361232" MODIFIED="1624118458532" TEXT="es funktioniert analog wie ein Gtk::Frame"/>
|
|
<node CREATED="1624118530287" ID="ID_1198328917" MODIFIED="1624118546896" TEXT="aber es hat auch Verhalten wie eine Gtk::Box"/>
|
|
<node CREATED="1624118488100" ID="ID_1709129346" MODIFIED="1624118551677" TEXT="es hat feste Kind-Elemente plus ein wählbares Content-Widget"/>
|
|
</node>
|
|
<node CREATED="1625069073522" ID="ID_1232660529" MODIFIED="1625070765303" TEXT="Möglichkeiten">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1625069082685" ID="ID_1397995115" MODIFIED="1625070771572" TEXT="Gtk::Bin">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1625069092758" ID="ID_402763047" MODIFIED="1625069101883" TEXT="abstrakte Basisklasse"/>
|
|
<node CREATED="1625069102548" ID="ID_1617772051" MODIFIED="1625069113063" TEXT="kann ein Kind-Widget halten"/>
|
|
<node CREATED="1625069113915" ID="ID_153758398" MODIFIED="1625069125077" TEXT="kann für dieses ein Label hinzufügen">
|
|
<node CREATED="1625070050530" ID="ID_903940935" MODIFIED="1625070054889" TEXT="aber nur ein textuell"/>
|
|
<node CREATED="1625070055598" ID="ID_403424864" MODIFIED="1625070058809" TEXT="oder ein Bitmap"/>
|
|
</node>
|
|
<node CREATED="1625070065123" ID="ID_1597717716" MODIFIED="1625070075262" TEXT="für alles weitere muß man sich selber in das draw() reinhängen"/>
|
|
</node>
|
|
<node CREATED="1625069187289" ID="ID_872591254" MODIFIED="1625070774327" TEXT="Gtk::Frame">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1625069192432" ID="ID_709423265" MODIFIED="1625069203664" TEXT="macht eigentlich exakt was wir brauchen"/>
|
|
<node CREATED="1625069204446" ID="ID_47523093" MODIFIED="1625069786876" TEXT="aber etwas »fest verdrahtet«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
es hat nur genau ein Label
|
|
</li>
|
|
<li>
|
|
für dieses Label kann man nur den Text angeben
|
|
</li>
|
|
<li>
|
|
auch der Frame wird praktisch "schlüsselfertig" bereitgestellt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1625069345843" ID="ID_184340763" MODIFIED="1625069366548" TEXT="aber optional kann man ein LabelWidget verwenden"/>
|
|
<node CREATED="1625069370600" ID="ID_1171321554" MODIFIED="1625069378659" TEXT="und das Alignment ist gut steuerbar">
|
|
<node CREATED="1625069794391" ID="ID_873265878" MODIFIED="1625069810266" TEXT="horizontale Position"/>
|
|
<node CREATED="1625069810952" ID="ID_1320642493" MODIFIED="1625069816840" TEXT="Label relativ zum Frame">
|
|
<node CREATED="1625069836370" ID="ID_1994693951" MODIFIED="1625069850491" TEXT="steuert indirekt ob der Frame unterbrochen wird"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1625069860086" ID="ID_190251401" MODIFIED="1625069890868" TEXT="offene Punkte">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1625069893018" ID="ID_1485806735" MODIFIED="1625069898845" TEXT="Zusammenspiel mit dem Theme">
|
|
<node CREATED="1625069902209" ID="ID_415033973" MODIFIED="1625069919149" TEXT="alle lieben den flachen Stil">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1625069931093" ID="ID_1105083016" MODIFIED="1625069942833" TEXT="es kann passieren, daß der Frame unsichtbar ist"/>
|
|
</node>
|
|
<node CREATED="1625069979972" ID="ID_426678553" MODIFIED="1625069994216" TEXT="Overlays und custom drawing"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1625070116748" ID="ID_848351976" MODIFIED="1625070768379" TEXT="Gtk::Layout">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1625070136274" ID="ID_104505251" MODIFIED="1625070160572">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt: weitgehend <i>custom drawing</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1625070617312" ID="ID_916760742" MODIFIED="1625070638385" TEXT="die komplexe Anordnung wäre leicht zu realisieren, incl Overlays"/>
|
|
<node CREATED="1625070640413" ID="ID_1387457523" MODIFIED="1625070725403" TEXT="Gefahr: höherer interner Verwaltungsaufwand">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1625070686998" ID="ID_751700152" MODIFIED="1625070725416" TEXT="Gefahr: spezieller Anzeigecode wird rasch komplex">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1625070776368" ID="ID_458451861" MODIFIED="1625070789467" TEXT="Beschluß: mit Gtk::Frame anfangen...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1625070800382" ID="ID_745380101" MODIFIED="1625070836175" TEXT="mit geschickter Parametrisierung könnte das sogar auf Dauer die Lösung sein"/>
|
|
<node CREATED="1625070967367" ID="ID_584171745" MODIFIED="1625070976257" TEXT="für den Inhalt bleiben wir flexibel">
|
|
<node CREATED="1625070978909" ID="ID_1566586463" MODIFIED="1625071001086" TEXT="Frame muß nah am Rand liegen"/>
|
|
<node CREATED="1625071002410" ID="ID_1625945732" MODIFIED="1625071018403" TEXT="...dann können wir alle Overlays per Gtk::Layout-Child handhaben"/>
|
|
<node CREATED="1625071050555" ID="ID_1277840158" MODIFIED="1625071065981" TEXT="alternativ bloß ein Gtk::Canvas (Wellenform)"/>
|
|
<node CREATED="1625071114066" ID="ID_1417509025" MODIFIED="1625071118604" TEXT="oder ein Gtk::Image"/>
|
|
<node CREATED="1625071125657" ID="ID_27403748" MODIFIED="1625071134499" TEXT="oder ein Video-Player-Widget"/>
|
|
<node CREATED="1625071135319" ID="ID_778840777" MODIFIED="1625071140731" TEXT="oder ein Gtk::TextView"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625072797631" ID="ID_841790569" MODIFIED="1666367871002" TEXT="Basis-Eigenschaften">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1625072864330" ID="ID_438468634" MODIFIED="1625072878647" TEXT="Ausdehnung fest vorgebbar">
|
|
<node CREATED="1625072881602" ID="ID_1324969264" MODIFIED="1625072892300" TEXT="muß sich dieser Vorgabe flexibel anpassen können"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073121818" ID="ID_1588690810" MODIFIED="1625073648828" TEXT="Baukasten-System">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1625073160693" ID="ID_741459865" MODIFIED="1666367854233" TEXT="Icon">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1625073209509" ID="ID_1647215892" MODIFIED="1625073216705" TEXT="Knopf mit Ein/Aus-Funktion"/>
|
|
<node CREATED="1625073252395" ID="ID_1887674930" MODIFIED="1625073270866" TEXT="Placement mit Placement-Properties"/>
|
|
<node CREATED="1625073397733" ID="ID_252893466" MODIFIED="1625073403209" TEXT="Typ-Icon"/>
|
|
<node COLOR="#435e98" CREATED="1664546626719" ID="ID_482244613" MODIFIED="1666367845862" TEXT="Varianten">
|
|
<linktarget COLOR="#5559e6" DESTINATION="ID_482244613" ENDARROW="Default" ENDINCLINATION="-920;179;" ID="Arrow_ID_1621895884" SOURCE="ID_303509395" STARTARROW="None" STARTINCLINATION="226;27;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1664546651860" ID="ID_54475262" MODIFIED="1664546667097" TEXT="das Grundmuster ist unveränderbar fixiert"/>
|
|
<node CREATED="1664546675817" ID="ID_1608209700" MODIFIED="1664546690747" TEXT="das erste Icon wird nach Presentation-Intent belegt">
|
|
<node CREATED="1664546694038" ID="ID_375518756" MODIFIED="1664546699722" TEXT="default: Placement"/>
|
|
<node CREATED="1664546700429" ID="ID_1871717245" MODIFIED="1664546714656" TEXT="Bin-Item: Typ-Icon"/>
|
|
</node>
|
|
<node CREATED="1664546716995" ID="ID_1893051713" MODIFIED="1664546729304" TEXT="das zweite Icon ist entweder ein Menü, oder ein Expander">
|
|
<node CREATED="1664546774836" ID="ID_1104234333" MODIFIED="1664548057947" TEXT="Menü == normales Kontext-Menü">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, der Menü-Button ist dann nur <i>pro forma </i>da, und bietet eine Fläche, auf der man zuverlässig dieses Menü trifft; letzteres ist relevant für eine Anzeige in Listen und Bins, bei der ansonsten die Ausdehnung des Widgets stark reduziert ist. Ein Klick auf das Name-Label hat eine andere Funktion (nämlich Editieren des Namens). Ein Weiterer Aspekt ist die Drag-Geste: es ist denkbar, diese auf dem Menü-Button <i>nicht</i> zu starten (wobei allerdings zu bedenken ist, das Ziehen auch noch an weitere Voraussetzungen zu knüpfen, z.B. einen Modifiere, oder den Umstand, daß das Objekt auch selektiert ist)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664546786666" ID="ID_418065847" MODIFIED="1664546893122" TEXT="links-Klick">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ja, wir wollen das alte Blender-Modell: Selektion mit rechts, Aktion mit links
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1664546793973" ID="ID_79262414" MODIFIED="1664546802948" TEXT="auch auf dem freien Hintergrund"/>
|
|
</node>
|
|
<node CREATED="1664546805728" ID="ID_162637423" MODIFIED="1664547883294" TEXT="Expander typischerweise für Timeline-Content">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in diesem Fall ist das dann eine Art Toggle-Button, d.h. er wechselt auch seine Gestalt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1664546823853" ID="ID_1235252109" MODIFIED="1664546831232" TEXT="dann verdrahtet mit Tangible"/>
|
|
<node CREATED="1664546831980" ID="ID_1813900014" MODIFIED="1664547929394">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das <i>verdrängt lediglich </i>das Kontext-Menü
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das Kontext-Menü soll auf dem ganzen Widget liegen (und konkurriert übrigens mit der Drag-Geste)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073420073" ID="ID_1610907627" MODIFIED="1625073651531" TEXT="Expander">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073503359" ID="ID_795687889" MODIFIED="1625073650316" TEXT="Label mit intelligentem Inhalt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1625073544225" ID="ID_714674809" MODIFIED="1625073574690" TEXT="ID-Nummer"/>
|
|
<node CREATED="1625073613360" ID="ID_881063614" MODIFIED="1625073620611" TEXT="ergänzende Beschreibung"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073654626" ID="ID_1873888723" MODIFIED="1625073685735" TEXT="Content-Schema">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073669648" ID="ID_1387633826" MODIFIED="1625073684495" TEXT="Hintergrund in Marker-Farbe">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073693037" ID="ID_800072798" MODIFIED="1625073713363" TEXT="konfigurierbarer Renderer">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073746174" ID="ID_978569677" MODIFIED="1625073749633" TEXT="Overlays">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073757173" ID="ID_1408901221" MODIFIED="1625073764844" TEXT="Resize-Ecken">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073766170" ID="ID_1361820852" MODIFIED="1625073794056" TEXT="horizontal gebundene Positions-Marker">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073626910" ID="ID_874230795" MODIFIED="1625073647305" TEXT="Kontext-Menü bereitstellen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625073639178" ID="ID_103540197" MODIFIED="1625073646355" TEXT="Verbindung zu einer Property-Box">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625075636602" ID="ID_1335603093" MODIFIED="1625075658764" TEXT="standardisierte Status-Reaktionen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1612620683850" ID="ID_1290975013" MODIFIED="1664548424931" TEXT="auszuarbeiten....">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1625075258497" ID="ID_1793264120" MODIFIED="1666367882488" TEXT="Steuerung des Darstellungs-Verhaltens">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625075337795" ID="ID_873107891" MODIFIED="1625075355499" TEXT="Analyse">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625075422300" ID="ID_1618347962" MODIFIED="1625075428886" TEXT="was ist flexibel?">
|
|
<arrowlink COLOR="#758d9c" DESTINATION="ID_1956334148" ENDARROW="Default" ENDINCLINATION="-821;-507;" ID="Arrow_ID_1964102997" STARTARROW="None" STARTINCLINATION="48;358;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1625075536956" ID="ID_1129688450" MODIFIED="1625075544135" TEXT="expanded vs collapsed"/>
|
|
<node CREATED="1625075675850" ID="ID_1669027675" MODIFIED="1625075700208" TEXT="Status-Anzeige-Elemente">
|
|
<node CREATED="1625075772886" ID="ID_181698364" MODIFIED="1625075778071" TEXT="müssen kombinierbar sein"/>
|
|
<node CREATED="1625075778875" ID="ID_888134732" MODIFIED="1625075798044" TEXT="konkret...">
|
|
<node CREATED="1625075799440" ID="ID_402285439" MODIFIED="1625075801836" TEXT="Fehler"/>
|
|
<node CREATED="1625075802531" ID="ID_1393529935" MODIFIED="1625075807091" TEXT="Warnung"/>
|
|
<node CREATED="1625075807920" ID="ID_212997652" MODIFIED="1625075819771" TEXT="Aktivität"/>
|
|
<node CREATED="1625075828060" ID="ID_193924085" MODIFIED="1625075831264" TEXT="Gesperrt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1625075575855" ID="ID_7348918" MODIFIED="1625075584153" TEXT="ScollWindowPos">
|
|
<node CREATED="1654445417792" ID="ID_503426913" MODIFIED="1654445428132" TEXT="internes Layout paßt sich an..."/>
|
|
<node CREATED="1654445429888" ID="ID_1772582519" MODIFIED="1654445484446" TEXT="Zweck: visueller Hinweis auf die ScrollWindowPos">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ScrollWindowPos == wo befindet sich das Scroll-Window (sichtbarer Ausschnitt) innerhalb eines größeren Intervalles, welches vom Widget dargestellt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625075342643" ID="ID_1177317250" MODIFIED="1625075354429" TEXT="Design-Entscheidungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1625075347837" ID="ID_1633859495" MODIFIED="1664029945723" TEXT="dynamic composition in ctor">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1664029957465" ID="ID_1547703834" MODIFIED="1664029964884" TEXT="also nicht komplett statisch/typesafe"/>
|
|
<node CREATED="1664029965728" ID="ID_420276641" MODIFIED="1664029974907" TEXT="aber einmal per Builder verdrahtet"/>
|
|
<node CREATED="1664029975919" ID="ID_1939158808" MODIFIED="1664030049366" TEXT="dynamic sanity checks">
|
|
<arrowlink COLOR="#404289" DESTINATION="ID_293134573" ENDARROW="Default" ENDINCLINATION="175;-873;" ID="Arrow_ID_1989504612" STARTARROW="None" STARTINCLINATION="768;94;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612620568330" ID="ID_1826613475" MODIFIED="1664494458140" TEXT="Problem: feste Größen-Vorgabe">
|
|
<linktarget COLOR="#6fb9c8" DESTINATION="ID_1826613475" ENDARROW="Default" ENDINCLINATION="1266;110;" ID="Arrow_ID_1550601686" SOURCE="ID_351516626" STARTARROW="None" STARTINCLINATION="2230;117;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1625072904888" ID="ID_373040535" MODIFIED="1625072974106" TEXT="paßt nicht recht in den Gtk-Standard">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn GTK geht von einer fixen Mindestgröße aus, einem Allocation-Request und dann einer Platzzuteilung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1625075098065" FOLDED="true" HGAP="75" ID="ID_740164704" MODIFIED="1663977387429" TEXT="Frage: wo muß man anpassen...." VSHIFT="-5">
|
|
<edge COLOR="#a56a6a"/>
|
|
<arrowlink COLOR="#796ba9" DESTINATION="ID_1143769023" ENDARROW="Default" ENDINCLINATION="-733;-40;" ID="Arrow_ID_1215170372" STARTARROW="None" STARTINCLINATION="-1892;158;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1663977162683" ID="ID_948579259" MODIFIED="1663977175076" TEXT="dazu muß man den Layout-Allokations-Mechanismus verstehen"/>
|
|
<node CREATED="1663977179224" ID="ID_1440569490" MODIFIED="1663977197290" TEXT="die Standard-Implementierung ist eine Kette von Aggregation und Delegation"/>
|
|
<node BACKGROUND_COLOR="#d5d1ef" COLOR="#435e98" CREATED="1663976907423" ID="ID_1507590849" MODIFIED="1663977378741" TEXT="Fazit">
|
|
<arrowlink COLOR="#6b229a" DESTINATION="ID_1503005110" ENDARROW="Default" ENDINCLINATION="-1806;-166;" ID="Arrow_ID_1347071203" STARTARROW="None" STARTINCLINATION="-2004;582;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1663976912732" ID="ID_1628642843" MODIFIED="1663976935956" TEXT="direkt bei den get_preferred-VFuncs ansetzen"/>
|
|
<node CREATED="1663976936598" ID="ID_538084170" MODIFIED="1663976947659" TEXT="Standard-Impl delegiert und aggregiert hier nur"/>
|
|
<node CREATED="1663976948910" ID="ID_665707543" MODIFIED="1663976964397" TEXT="die Basiswerte stammen aus der CSS-Auswertung"/>
|
|
<node CREATED="1663976973787" ID="ID_1501027418" MODIFIED="1663977503034" TEXT="also drei Schritte">
|
|
<arrowlink COLOR="#505398" DESTINATION="ID_763928282" ENDARROW="Default" ENDINCLINATION="-708;-358;" ID="Arrow_ID_1762163985" STARTARROW="None" STARTINCLINATION="-29;281;"/>
|
|
<node CREATED="1663976978882" ID="ID_1756884177" MODIFIED="1663977086920" TEXT="Basis-Impl aufrufen ⟹ holt Standard-Layout von CSS">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1663976986201" ID="ID_280056674" MODIFIED="1663977065627" TEXT="Abgleich, Manipulation, Ausblenden ⟹ bis Constraint erfüllt">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1663977014990" ID="ID_696754346" MODIFIED="1663977067787" TEXT="dann schließlich den vordefinierten Size-Constraint zurückliefern">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661557586218" FOLDED="true" ID="ID_859822896" MODIFIED="1666367808161" TEXT="Zeitangabe in Ausdehnung umsetzen">
|
|
<arrowlink COLOR="#7479c0" DESTINATION="ID_1343110314" ENDARROW="Default" ENDINCLINATION="-766;-1697;" ID="Arrow_ID_712594873" STARTARROW="None" STARTINCLINATION="520;37;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1661557875471" ID="ID_339780782" MODIFIED="1666367752575" TEXT="API im CanvasHook">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1661557894284" ID="ID_58216896" MODIFIED="1661557909598" TEXT="⟹ dann müßte es hookable sein..."/>
|
|
<node COLOR="#435e98" CREATED="1661557910685" ID="ID_709773431" MODIFIED="1666367524129" TEXT="Alternativen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666367514311" ID="ID_1178111441" MODIFIED="1666367521823" TEXT="generisches API einführen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1666367490994" ID="ID_636187892" MODIFIED="1666367724504" TEXT="Pull per λ">
|
|
<linktarget COLOR="#4e4fc1" DESTINATION="ID_636187892" ENDARROW="Default" ENDINCLINATION="-34;579;" ID="Arrow_ID_1572846735" SOURCE="ID_1159408504" STARTARROW="None" STARTINCLINATION="61;-374;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1666367543907" ID="ID_859364136" LINK="#ID_953567994" MODIFIED="1666367732555" TEXT="proof-of-Concept: ClipWidget"/>
|
|
<node COLOR="#435e98" CREATED="1666367735326" ID="ID_148248231" MODIFIED="1666367745247" TEXT="Lösung sieht sauber aus">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1661557959964" HGAP="149" ID="ID_1683748982" MODIFIED="1666367798594" TEXT="Wann/wozu?" VSHIFT="2">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1661558025450" ID="ID_153982067" MODIFIED="1661558059696" TEXT="im Modus "feste Längenvorgabe"">
|
|
<arrowlink DESTINATION="ID_857510555" ENDARROW="Default" ENDINCLINATION="390;43;" ID="Arrow_ID_817703923" STARTARROW="None" STARTINCLINATION="474;-38;"/>
|
|
</node>
|
|
<node CREATED="1666367765333" ID="ID_1429653928" MODIFIED="1666367779043" TEXT="anpassen nach jeder Zoom-Änderung"/>
|
|
<node CREATED="1666367783710" ID="ID_1991615628" MODIFIED="1666367796499" TEXT="ggfs auch Vorgaben zur Höhe vorsehen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1625075206250" ID="ID_721261085" MODIFIED="1625075212634" TEXT="Strukturen aufbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1625075275103" ID="ID_1622786444" MODIFIED="1664836999132" TEXT="Konstruktor">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1625075282830" ID="ID_1730704998" MODIFIED="1664494473359" TEXT="mini-DSL für die Konfigurations-Varianten schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1654445954424" FOLDED="true" ID="ID_1720484280" MODIFIED="1661558650010" TEXT="1.Ansatz: explizit">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1654445618173" ID="ID_1315147546" MODIFIED="1654445654111" TEXT="Icon per vordefinierter Spec">
|
|
<node CREATED="1654445665127" ID="ID_579106767" MODIFIED="1654445667994" TEXT="TOGGLE"/>
|
|
<node CREATED="1654445668679" ID="ID_459682437" MODIFIED="1654445672029" TEXT="PLACEMENT"/>
|
|
<node CREATED="1654445697299" ID="ID_1904059530" MODIFIED="1654445701143" TEXT="TYPE_VIDEO"/>
|
|
<node CREATED="1654445702115" ID="ID_910973152" MODIFIED="1654445719157" TEXT="TYPE_AUDIO"/>
|
|
<node CREATED="1654445720120" ID="ID_929230990" MODIFIED="1654445722442" TEXT="....">
|
|
<node CREATED="1654445723463" ID="ID_1294993319" MODIFIED="1654445734936" TEXT="hier bewußt "flach" anfangen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654445976060" ID="ID_245045599" MODIFIED="1654446070433" TEXT="Expander"/>
|
|
<node CREATED="1654446071737" ID="ID_1388489184" MODIFIED="1654446081995" TEXT="Menu einbinden"/>
|
|
<node CREATED="1654446105991" ID="ID_1589646798" MODIFIED="1654446111272" TEXT="Placement einbinden">
|
|
<node CREATED="1654446112410" ID="ID_1144219107" MODIFIED="1654446126479" TEXT="Frage: wie referenziert?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654446135374" ID="ID_1745476469" MODIFIED="1654446169327" TEXT="Content">
|
|
<node CREATED="1654446170127" ID="ID_161101124" MODIFIED="1654446175702" TEXT="Hintergrundfarbe"/>
|
|
<node CREATED="1654446176506" ID="ID_1198030114" MODIFIED="1654446183237" TEXT="speziellen Renderer einbinden"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654447175801" FOLDED="true" ID="ID_130925250" MODIFIED="1661558654675" TEXT="2.Ansatz: intentional">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1654447205213" ID="ID_360701766" MODIFIED="1654447213879" TEXT="man gibt einen Präsentationsstil vor"/>
|
|
<node CREATED="1654447241576" ID="ID_17226608" MODIFIED="1654447262732" TEXT="sowie einen Typ und einen Inhalts-Stil"/>
|
|
<node CREATED="1654447896151" ID="ID_1043723877" MODIFIED="1654447900359" TEXT="Schema">
|
|
<node CREATED="1654447901661" ID="ID_988465077" MODIFIED="1654448124509" TEXT="Kind">
|
|
<node CREATED="1654447908464" ID="ID_1051744069" MODIFIED="1654447973665" TEXT="MARK">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein Marker, ein Pin, Position,....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1654447915277" ID="ID_605454519" MODIFIED="1654448000114" TEXT="SPAN">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
repräsentiert einen benannten Zeit-Bereich:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Range-Mark
|
|
</li>
|
|
<li>
|
|
Effekt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1654447918320" ID="ID_518830573" MODIFIED="1654448078388" TEXT="ITEM">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Eintrag in einer Liste oder Asset in einer Sammlung;
|
|
</p>
|
|
<p>
|
|
hier erfolgt Präsentation nach <i>natürlicher Größe</i>, ggfs mit Längenbeschränkung...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1654447921187" ID="ID_513954235" MODIFIED="1654448113829" TEXT="CONTENT">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ein Mini-Container mit Placement, Name und einem Inhalts-Renderer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654448125537" ID="ID_1395529796" MODIFIED="1654448128455" TEXT="Type">
|
|
<node CREATED="1654448130558" ID="ID_1241445967" MODIFIED="1654448134530" TEXT="Art des Objekts">
|
|
<node CREATED="1654448141757" ID="ID_950634267" MODIFIED="1654448144148" TEXT="VIDEO"/>
|
|
<node CREATED="1654448145019" ID="ID_1438778701" MODIFIED="1654448147368" TEXT="AUDIO"/>
|
|
<node CREATED="1654448148172" ID="ID_619152561" MODIFIED="1654448153007" TEXT="EFFECT"/>
|
|
<node CREATED="1654448154480" ID="ID_1428501909" MODIFIED="1654448287941" TEXT="LABEL">
|
|
<node CREATED="1654448495868" ID="ID_278262506" MODIFIED="1662037668001" TEXT="oder MARKER?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Terminologie nicht klar...
|
|
</p>
|
|
<p>
|
|
...was hab ich bei den Kind-Elementen vom Track gemacht?
|
|
</p>
|
|
<p>
|
|
⟹ die heißen auch »Marker«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1661896412054" ID="ID_1438729609" MODIFIED="1662037625910" TEXT=""Marker" drückt den Intent besser aus">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1662037631505" ID="ID_242913609" MODIFIED="1662037676913" TEXT="Aber das Objekt ist besser als »Label« beschrieben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654448789732" ID="ID_816398160" MODIFIED="1654450396327" TEXT="RULER">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1654448804617" ID="ID_1155659692" MODIFIED="1654448839461" TEXT="dient nur zur Dartellung von Bereichen + Marken"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1654450398063" ID="ID_1951922896" MODIFIED="1654450407871" TEXT="Relevanz noch nicht klar">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654449069944" ID="ID_1055078998" MODIFIED="1654449100179" TEXT="GROUP">
|
|
<node CREATED="1654449075116" ID="ID_1577967123" MODIFIED="1654449097158" TEXT="ein Element das andere Elemente stukturiert"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654448849843" ID="ID_1484299794" MODIFIED="1654448862165" TEXT="impliziert ein Standard-Layout">
|
|
<node CREATED="1654448872908" ID="ID_257526761" MODIFIED="1654448894394" TEXT="VIDEO / AUDIO : Placement und Content"/>
|
|
<node CREATED="1654448969802" ID="ID_1936666898" MODIFIED="1654448981191" TEXT="EFFECT: Placement aber kein Content"/>
|
|
<node CREATED="1654449021075" ID="ID_1709293733" MODIFIED="1654449037283" TEXT="LABEL: es geht nur um den Namen"/>
|
|
<node CREATED="1654449123375" ID="ID_167073471" MODIFIED="1654449138312" TEXT="RULER: hier wird ein oder mehrere (Zeit)Bereiche markiert"/>
|
|
<node CREATED="1654449140080" ID="ID_785172025" MODIFIED="1654449151119" TEXT="GROUP: Placement + Grid-Content"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654449181597" ID="ID_1379040287" MODIFIED="1654449618220" TEXT="Qualifier">
|
|
<node CREATED="1654449673650" ID="ID_1156591730" MODIFIED="1654449696235" TEXT="Wunsch: offene Ergänzung mit weiteren Parametern"/>
|
|
<node CREATED="1654449697703" ID="ID_1842181934" MODIFIED="1661721298137" TEXT="analog zu algebraischen Datentypen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1654449709778" ID="ID_1842345806" MODIFIED="1654449715002" TEXT="prädikat-artiger Term"/>
|
|
<node CREATED="1654449716467" ID="ID_1816176358" MODIFIED="1654449724831" TEXT="aber mit Compile-Time safety"/>
|
|
<node COLOR="#435e98" CREATED="1661640883263" ID="ID_606322224" MODIFIED="1661721271303" TEXT="ist das möglich?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Ja,</i> und zwar sogar ziemlich <i>einfach und lesbar...</i> 
|
|
</p>
|
|
<p>
|
|
auch wenn ich mal wieder einen ganzen Tag gebraucht habe, um diese paar Zeilen Code auszuknobeln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1661640991591" ID="ID_1210145081" MODIFIED="1661641017079" TEXT="Idee: Funktor auf einen Konfiguration-Record anwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661641024133" ID="ID_610957557" MODIFIED="1661721177675" TEXT="in eine Library-Implementierung verpacken (mix-in)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661721182726" ID="ID_1592354346" MODIFIED="1661721188107" TEXT="Dest / Demo">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661721308152" ID="ID_1192772963" MODIFIED="1661721429475" TEXT="Konsequenz: brauche eine build()-Funktion zur Validation">
|
|
<arrowlink COLOR="#c63166" DESTINATION="ID_293134573" ENDARROW="Default" ENDINCLINATION="64;-83;" ID="Arrow_ID_543159170" STARTARROW="None" STARTINCLINATION="-313;15;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1661721330773" ID="ID_335266282" MODIFIED="1661721341869" TEXT="denn dieses Konzept wenden die Funktoren blindlings an"/>
|
|
<node CREATED="1661721342572" ID="ID_1569355841" MODIFIED="1661721355870" TEXT="es muß dann eigens geprüft werden, ob diese Einstellungen konsistent sind"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1654449966426" ID="ID_100214768" MODIFIED="1654449972509" TEXT="Zweck">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1654450318381" ID="ID_350844868" MODIFIED="1654450326861" TEXT="Detail-Differenzierungen durchreichen"/>
|
|
<node CREATED="1654450327871" ID="ID_210552013" MODIFIED="1654450333640" TEXT="spezielleres Icon"/>
|
|
<node CREATED="1654450336155" ID="ID_949035541" MODIFIED="1654450342340" TEXT="Varianten beim Binding"/>
|
|
<node CREATED="1654450361629" ID="ID_876813319" MODIFIED="1654450385555" TEXT="Puffer für spätere Ergänzungen und Weiterentwicklung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1625075301830" FOLDED="true" ID="ID_792792003" MODIFIED="1679088238251" TEXT="Möglichkeiten vordefinierter Ausstattung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1661721385054" ID="ID_229098374" MODIFIED="1664837009375" TEXT="Framework anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1661721522872" ID="ID_1721632208" MODIFIED="1662051074564" TEXT="ENUMs">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661721389797" ID="ID_96735997" MODIFIED="1662051077177" TEXT="Qualifier">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661721393893" ID="ID_293134573" MODIFIED="1664837010799" TEXT="Validierungs-Funktion">
|
|
<linktarget COLOR="#404289" DESTINATION="ID_293134573" ENDARROW="Default" ENDINCLINATION="175;-873;" ID="Arrow_ID_1989504612" SOURCE="ID_1939158808" STARTARROW="None" STARTINCLINATION="768;94;"/>
|
|
<linktarget COLOR="#c63166" DESTINATION="ID_293134573" ENDARROW="Default" ENDINCLINATION="64;-83;" ID="Arrow_ID_543159170" SOURCE="ID_1192772963" STARTARROW="None" STARTINCLINATION="-313;15;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1662051084085" ID="ID_906734828" MODIFIED="1664668205361">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced">ElementBoxWidget::Config::<b>buildLayoutStrategy</b>(</font><font color="#2d40af" face="Monospaced">ElementBoxWidget</font><font face="Monospaced">&)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664837017382" ID="ID_1774424476" MODIFIED="1664837035511" TEXT="hier Entscheidung über den Layout-Typ">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661896735138" ID="ID_1956334148" MODIFIED="1679088230561" TEXT="Darstellungs-Varianten">
|
|
<linktarget COLOR="#758d9c" DESTINATION="ID_1956334148" ENDARROW="Default" ENDINCLINATION="-821;-507;" ID="Arrow_ID_1964102997" SOURCE="ID_1618347962" STARTARROW="None" STARTINCLINATION="48;358;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1661897283192" ID="ID_981716930" MODIFIED="1661897305658" TEXT="natural-size vs. time-extension">
|
|
<node CREATED="1661897836550" ID="ID_855148084" MODIFIED="1661897851456" TEXT="Standard-Breite + Platz gemäß Label"/>
|
|
<node CREATED="1661897852332" ID="ID_1972489184" MODIFIED="1661897874317" TEXT="nimmt eine bestimmte, geeichte Länge ein"/>
|
|
</node>
|
|
<node CREATED="1661897434780" ID="ID_527434032" MODIFIED="1661897445710" TEXT="ruler vs. content">
|
|
<node CREATED="1661897884248" ID="ID_123509205" MODIFIED="1661897894398" TEXT="nur ein Balken, auf dem das Label platziert ist"/>
|
|
<node CREATED="1661897895098" ID="ID_730907328" MODIFIED="1661897906945" TEXT="oder ein Container mit Inhalts-Darstellung"/>
|
|
</node>
|
|
<node CREATED="1661897677379" ID="ID_1139847619" MODIFIED="1661897684638" TEXT="Placement vs Type-Icon">
|
|
<node CREATED="1661897909029" ID="ID_1339555856" MODIFIED="1661897948418" TEXT="Placement-UI; Menü per Rechts-click auf den Content"/>
|
|
<node CREATED="1661897950823" ID="ID_307552216" MODIFIED="1661898035463" TEXT="Type-Icon öffnet Menü"/>
|
|
</node>
|
|
<node CREATED="1661897791060" ID="ID_745130106" MODIFIED="1661897799999" TEXT="Expander vs Details">
|
|
<node CREATED="1661898047850" ID="ID_655139501" MODIFIED="1661898068517" TEXT="Expander auf/ab klappt Anzeige auf"/>
|
|
<node CREATED="1661898071047" ID="ID_1263290203" MODIFIED="1661898088744" TEXT="Detail-Pfeil öffnet Property-Box"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1662074862784" ID="ID_1262449587" MODIFIED="1662074946153" TEXT="Support für CSS-styling">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1662074874623" ID="ID_89564608" MODIFIED="1662074885181" TEXT="verwende den Gtk-Inspector">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1662074886207" ID="ID_1586325013" MODIFIED="1662074920204" TEXT="Klasse .background ⟹ Hintergrund undurchsichtig"/>
|
|
<node CREATED="1662074921529" ID="ID_1811056856" MODIFIED="1662074940890" TEXT="Widgets benennen ⟹ im CSS als #name (ID) ansprechbar"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666316047026" ID="ID_1796374049" MODIFIED="1679088250326" TEXT="Widget-Struktur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1666316060213" ID="ID_1152183779" MODIFIED="1666316068920" TEXT="verwendet ein Sub-Widget als Label">
|
|
<node CREATED="1666316070268" ID="ID_695985659" MODIFIED="1666316075503" TEXT="class IDLabel"/>
|
|
<node CREATED="1666316078131" ID="ID_1171906205" MODIFIED="1666316092903" TEXT="dieses bildet die charakteristische Triple-Struktur">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666316099067" ID="ID_781968330" MODIFIED="1666316117414" TEXT="Funktionalität zur Anpassung an size-constraint">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666316122109" ID="ID_1084456020" MODIFIED="1666366890443" TEXT="erzeugt einen undurchsichtigen Hintergrund">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1666316168044" ID="ID_875996468" MODIFIED="1666366863733" TEXT="Lösung: CSS-Klasse .background">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666317118953" ID="ID_204505026" MODIFIED="1666366866847" TEXT="Lösung: Styling auf der (sichtbaren) EventBox">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665969462522" ID="ID_1425589285" MODIFIED="1666368691150" TEXT="Medien-Typ in CSS-Styles umsetzen">
|
|
<arrowlink COLOR="#b46465" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-539;-35;" ID="Arrow_ID_742470916" STARTARROW="None" STARTINCLINATION="-274;362;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666316190604" ID="ID_519294969" MODIFIED="1666366924396" TEXT="packt Content in eine Gtk::EventBox">
|
|
<linktarget COLOR="#526674" DESTINATION="ID_519294969" ENDARROW="Default" ENDINCLINATION="1268;576;" ID="Arrow_ID_860609088" SOURCE="ID_387720838" STARTARROW="None" STARTINCLINATION="-1409;-62;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1666316757672" ID="ID_869966472" MODIFIED="1666366920557" TEXT="verwendet ein sichtbares GdkWindow behind_child">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1666316737650" ID="ID_354756036" MODIFIED="1666366917942" TEXT="schafft Möglichkeit, den Hintergrund einzufärben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1666316803445" ID="ID_431972258" MODIFIED="1666366907656" TEXT="dient als Parent-Window für Widgets mit eigenem Window">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666316815184" ID="ID_1495596367" MODIFIED="1666366904297" TEXT="damit normale Event-Propagierung möglich">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666316924338" ID="ID_492711320" MODIFIED="1666316935588" TEXT="Anordnung">
|
|
<node COLOR="#338800" CREATED="1666316936962" ID="ID_1057903927" MODIFIED="1666366928981" TEXT="erbt direkt von Gtk::EventBox">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1666316958230" ID="ID_1048866675" MODIFIED="1666316981759" TEXT="damit ist die Event-Verdrahtung für abgeleitete Klassen sichtbar"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666316984594" ID="ID_1504629263" MODIFIED="1666366930475" TEXT="verwendet Gtk::Frame als Kind">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666316993672" ID="ID_827533347" MODIFIED="1666317106925" TEXT="Child-handling-API weiterleiten">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1666317058231" ID="ID_217426878" MODIFIED="1666317080067" TEXT="damit es sich wie ein Container verhält..."/>
|
|
<node CREATED="1666317080989" ID="ID_1257628334" MODIFIED="1666317104078" TEXT="dieses Verhalten aber an den Inhalt vom Gtk::Frame weitergibt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1662051984940" ID="ID_974876977" MODIFIED="1662051988957" TEXT="Icon verwalten">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1662051990492" ID="ID_264004203" MODIFIED="1662052527424" TEXT="Verwaltung vordefinierter Icons">
|
|
<arrowlink COLOR="#b73b74" DESTINATION="ID_1998357180" ENDARROW="Default" ENDINCLINATION="-1444;146;" ID="Arrow_ID_373354654" STARTARROW="None" STARTINCLINATION="-586;-482;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1662247852505" ID="ID_685267801" MODIFIED="1662247866746" TEXT="wird relevant mit Gtk-4">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1662247868126" ID="ID_487747089" MODIFIED="1662247880210" TEXT="vorerst möglichst das bestehende System nutzen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#210f69" CREATED="1664548449268" ID="ID_303509395" MODIFIED="1664548735480" TEXT="Design-Prinzipien">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
festes Schema aus zwei Icons
|
|
</li>
|
|
<li>
|
|
nur die Art der Icons wird ausgewechselt
|
|
</li>
|
|
<li>
|
|
beide Icons sind Buttons und lösen führen eine Steuer-Aktion aus (keine direkte Manipulation)
|
|
</li>
|
|
<li>
|
|
der erste Button führt immer in den Placement-Editor, der so etwas wie eine Property-Box darstellt (ggfs als Pop-Up, ggfs in einem Pannel-Grid)
|
|
</li>
|
|
<li>
|
|
der zweite Button öffnet entweder das normale Pop-up-Menü (das auf <b>Linksklick</b> liegt), oder er betätigt den Expander
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5559e6" DESTINATION="ID_482244613" ENDARROW="Default" ENDINCLINATION="-920;179;" ID="Arrow_ID_1621895884" STARTARROW="None" STARTINCLINATION="226;27;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664548762473" ID="ID_1889891499" MODIFIED="1664548771120" TEXT="Icons belegen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1664548773656" ID="ID_1911341239" MODIFIED="1664553930837" TEXT="Möglichkeit für zwei Icon-Button vorsehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664548786932" ID="ID_1354120525" MODIFIED="1664553936475" TEXT="Konfigurierbarkeit gewährleisten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1662241779699" ID="ID_178231784" MODIFIED="1665855497333" TEXT="#1236 Placement-Icon">
|
|
<linktarget COLOR="#6681be" DESTINATION="ID_178231784" ENDARROW="Default" ENDINCLINATION="-1422;-171;" ID="Arrow_ID_287037902" SOURCE="ID_1904965684" STARTARROW="None" STARTINCLINATION="626;53;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1662241785372" ID="ID_1501125340" MODIFIED="1665855504959" TEXT="Menü/Expander-Icon">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1665855546746" ID="ID_1649379892" MODIFIED="1665855568834" TEXT="sieht vorerst ordentlich aus"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665855569555" ID="ID_1045883941" MODIFIED="1665855630056" TEXT="ist aber vielleicht etwas zu hell geraten">
|
|
<arrowlink COLOR="#f27d99" DESTINATION="ID_446507732" ENDARROW="Default" ENDINCLINATION="356;501;" ID="Arrow_ID_1734621230" STARTARROW="None" STARTINCLINATION="225;17;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1666367000884" ID="ID_1552390941" MODIFIED="1666367099475" TEXT="sieht mehr wie ein "play"-Button aus...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist vielleicht sogar eine gute Idee: Lumiera könnte die Möglichkeit bieten, jedwedes Element eigens für sich darzustellen oder zu inspizieren, transient und ohne Seiteneffekte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1662241925929" ID="ID_217944947" MODIFIED="1664136727535" TEXT="horizontale Ausdehnung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1663945598778" ID="ID_1866891133" MODIFIED="1663945862337" TEXT="Ansatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1663945603065" ID="ID_1792803134" MODIFIED="1663945629088" TEXT="Mechanismus zur Größenbeschränkung auf dem Haupt-Widget"/>
|
|
<node CREATED="1663945637397" ID="ID_1469516364" MODIFIED="1663945650908" TEXT="erforderliche Ausdehnung der Kind-Elemente feststellen"/>
|
|
<node CREATED="1663945651910" ID="ID_897434501" MODIFIED="1663945668859" TEXT="Kind-Elemente ggfs verbergen"/>
|
|
<node CREATED="1663945669814" ID="ID_1057659827" MODIFIED="1663945692748">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
veränderte Menü-Steuerung bei derartiger <i>Degradierung</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1663945712608" ID="ID_1162263503" MODIFIED="1663945819361" TEXT="minimal-Ausdehung per API bereitstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das bedeutet: es ist Aufgabe eines übergeordneten Layout-Managers, dann auch ein <i>reduziertes Display</i> zu schalten; das ElementBoxWidget kann davon ausgehen, den minimal benötigten Platz auch zu bekommen (size request)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1663977435805" FOLDED="true" ID="ID_763928282" MODIFIED="1666370194656" TEXT="Lösungs-Mechanismus GTK+CSS">
|
|
<linktarget COLOR="#505398" DESTINATION="ID_763928282" ENDARROW="Default" ENDINCLINATION="-708;-358;" ID="Arrow_ID_1762163985" SOURCE="ID_1501027418" STARTARROW="None" STARTINCLINATION="-29;281;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664036044208" ID="ID_1165985409" MODIFIED="1666369956106" TEXT="#1235 draft solution for size-constrained widgets">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664486479334" ID="ID_1175352945" MODIFIED="1666369958878" TEXT="Fazit: Widget liefert den Constraint als minimal und als natural request">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664486499547" ID="ID_1517909946" MODIFIED="1664486599158" TEXT="CSS muß dafür sorgen, daß dem nichts hinzugefügt wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Besonderen keine Border!
|
|
</p>
|
|
<p>
|
|
Das ist auch genau ein Argument, warum wir auf Gtk::Frame aufsetzen — damit ist der Frame nämlich ins <i>Innere des Widget</i> verlagert, und das Label liegt on-top und grenzt an den Rand an.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1664668298178" ID="ID_1102642211" LINK="#ID_1853406335" MODIFIED="1664674552382" TEXT="geeignete Selektoren vorsehen">
|
|
<arrowlink COLOR="#543f8c" DESTINATION="ID_696787535" ENDARROW="Default" ENDINCLINATION="-344;-15;" ID="Arrow_ID_1626542451" STARTARROW="None" STARTINCLINATION="560;45;"/>
|
|
<arrowlink COLOR="#4482cb" DESTINATION="ID_1131035647" ENDARROW="Default" ENDINCLINATION="1109;-797;" ID="Arrow_ID_860130995" STARTARROW="None" STARTINCLINATION="394;586;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#4f4398" CREATED="1666370148380" ID="ID_910686792" LINK="#ID_1266679575" MODIFIED="1666370185149" TEXT="Lösung funktioniert im Prototyp">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664027101386" FOLDED="true" ID="ID_325165287" MODIFIED="1664494902370" TEXT="erforderliche Ausdehnung feststellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1664027121220" ID="ID_1123910943" MODIFIED="1664027234710" TEXT="für das ElementBoxWidget stets in Pixel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist eine Design/Architektur-Entscheidung; ein generisches Widget soll noch nicht mit dem speziellen Belang einer Eichung in Zeiteinheiten belastet werden; dies hat dann jeweils ins abgeleiteten Klassen zu erfolgen, so z.B im Clip-Widget
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664027274328" ID="ID_1533967380" MODIFIED="1664494894900" TEXT="Interaktionsmuster der Schnittstelle">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1664027342687" FOLDED="true" ID="ID_987588934" MODIFIED="1664494887246" TEXT="Analyse">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1664027374909" ID="ID_1916479707" MODIFIED="1664027563708" TEXT="Information wird von den GTK-Callbacks benötigt">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664027389923" FOLDED="true" ID="ID_1208852991" MODIFIED="1664494880330" TEXT="sie ist also berets zur Initialisierung (oder kurz danach) erforderlich">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1664027420141" ID="ID_217473035" MODIFIED="1664494566272" TEXT="wann und wie werden die Callbacks aufgerufen?">
|
|
<linktarget COLOR="#4285bf" DESTINATION="ID_217473035" ENDARROW="Default" ENDINCLINATION="-989;57;" ID="Arrow_ID_1041626932" SOURCE="ID_945958753" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1664027451687" ID="ID_26942945" MODIFIED="1664027457671" TEXT="Vermutung...">
|
|
<node CREATED="1664027458520" ID="ID_53350409" MODIFIED="1664027468099" TEXT="aus dem Event-Handling"/>
|
|
<node CREATED="1664027505881" ID="ID_102723884" MODIFIED="1664027518260" TEXT="als Folge einer "invalidation""/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664027526879" ID="ID_849843415" MODIFIED="1664494543169" TEXT="an der konkreten Implementierung beobachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1664152872453" ID="ID_1559151133" MODIFIED="1664152874424" TEXT="korrekt"/>
|
|
<node CREATED="1664152875229" ID="ID_1591242265" MODIFIED="1664152886391" TEXT="definitiv aus der Event-Loop"/>
|
|
<node CREATED="1664152887076" ID="ID_1667743717" MODIFIED="1664152893950" TEXT="und nicht aus dem Widget-ctor"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664494523077" ID="ID_509196294" MODIFIED="1664494548030" TEXT="die Implementierung der GTK Layout-Engine stellt das sicher">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664494602946" ID="ID_1093994466" MODIFIED="1664494618443" TEXT="zum "mapping" des Widgets wird die size-Allocation ermittelt"/>
|
|
<node CREATED="1664494619248" ID="ID_1432947442" MODIFIED="1664494782463" TEXT="hierfür gibt es nur wenige Standard-Implementierungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die wichtigste Implementierung ist in <b>gtk_widget_size_allocate_with_baseline</b>; sie wird von fast allen Containern verwendet, um ihre Kinder zu allozieren
|
|
</li>
|
|
<li>
|
|
top-level Windows, Dialogboxen und Menu-Items verwenden ihre eigene Implementierung
|
|
</li>
|
|
<li>
|
|
Gtk::Layout hat ebenfalls eine vereinfachte Variante: diese geht von dem <b>minimal_size</b> des Widgets aus!
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664494784130" ID="ID_710050245" MODIFIED="1664494808538" TEXT="Alle diese werden nach dem ctor aber vor dem ersten "draw" aufgerufen"/>
|
|
<node CREATED="1664494810334" ID="ID_1899633587" MODIFIED="1664494830787" TEXT="außerdem werden sie bei jedem Fokus-Wechsel aufgerufen"/>
|
|
<node CREATED="1664494863383" ID="ID_402498612" MODIFIED="1664494874185" TEXT="danach erfolgt ein set_allocation"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664027626370" ID="ID_244953029" MODIFIED="1664027646110" TEXT="eine falsche Angabe führt zu (vorübergehend) falschem Layout"/>
|
|
<node CREATED="1664027651294" ID="ID_1669994961" MODIFIED="1664028901505" TEXT="»push« bedeutet...">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1664027665253" ID="ID_940658024" MODIFIED="1664027681994" TEXT="das API ist einfach und die Verwendung natürlich"/>
|
|
<node CREATED="1664027684394" ID="ID_220726069" MODIFIED="1664027717150" TEXT="der Nutzer muß sich an ein Protokoll halten"/>
|
|
<node CREATED="1664027718941" ID="ID_319058319" MODIFIED="1664027737327" TEXT="falls die Info schon im ctor notwendig ist..."/>
|
|
<node CREATED="1664027738275" ID="ID_1665189390" MODIFIED="1664027747373" TEXT="...dann braucht man zwei verschiedene APIs">
|
|
<node CREATED="1664027751780" ID="ID_57107088" MODIFIED="1664027759172" TEXT="Initiale Spec"/>
|
|
<node CREATED="1664027760042" ID="ID_296144190" MODIFIED="1664027767514" TEXT="Setter für spätere Änderung"/>
|
|
</node>
|
|
<node CREATED="1664027848116" ID="ID_1337478070" MODIFIED="1664027863406" TEXT="invalidation / redraw ergeben sich nebenbei (im Setter)"/>
|
|
</node>
|
|
<node CREATED="1664027866247" ID="ID_981182676" MODIFIED="1664028904533" TEXT="»pull« bedeutet...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1664027887399" ID="ID_1658293889" MODIFIED="1664027910527" TEXT="der Nutzer muß zwei Getter-λ bereitstellen"/>
|
|
<node CREATED="1664027980946" ID="ID_1814840612" MODIFIED="1664028017505" TEXT="diese sind aber nur notwendig, falls constrained extension gewünscht"/>
|
|
<node CREATED="1664028024900" ID="ID_1409117153" MODIFIED="1664028235700" TEXT="dieses komplexe API könnte durch die ctor-DSL verständlich gemacht werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern dann die Beschränkung der Ausdehnung einzig dadurch aktiviert werden kann, daß man ein geeignetes Verb angibt, welches diese beiden Lambda als Argument nimmt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664028265740" ID="ID_414167652" MODIFIED="1664028312456" TEXT="der Zugriff erfolgt natürlich, transparent und on-demand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und ich muß die Frage, wann genau diese Info bezogen wird, überhaupt nicht klären
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664028318861" ID="ID_1910143460" MODIFIED="1664028491553" TEXT="jede Metrik-Änderung muß dem Widget über ein separates API eigens gePUSHt werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wobei letztlich nur ein queue_resize erfolgen muß; es könnte also sein, daß dafür der Aufruf einer bestehenden GTK-Funktion genügt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664028417616" ID="ID_743592439" MODIFIED="1664028542302" TEXT="idealerweise läßt sich das jedoch über den Parent-Container automatisieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...unter der Annahme, daß letzlich eine "invalidation" des Widgets genügt, ließe sich das elegant lösen, indem der Canvas-Container insgesamt "invalidated" wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1664028546726" ID="ID_1159408504" MODIFIED="1664028775997" TEXT="Enscheidung: »pull«-API">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
In Summe viel eleganter.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
das Dokumentations-Problem wird durch die DSL gelöst
|
|
</li>
|
|
<li>
|
|
die "Invalidation" sollte sich aus dem Parent-Container ergeben
|
|
</li>
|
|
<li>
|
|
damit bleiben hier praktisch keine Probleme mehr übrig
|
|
</li>
|
|
<li>
|
|
Redundanz im DSL-API ist nicht wirklich ein Problem; Kind=CONTENT impliziert nicht notwendig auch ein geeichtes Display
|
|
</li>
|
|
<li>
|
|
ansonsten sollte dieser Ansatz komplett transparent funktionieren, und dürfte weniger fragil sein
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#4e4fc1" DESTINATION="ID_636187892" ENDARROW="Default" ENDINCLINATION="-34;579;" ID="Arrow_ID_1572846735" STARTARROW="None" STARTINCLINATION="61;-374;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664028782841" ID="ID_1596292708" MODIFIED="1664152807960" TEXT="Implementierung der Schnittstelle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664028797404" ID="ID_1421736344" MODIFIED="1664152806643" TEXT="die λ speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664028811314" ID="ID_1790496772" MODIFIED="1664152804500" TEXT="die Höhen-Angabe optional machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664028833680" ID="ID_822885755" MODIFIED="1664136676337" TEXT="Prädikat: Erkennung size-constrained">
|
|
<linktarget COLOR="#fff78b" DESTINATION="ID_822885755" ENDARROW="Default" ENDINCLINATION="-71;5;" ID="Arrow_ID_502040558" SOURCE="ID_10961106" STARTARROW="None" STARTINCLINATION="67;7;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664028974965" ID="ID_1683239335" MODIFIED="1664152835281" TEXT="Weiche in den Layout-Callbacks">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1664028987763" ID="ID_10961106" MODIFIED="1664152816917" TEXT="beruht auf dem Prädikat">
|
|
<arrowlink COLOR="#fff78b" DESTINATION="ID_822885755" ENDARROW="Default" ENDINCLINATION="-71;5;" ID="Arrow_ID_502040558" STARTARROW="None" STARTINCLINATION="67;7;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664029083790" ID="ID_1708491997" MODIFIED="1664152834413" TEXT="Antwort der Callbacks implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664029105419" ID="ID_1976797471" MODIFIED="1664152823165" TEXT="entweder per λ">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664029112435" ID="ID_82095109" MODIFIED="1664136681131" TEXT="oder die Basis-Impl verwenden">
|
|
<arrowlink COLOR="#6873c6" DESTINATION="ID_986565985" ENDARROW="Default" ENDINCLINATION="31;1;" ID="Arrow_ID_1518071893" STARTARROW="None" STARTINCLINATION="-102;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664029128360" ID="ID_986565985" MODIFIED="1664136684354" TEXT="Aufruf der Basis-Impl vorsehen">
|
|
<linktarget COLOR="#6873c6" DESTINATION="ID_986565985" ENDARROW="Default" ENDINCLINATION="31;1;" ID="Arrow_ID_1518071893" SOURCE="ID_82095109" STARTARROW="None" STARTINCLINATION="-102;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1664029223580" ID="ID_825294836" MODIFIED="1664136733333" TEXT="Framework zur Steuerung der Ausdehnung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1664029250424" ID="ID_1097443082" MODIFIED="1664836823192" TEXT="hier erst mal nur das Fundament legen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1664029267136" ID="ID_1383671067" MODIFIED="1664029355911" TEXT="zwei Themen">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1664029340460" ID="ID_1398837731" MODIFIED="1664836798961" TEXT="Ausdehnung des Labels steuern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1664031831907" ID="ID_701574899" MODIFIED="1664031980972" TEXT="Problem: reaktiv getriggert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bedingt durch das Aufrufschema können wir nicht zu Beginn steuernd eingreifen, sondern wir können nur erkennen, wenn das Sub-Widget (aus welchen Gründen auch immer) den extension-constraint verletzt. Und wir bekommen keine direkten Wirkfaktoren in die Hand (weil sich die Ausdehnung aus einem komplexen Zusammenspiel von Font, Pixelgröße und Styles ergibt)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664035985288" ID="ID_1514029086" MODIFIED="1664836806242" TEXT="#1238 hide ElementBoxWidget label to meet size constraint">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664032709767" FOLDED="true" ID="ID_89148369" MODIFIED="1664834444524" TEXT="einfache Lösung: per Seiteneffekt verbergen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664032721142" ID="ID_999001948" MODIFIED="1664313668307" TEXT="geht das?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
der GTK-Lyout-Callback wird aufgerufen
|
|
</li>
|
|
<li>
|
|
er ruft die btr. Callbacks der Kinder auf, um deren <i>natürliche Größe</i> zu ermitteln
|
|
</li>
|
|
<li>
|
|
wenn die Kinder nicht in den vorhandenen Platz passen, werden sie manipuliert oder verborgen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1664152924415" FOLDED="true" ID="ID_1883395520" MODIFIED="1664313655185" TEXT="funktioniert nicht zuverläasig">
|
|
<icon BUILTIN="broken-line"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1664152946955" ID="ID_5147112" MODIFIED="1664152961325" TEXT="beim 1.Aufruf sind die Allocationen noch allesamt 0"/>
|
|
<node CREATED="1664152963036" ID="ID_1568702731" MODIFIED="1664152994857" TEXT="es gibt später bei jedem Focus-Wechsel einen Aufruf"/>
|
|
<node CREATED="1664152996461" ID="ID_1521476415" MODIFIED="1664308648349" TEXT="der verbirgt dann auch korrekt das Label-Widget"/>
|
|
<node CREATED="1664308676289" ID="ID_1647971325" MODIFIED="1664308701317" TEXT="aber das passiert dann eben zu spät — die initiale Anzeige ist falsch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664153044266" FOLDED="true" ID="ID_175410634" MODIFIED="1664236010809" TEXT="und das Debugging per cout gibt Hexzahlen aus">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1664235646216" ID="ID_1679047596" MODIFIED="1664236010445" TEXT="Ursache waren naiv verwendete stream-Manipulatoren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die meisten IOS-Stream-Manipulatoren sind »sticky«, d.h. sie verändern per Seiteneffekt den Zustand im jeweiligen ostream. Ich hatte eine Methode zum Ausgeben einer Addresse, eingebaut im to-String-Framework, und diese hat std::output auf Hex-Ausgabe umgeschaltet. Erstaunlich daß ich das jahrelang nicht gemerkt habe!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664235664755" ID="ID_1756013187" MODIFIED="1664235705945" TEXT="RAII-Helper-Klasse, die ostream-Format-Zustand speichern und restaurieren kann">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664235714143" ID="ID_1375500060" MODIFIED="1664235720200" TEXT="mit Test abgedeckt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664235720902" ID="ID_558625134" MODIFIED="1664235875234" TEXT="Bug in format-obj.cpp damit gefixt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664313591898" ID="ID_1408861050" MODIFIED="1664313653715" TEXT="Probleme aufgeklärt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Zufallszahl wurde re-evaluiert im callback
|
|
</li>
|
|
<li>
|
|
darf nicht die Allokation verwenden, sondern stattdessen das Kind nach seiner preferred_size fragen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664308707648" ID="ID_1988489591" MODIFIED="1664308984611" TEXT="Untersuchung mit Trace-Print">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1664308730228" ID="ID_964535587" MODIFIED="1664308762363" TEXT="zum Zeitpunkt der Alloc-Zuteilung haben die nested-children noch keine Allokation"/>
|
|
<node CREATED="1664308866802" ID="ID_993068829" MODIFIED="1664308941471" TEXT="die Alloc-Zuteiltung für die Kiner passiert irgendwann später">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was normalerweise ja auch irrelevant ist, denn per Voraussetzung sollte ein Container die Werte von seinen Kindern bereits bei seiner initialen Meldung berücksichtigt haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664308771838" ID="ID_263801875" MODIFIED="1664308782506" TEXT="deshalb wird der Constraint initial immer erfüllt"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664308954262" FOLDED="true" ID="ID_1280341553" MODIFIED="1664313708451" TEXT="Problem: wie erfahren wir den Bedarf der Kinder?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664309487207" ID="ID_787731711" MODIFIED="1664309508504" TEXT="man könnte die get_preferred_*-Funktionen aufrufen"/>
|
|
<node CREATED="1664309544264" ID="ID_1683308991" MODIFIED="1664309560656" TEXT="wie geht denn die Implementierung von GTK vor?">
|
|
<node CREATED="1664309851614" ID="ID_1826397011" MODIFIED="1664309859201" TEXT="Beispiel Gtk::Frame"/>
|
|
<node CREATED="1664309859981" ID="ID_1769727317" MODIFIED="1664309861000" TEXT="gtk_widget_get_preferred_width">
|
|
<node CREATED="1664309926372" ID="ID_1300086457" MODIFIED="1664309930855" TEXT="gtksizerequest.c"/>
|
|
</node>
|
|
<node CREATED="1664309950440" ID="ID_1543575708" MODIFIED="1664309951372" TEXT="gtk_widget_compute_size_for_orientation"/>
|
|
<node CREATED="1664310005913" ID="ID_856747886" MODIFIED="1664310007318" TEXT="gtk_widget_query_size_for_orientation"/>
|
|
<node CREATED="1664310069177" ID="ID_667553135" MODIFIED="1664310070644" TEXT="widget_class->get_preferred_width">
|
|
<node CREATED="1664310105612" ID="ID_863371349" MODIFIED="1664310110172" TEXT="gtk_frame_get_preferred_width">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1664310126129" ID="ID_519479957" MODIFIED="1664310128423" TEXT="gtk_css_gadget_get_preferred_size"/>
|
|
</node>
|
|
<node CREATED="1664310467699" ID="ID_1970422819" MODIFIED="1664311129407" TEXT="das CSS Gadget ist Zukunft">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1664310476354" ID="ID_1555596776" MODIFIED="1664310481829" TEXT=""next gen widgets""/>
|
|
<node CREATED="1664310482704" ID="ID_915376669" MODIFIED="1664311133350" TEXT="aber aktuell noch nicht nach Gtkmm gemapped">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1664310512341" ID="ID_1313597088" MODIFIED="1664311136031" TEXT="widget->priv->gadget">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664310586763" ID="ID_64937663" MODIFIED="1664313705215" TEXT="Gtk::Widget::get_preferred_size(Requistion, Requisition)">
|
|
<arrowlink COLOR="#2080c0" DESTINATION="ID_117097226" ENDARROW="Default" ENDINCLINATION="108;6;" ID="Arrow_ID_766467833" STARTARROW="None" STARTINCLINATION="-29;46;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664310599964" ID="ID_751138081" MODIFIED="1664310626241" TEXT="das ist eine Abkürzug über die preferred_-Funtkionen plus den Layout-Trend"/>
|
|
<node COLOR="#338800" CREATED="1664311100685" ID="ID_1082035208" MODIFIED="1664311120569" TEXT="und liefert bereits zu Beginn die korrekten Werte">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664313525651" ID="ID_117097226" MODIFIED="1664313699335">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Fazit</b>: ja die Lösung <font color="#6206ae">funktioniert</font> und erscheint stabil
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#2080c0" DESTINATION="ID_117097226" ENDARROW="Default" ENDINCLINATION="108;6;" ID="Arrow_ID_766467833" SOURCE="ID_64937663" STARTARROW="None" STARTINCLINATION="-29;46;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664152748537" ID="ID_1604673752" MODIFIED="1664152775554" TEXT="besser: on_size_allocate verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664404663320" FOLDED="true" ID="ID_1822441152" MODIFIED="1664494935891" TEXT="minimal-size einführen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1664404674695" ID="ID_1745650030" MODIFIED="1664404686405" TEXT="Minimum sollte die Ausdehnung des Icon sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1664404687461" ID="ID_464093874" MODIFIED="1664404789460" TEXT="size_request und minimal-size werden von GTK nicht wirklich verwendet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...daher scheidet die offensichtliche einfache Lösung aus: nämlich einen size-request in der Größe des Icon zu setzen...
|
|
</p>
|
|
<p>
|
|
Stattdessen müssen wir dieses Minimum explizit in die Verarbeitung des size-Constraint einarbeiten, und dabe auf der <i>natural-size</i> des Icon aufbauen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1664404791911" ID="ID_1038149541" MODIFIED="1664486283099">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Nein! minimal und natural size <b>sollten gleich sein</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#bed1fd" DESTINATION="ID_1768206919" ENDARROW="Default" ENDINCLINATION="-2510;160;" ID="Arrow_ID_1173769741" STARTARROW="None" STARTINCLINATION="-2083;106;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1664486239918" ID="ID_393871048" MODIFIED="1664486273354" TEXT="unser size-constraint sollte auf beide gleichermaßen wirken">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1664486285336" ID="ID_1824223190" MODIFIED="1664486318819" TEXT="die allermeisten Container gehen von natural_size aus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664486295583" ID="ID_375004402" MODIFIED="1664486313154" TEXT="aber (relevant!) Gtk::Layout geht von minimal_width aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664486326706" ID="ID_23033105" MODIFIED="1664486428143" TEXT="strikt an die logische Bedeutung halten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664486342176" ID="ID_1766841402" MODIFIED="1664486354403" TEXT="minimal: "the minimum a widget neets to work properly""/>
|
|
<node CREATED="1664486355182" ID="ID_1887502358" MODIFIED="1664486366330" TEXT="in unserem Fall ist das der Size-constraint"/>
|
|
<node CREATED="1664486367173" ID="ID_203408708" MODIFIED="1664486380447" TEXT="und das Widget muß dann intern dafür sorgen, daß es seinen Content da reinbekommt"/>
|
|
<node CREATED="1664486398329" ID="ID_1798174878" MODIFIED="1664486423313" TEXT="GTK wird selber niemals ein Widget "stauchen"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn, dann muß man das dynamisch implementieren...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664027420141" FOLDED="true" ID="ID_969143327" MODIFIED="1664312508858" TEXT="führt das zu einem re-Draw?">
|
|
<linktarget COLOR="#4272bf" DESTINATION="ID_969143327" ENDARROW="Default" ENDINCLINATION="-1003;96;" ID="Arrow_ID_190980327" SOURCE="ID_945958753" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1664312511033" ID="ID_1716799052" MODIFIED="1664312589370" TEXT="wahrscheinlich Nein">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1664312522879" ID="ID_568381694" MODIFIED="1664312946309" TEXT="denn der erste Draw erfolgt nach der Zuteilung einer Allokation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwar machen wir im Ctor zuletzt ein show_all(), welches dann erst diese Layout-Berechnung anstößt. Aber zum Zeitpunkt der Allokations-Zuteilung für das Container-Widget (ElementBox selber) haben die nested-children noch keine Allokation bekommen; zwar gelten sie schon als "mapped" und "realized", aber offensichtlich führt eine Änderung des visible()-Status dazu, daß das damit ausgeblendete Kind-Widget schon gleich gar nicht gezeichnet wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664312590502" ID="ID_694110716" MODIFIED="1664312697424" TEXT="definitiv: keine erneute Layout-Berechnung und Allokation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ersichtlich aus Trace-Meldungen, welche ich zur Analyse in den get_preferred_*-Funktionen und beim Setzen der Allokation hatte. Auch auf dem Kind-Elementen sehe ich keine erneuten Aufrufe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664313319325" ID="ID_1660318028" MODIFIED="1664313502546" TEXT="aber: nach dem hide() liefert die umschließende Box sofort angepaßte preferred_size">
|
|
<arrowlink COLOR="#fcf2bc" DESTINATION="ID_611179505" ENDARROW="Default" ENDINCLINATION="-47;-40;" ID="Arrow_ID_96952850" STARTARROW="None" STARTINCLINATION="36;39;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664721403567" ID="ID_1984818373" MODIFIED="1664721416232" TEXT="das wäre ein weiterer Ansatzpunkt"/>
|
|
<node CREATED="1664721417261" ID="ID_264816651" MODIFIED="1672763811783" TEXT="die Widgets können die Situation "proben""/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664033098675" FOLDED="true" ID="ID_617752641" MODIFIED="1664836791921" TEXT="differenziertere Lösung evaluieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664721239543" ID="ID_958938237" MODIFIED="1664834954143" TEXT="Ansatz: Komponenten schritweise verbergen">
|
|
<arrowlink COLOR="#f8fecd" DESTINATION="ID_611179505" ENDARROW="None" ENDINCLINATION="-198;-9;" ID="Arrow_ID_990474269" STARTARROW="Default" STARTINCLINATION="202;13;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1664721613355" HGAP="38" ID="ID_100250479" MODIFIED="1664834929101" TEXT="Lösungs-Mechanik?" VSHIFT="-26">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#0d5b57" COLOR="#63cb95" CREATED="1664723304392" FOLDED="true" ID="ID_351577212" MODIFIED="1664723403946" STYLE="bubble" TEXT="Logik">
|
|
<edge COLOR="#52c44c" STYLE="linear"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="15"/>
|
|
<node COLOR="#33565a" CREATED="1664723420339" HGAP="38" ID="ID_1605718107" MODIFIED="1664727861369" TEXT="Handlungsbedarf?" VSHIFT="39">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BEDINGUNG: Constraint < Vollgröße
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Vollgröße ist im Widget gespeichert und wird nach Textänderung ermittelt (‣damit implizit auch initial)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#76fe43" DESTINATION="ID_793769798" ENDARROW="Default" ENDINCLINATION="15;-39;" ID="Arrow_ID_1548203404" STARTARROW="None" STARTINCLINATION="-3;6;"/>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664723834064" HGAP="35" ID="ID_793769798" MODIFIED="1664727861369" TEXT="erfüllt(cH)?" VSHIFT="26">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BEDINUNG: cH > aktuelleHöhe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#76fe43" DESTINATION="ID_793769798" ENDARROW="Default" ENDINCLINATION="15;-39;" ID="Arrow_ID_1548203404" SOURCE="ID_1605718107" STARTARROW="None" STARTINCLINATION="-3;6;"/>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<node COLOR="#33565a" CREATED="1664724142663" ID="ID_212862875" MODIFIED="1664727540444" TEXT="Nein ⟹ alles ausblenden ▣">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664725209295" ID="ID_657215999" MODIFIED="1664727540444" TEXT="Ja ⟹ prüfen...">
|
|
<arrowlink COLOR="#76fe43" DESTINATION="ID_1918462068" ENDARROW="Default" ENDINCLINATION="5;-16;" ID="Arrow_ID_1055241213" STARTARROW="None" STARTINCLINATION="-45;7;"/>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664725271351" HGAP="38" ID="ID_1918462068" MODIFIED="1664727540441" TEXT="erfüllt(cW)?" VSHIFT="-10">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BEDINUNG: cW > aktuelleWeite
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#76fe43" DESTINATION="ID_1918462068" ENDARROW="Default" ENDINCLINATION="5;-16;" ID="Arrow_ID_1055241213" SOURCE="ID_657215999" STARTARROW="None" STARTINCLINATION="-45;7;"/>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<node COLOR="#33565a" CREATED="1664725445271" ID="ID_1506234286" MODIFIED="1664727540444" TEXT="Nein ⟹ reduzieren!">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<node COLOR="#33565a" CREATED="1664725557464" ID="ID_1964737255" MODIFIED="1664727540443" TEXT="reduce(Name)? ⟹ ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BEDINGUNG: ΔName > goal
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Hilfsfunktion reduce(Name) : kann im Extremfall den Namen ausblenden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664725557464" ID="ID_827509447" MODIFIED="1664727540443" TEXT="reduce(Menu)? ⟹ ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BEDINGUNG: ΔMenu > goal
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Hilfsfunktion reduce(Menu) : kann das Menü ggfs ausblenden und liefert das dadurch erzielte Delta
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664725557464" ID="ID_76551672" MODIFIED="1664727540443" TEXT="reduce(Icon) ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Hier kein Test mehr notwendig; mehr als alles ausblenden können wir nicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664725508319" ID="ID_348137834" MODIFIED="1664727540442" TEXT="Ja ⟹ einblenden?">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<node COLOR="#33565a" CREATED="1664726003283" ID="ID_991077863" MODIFIED="1664727540443" TEXT="show(Icon)? Nein ⟹ ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mehrstufige Prüfung mit Hysterese (um Flackern zu vermeiden)...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
rechnerische Prüfung: Nominalgröße Icon + Hysterese < cW <i>und ebenso </i>< cH
|
|
</li>
|
|
<li>
|
|
danach: Icon einblenden und reale Größe ermitteln und gegen Constraint checken
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664726003283" ID="ID_1754814316" MODIFIED="1664727540443" TEXT="show(Menu)? Nein ⟹ ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auch hier mehrstufige Prüfung mit Hysterese...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#33565a" CREATED="1664726003283" ID="ID_249986815" MODIFIED="1664727540442" TEXT="show(Name)? ▣">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auch hier mehrstufige Prüfung...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
zunächst rechnerisch...
|
|
</li>
|
|
<ul>
|
|
<li>
|
|
in der ersten (einfachen) Version wird gegen die nominelle Gesamtgröße geprüft + Hysterese
|
|
</li>
|
|
<li>
|
|
in der (geplanten) Vollversion prüfen wir gegen die Icon-Größe + Hysterese, und unterstellen, daß sich der Name dann hinreichend kürzen kann
|
|
</li>
|
|
</ul>
|
|
<li>
|
|
danach wird der Name eingeblendet und reduce(Name) aufgerufen; sollte dies scheitern, muß eine Warnung und Assertion-Failure erfolgen, da die Logik sonst zwangsläufig in ein Schleife mit permanentem Flackern läuft!
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664727903654" FOLDED="true" HGAP="47" ID="ID_479783297" MODIFIED="1664836779699" TEXT="Implementierung" VSHIFT="-4">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1664766812799" ID="ID_806792302" MODIFIED="1664767612419" TEXT="weitgehend in lokalen Funktionen implementierbar">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664766835991" ID="ID_325959824" MODIFIED="1664767606249" TEXT="redundante Größen-Ermittlung in der Kette">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1664766851269" ID="ID_1929258813" MODIFIED="1664767130682" TEXT="habe hier Bedenken wegen der Performance">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#b1058d"><i>premature optimisation</i></font>??
|
|
</p>
|
|
<p>
|
|
Normalwerweise funktionieren alle unsere GUIs trotzdem schnell genug.<br />Aber hier wollen wir diese Sequenz hunderte Mal für jeden Fokus-Wechsel machen...
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<b>Problematisch</b> ist, daß hier über zwei Ebenen hinweg und über zwei mal zwei virtuelle Calls gegangen wird
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wir springen jeweils in eine non-inline-Funktion auf Gtkmm
|
|
</li>
|
|
<li>
|
|
diese delegiert auf eine non-inline-Funktion in Gtk+
|
|
</li>
|
|
<li>
|
|
und diese nutzt u.U zwei drei virtuelle Callbacks (Layout-Trend, Haupt-Dimension, sekundäre Dimension)
|
|
</li>
|
|
<li>
|
|
und jeder dieser Callbacks wir ein weiteres Mal von Gtkmm durch eine vtable dispatched
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664767140485" ID="ID_428399436" MODIFIED="1664767217656" TEXT="vor allem die wieder-einblenden-Sequenz ist gefährlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn sie wird für jeden Fokuswechsel und für jeden erfolglosen Versuch erneut durchlaufen, und zwar in den meisten Fällen (Label) bis zum 3.Schritt, nur um dann zu merken, daß eben doch nichts mehr rauszuholen ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664767237232" ID="ID_871917652" MODIFIED="1664767375307" TEXT="leider arbeiten hier die mogöichen Paddings gegen uns">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn das Stylesheet eben doch zusätzliche Paddings definiert, dann geht die Rechnung nicht auf, da sie auf den required-sizes der Kind-Widgets beruht, und daher (mit Paddings) zu optimistisch ist. Daher <i>müssen wir zwingend</i> nach einem versuchten wieder-Einblenden die <i>reale Ausdehnung des ganzen IDLabel </i>ermitteln und gegen die Constraints prüfen. Bei der Verkleinerung ist das nicht der Fall, denn da wirken die wegfallenden Paddings als zusätzlicher "Bonus".
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1664767377647" ID="ID_482878586" MODIFIED="1664767538685" TEXT="Verwende ein λ mit Seiteneffekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Damit muß ich nach jedem Schritt nur einmal die Größe neu ermitteln; diese Werte schlagen dann aus dem λ per Seiteneffekt auf die Variablen des umschließenden Scope durch. Das λ selber ist "scheinbar" nur eine Prüf-Funktion, und wird als Solche an die Hilfsfunktionen gegeben. Nicht schön, aber auch nicht wirklich gefährlich, da sich alles in einem lokalen Namespace abspielt. Habe eine Warnung im Code hinterlassen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664767619949" ID="ID_1351254549" MODIFIED="1664834924277" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1664767649344" ID="ID_408352584" MODIFIED="1664767655318" TEXT="kein Crash">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1664767638298" ID="ID_212652160" MODIFIED="1664767648612" TEXT="Ausblenden des Label funktioniert"/>
|
|
<node COLOR="#435e98" CREATED="1664767657871" ID="ID_599051282" MODIFIED="1664834531310" TEXT="Ausblenden der Icons funktioniert nicht">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1664834459501" ID="ID_1315620982" MODIFIED="1664834529415" TEXT="war nur ein Klammerungs-Fehler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Assignment-Operatoren binden weniger stark als Wertevergleiche, daher ist er immer nach dem ersten Reduktionsschritt ausgestiegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664834532931" ID="ID_60942393" MODIFIED="1664834557153" TEXT="Zusätzlicher Check ob Icon schon wieder eingeblendet ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664834558009" ID="ID_1531756128" MODIFIED="1664834595460" TEXT="redundante Prüfung beim Name-Label unvermeidbar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664834635582" ID="ID_611375985" MODIFIED="1664834740525">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil der Constraint ja <i>gelockert </i>sein könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, wenn das Label schon eingeblendet ist, aber nun zusätzlicher Platz verfügbar wird; deshalb dürfen wir hier bei einem bereits eingeblendeten Label nicht pauschal aussteigen, sondern müssen jedesmal die ganze Prüfung machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664834597364" ID="ID_988500213" MODIFIED="1664834784457" TEXT="ist aber nur schlimm solange wir das Label nicht kürzen können">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil in dem Fall jedesmal das Label wieder ausgeblendet wird, und dazu insgesamt drei mal die requested_width ermittelt werden muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664834616551" ID="ID_1590264446" MODIFIED="1664834836962" TEXT="in der Endversion wird uns die Hysterese schützen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...unter der Annahme, daß das Kürzen ggfs.auch verlängern kann, und damit schon relativ nahe am verfügbaren Platz ist. Dann verhindert die Hysterese, daß nochmal geprüft wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664834846850" ID="ID_1842010427" MODIFIED="1664834875522" TEXT="das Caching bekannter Constraints könnte sehr relevant sein. Unbedingt prüfen!"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664834911721" ID="ID_433069881" MODIFIED="1664836773505" TEXT="ansonsten verhält sich der Code jetzt wie intendiert">
|
|
<linktarget COLOR="#2db81a" DESTINATION="ID_433069881" ENDARROW="Default" ENDINCLINATION="366;20;" ID="Arrow_ID_1166896363" SOURCE="ID_1294234975" STARTARROW="None" STARTINCLINATION="301;14;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664033207476" ID="ID_1973707010" MODIFIED="1664721283088" TEXT="Weiterführende Idee: Label dynamisch kürzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664769914851" ID="ID_816204048" MODIFIED="1664769938381" TEXT="#1242 shorten ID-Label text to fit into size constraints">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664027420141" FOLDED="true" ID="ID_891209068" MODIFIED="1664836788731" TEXT="kann man den Label-Text ändern und sieht sofort eine Änderung auf dem Layout-Callback?">
|
|
<linktarget COLOR="#4265bf" DESTINATION="ID_891209068" ENDARROW="Default" ENDINCLINATION="-836;28;" ID="Arrow_ID_120092077" SOURCE="ID_945958753" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1664313375789" ID="ID_611179505" MODIFIED="1664313504665" TEXT="zumindest nach hide() ist sofort die prefered_size angepaßt">
|
|
<linktarget COLOR="#fcf2bc" DESTINATION="ID_611179505" ENDARROW="Default" ENDINCLINATION="-47;-40;" ID="Arrow_ID_96952850" SOURCE="ID_1660318028" STARTARROW="None" STARTINCLINATION="36;39;"/>
|
|
<linktarget COLOR="#f8fecd" DESTINATION="ID_611179505" ENDARROW="None" ENDINCLINATION="-198;-9;" ID="Arrow_ID_990474269" SOURCE="ID_958938237" STARTARROW="Default" STARTINCLINATION="202;13;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664543738587" ID="ID_418832883" MODIFIED="1664836412493" TEXT="Experiment durchführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1664543750721" ID="ID_1515243070" MODIFIED="1664836391654">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced">setName(cuString&)</font> implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664543863364" ID="ID_1704098172" MODIFIED="1664836402142" TEXT="Test-Manipulationsfunktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1664543973587" ID="ID_1411171343" MODIFIED="1664836399572" TEXT="Verb "manip""/>
|
|
<node COLOR="#435e98" CREATED="1664543988561" ID="ID_622195313" MODIFIED="1664836399571" TEXT="manipuliert die zuletzt erzeugte Box"/>
|
|
<node COLOR="#435e98" CREATED="1664543997192" ID="ID_332394972" MODIFIED="1664836399570" TEXT="setzt einen neuen Random-String"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664544020621" ID="ID_1995553965" MODIFIED="1664836410800" TEXT="Verhalten per Dump-msg beobachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664836698977" ID="ID_1294234975" MODIFIED="1664836773505" TEXT="ist nebenbei ein weiterer erfolgreicher Test für die Layout-Logik">
|
|
<arrowlink COLOR="#2db81a" DESTINATION="ID_433069881" ENDARROW="Default" ENDINCLINATION="366;20;" ID="Arrow_ID_1166896363" STARTARROW="None" STARTINCLINATION="301;14;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664836417335" ID="ID_683250227" MODIFIED="1664836426079" TEXT="Fazit">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1664836427405" ID="ID_1030484461" MODIFIED="1664836664800" TEXT="Änderungen wirken sich sofort auf die get_preferred_*() -Funktionen aus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664836480317" ID="ID_1978427776" MODIFIED="1664836667109" TEXT="aber nur wenn das Widget visible ist">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1664836489848" ID="ID_625722238" MODIFIED="1664836671391" TEXT="man muß also ggfs. show_all() aufrufen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1672763989377" ID="ID_898557963" MODIFIED="1672764024762" TEXT="Layout-Anpassungen sollte man also machen...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1672764001658" ID="ID_1513659794" MODIFIED="1672764011021" TEXT="in den get_preferred_*-VFunks"/>
|
|
<node CREATED="1672764011872" ID="ID_779540257" MODIFIED="1672764022227" TEXT="im on_size_allocate-Callback"/>
|
|
</node>
|
|
<node CREATED="1664836501374" ID="ID_915287836" MODIFIED="1672764716013" TEXT="Kein Problem: Layout-Handling-Code läuft vor dem nächsten DRAW">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Alle solchen UI-Aktionen kommen aus dem Event-Thread.
|
|
</li>
|
|
<li>
|
|
Jede Änderung der Visibility zieht eine resize-Kalkulation nach sich
|
|
</li>
|
|
<li>
|
|
dabei werden unsere Hooks aufgerufen, stellen die Änderung fest, und setzten ggfs. visible = false
|
|
</li>
|
|
<li>
|
|
Ergebnis: keinerlei sichtbarer Effekt (es sei denn, der Text wird tatsächlich angezeigt)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#738fa6" DESTINATION="ID_915287836" ENDARROW="Default" ENDINCLINATION="-35;506;" ID="Arrow_ID_1564122490" SOURCE="ID_327539453" STARTARROW="None" STARTINCLINATION="1322;71;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664033233729" ID="ID_73562728" MODIFIED="1664033252543" TEXT="ggfs Übersetzungs-Faktor im Advice-System ablegen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664728069849" ID="ID_458393482" MODIFIED="1664728428510" TEXT="Performance der Anzeigelogik beobachten">
|
|
<arrowlink COLOR="#675f90" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="144;-94;" ID="Arrow_ID_314973122" STARTARROW="None" STARTINCLINATION="-577;39;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664033337194" FOLDED="true" ID="ID_142928718" MODIFIED="1664674849781" TEXT="Label-Komponente anlegen">
|
|
<arrowlink COLOR="#feebc1" DESTINATION="ID_1075411565" ENDARROW="Default" ENDINCLINATION="-16;-582;" ID="Arrow_ID_957764469" STARTARROW="None" STARTINCLINATION="-606;54;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1664033348579" ID="ID_575467306" MODIFIED="1664553856140" TEXT="erst mal als gruppiertes Sub-Widget extrahieren">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1664544131446" ID="ID_448994253" MODIFIED="1664553853255" TEXT="der Box-Container">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664544138573" ID="ID_334656865" MODIFIED="1664553854357" TEXT="plus die Size-Handling-Logik">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664553879483" ID="ID_923634948" MODIFIED="1664674831082" TEXT="Buttons sind zu groß">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#338800" CREATED="1664668329069" ID="ID_696787535" MODIFIED="1664674548169" TEXT="Anforderung: muß diese Buttons "greifen" können">
|
|
<linktarget COLOR="#543f8c" DESTINATION="ID_696787535" ENDARROW="Default" ENDINCLINATION="-344;-15;" ID="Arrow_ID_1626542451" SOURCE="ID_1102642211" STARTARROW="None" STARTINCLINATION="560;45;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664674559510" ID="ID_1604472823" MODIFIED="1664674623071" TEXT="Untersuchung...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664674569649" ID="ID_892636850" MODIFIED="1664674628657" TEXT="zwei Ursachen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1664674575884" ID="ID_1453761517" MODIFIED="1664674589737" TEXT="alle Buttons haben ein min-width und min-height"/>
|
|
<node CREATED="1664674590960" ID="ID_1398294801" MODIFIED="1664674608939" TEXT="zumindest image-button hat auch ein Padding (4px bei mir)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664674677718" ID="ID_692056808" MODIFIED="1664674712628" TEXT="Style-Regeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1664674687597" ID="ID_1042549380" MODIFIED="1664674693955" TEXT="unset-Regel auf: .idlabel .image-button"/>
|
|
<node CREATED="1664674699611" ID="ID_1706886045" MODIFIED="1664674710229" TEXT="minimales Padding auf das Icon"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664544186535" ID="ID_272598573" MODIFIED="1664553847453" TEXT="Auslegung der Icons per Strategy steuerbar machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664033361175" ID="ID_314954032" MODIFIED="1664544103011" TEXT="könnte später mal eigenständiges Custom-Widget werden">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664029346619" ID="ID_1680520179" MODIFIED="1664031788262" TEXT="Ausdehnung an den Content-Render weitergeben">
|
|
<arrowlink COLOR="#5d8bc2" DESTINATION="ID_1572928176" ENDARROW="Default" ENDINCLINATION="74;-5;" ID="Arrow_ID_1521837627" STARTARROW="None" STARTINCLINATION="15;42;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664054650065" ID="ID_402860624" MODIFIED="1664054657328" TEXT="Konfiguration der Layout-Steuerung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664054365436" ID="ID_74006008" MODIFIED="1664054707374" TEXT="Shared Strategy">
|
|
<linktarget COLOR="#fde2be" DESTINATION="ID_74006008" ENDARROW="Default" ENDINCLINATION="6;128;" ID="Arrow_ID_1045794051" SOURCE="ID_1399625126" STARTARROW="None" STARTINCLINATION="-266;36;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#435e98" CREATED="1664055105139" ID="ID_594735349" MODIFIED="1664136644965" TEXT="sind mehrfache Indirektionen ein Problem?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1664055185035" ID="ID_1386788488" MODIFIED="1664055198439" TEXT="wir hätten konkrete Clip-delegates">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664055199606" ID="ID_1356714491" MODIFIED="1664133207079" TEXT="also doch policy based design?">
|
|
<arrowlink COLOR="#8d81ac" DESTINATION="ID_1304690112" ENDARROW="Default" ENDINCLINATION="654;32;" ID="Arrow_ID_1945811186" STARTARROW="None" STARTINCLINATION="942;-96;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1664055305064" ID="ID_794765074" MODIFIED="1664055318882" TEXT="dann müßte ElementBoxWidget von der Strategy erben"/>
|
|
<node CREATED="1664055333428" ID="ID_383670287" MODIFIED="1664055344687" TEXT="denn GTK verwendet bereits die VTable zur Differenzierung"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664055432842" ID="ID_217414794" MODIFIED="1664055487432" TEXT="Keine Panik!">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664055442553" ID="ID_94790418" MODIFIED="1664055480281">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Unterscheidung <i>resize</i> ⟺ <i>rerender</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664055520691" ID="ID_1052240865" MODIFIED="1664055540263" TEXT="Resize ⟹ muß Anzahl der (realisierten) Widgets limitieren"/>
|
|
<node CREATED="1664055541961" ID="ID_1385566332" MODIFIED="1664055595693" TEXT="reRender ⟹ bereits festgelegte Konfiguration + berechnetes Content-Pixmap"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664060239692" ID="ID_1617851912" MODIFIED="1664060250875" TEXT="also doch erst mal "bodenständig" beginnen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aua!
|
|
</p>
|
|
<p>
|
|
fällt mir schwer... ich sehe andauernd die späteren Probleme
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664054377646" ID="ID_309729651" MODIFIED="1664054397978" TEXT="nur eine Instanz pro Render-Methode">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664054422047" ID="ID_1277984931" MODIFIED="1664054478616" TEXT="für konkrete Darstellung wird ein Ausführungskontext erstellt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664054437613" ID="ID_409457601" MODIFIED="1664054479672" TEXT="Aufgabe: Ownership/Allokation für diesen Kontext">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664055065995" ID="ID_1022541607" MODIFIED="1664055102548" TEXT="nur eine Instanz pro konkrete Layout-Konfiguration(insgesamt)">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1664055731547" ID="ID_1438169680" MODIFIED="1664136751044" TEXT="Daten der individuellen Instanz">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1664055752785" ID="ID_1076715259" MODIFIED="1664055785130">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Analyse: welche <i>beweglichen Teile </i>gibt es überhaupt?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1664055792657" ID="ID_444290772" MODIFIED="1664055812602" TEXT="nameID">
|
|
<node CREATED="1664055813925" ID="ID_911900339" MODIFIED="1664055832455" TEXT="steckt dann im konkreten Clip-Widget"/>
|
|
<node CREATED="1664055833899" ID="ID_802603191" MODIFIED="1664055854529" TEXT="aufgedoppelt im Label-Widget-Content">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664056044104" ID="ID_637592114" MODIFIED="1664056050520" TEXT="nicht zwangsläufig">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1664056051832" ID="ID_528560555" MODIFIED="1664056323292" TEXT="möglicherweise die human-readable-Form">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die name-ID muß eindeutig sein (modulo Objekt-Typ), weil allein daraus eine EntryID zu konstruieren ist, vermöge deren die Kommunikation über den Bus gesteuert wird. Daher ist es denkbar, daß die User [optional] eine mnemonische Form definieren wollen, und diese steht dann im Label-Widget. Und noch etwas: der Label-Text wird ggfs. zur Anzeige gekürzt, also muß irgendwo der Basis-Text stehen (es sei denn, man holt sich den via Request über den Bus)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664055888396" ID="ID_926506496" MODIFIED="1664055891599" TEXT="expander">
|
|
<node CREATED="1664055910665" ID="ID_209252458" MODIFIED="1664055945904" TEXT="λ-Binding auf eine konkrete Controller-Instanz"/>
|
|
</node>
|
|
<node CREATED="1664055998046" ID="ID_298956950" MODIFIED="1664056000233" TEXT="placement">
|
|
<node CREATED="1664056001597" ID="ID_1442530188" MODIFIED="1664056035412" TEXT="nur ein ID-Binding (⟹ ergibt sich aus Name-ID)"/>
|
|
<node CREATED="1664056374416" ID="ID_316046833" MODIFIED="1664057693354" TEXT="(auch) hier ergibt sich die Notwendigkeit eines re-Populations-Diff">
|
|
<arrowlink COLOR="#fec2a0" DESTINATION="ID_501539344" ENDARROW="Default" ENDINCLINATION="-1291;-991;" ID="Arrow_ID_189200159" STARTARROW="None" STARTINCLINATION="-1328;59;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664059454965" ID="ID_223766358" MODIFIED="1664059458062" TEXT="extension">
|
|
<node CREATED="1664059464264" ID="ID_1408566346" MODIFIED="1664059479665" TEXT="[optional] constraint auf die Ausdehnung des Widget"/>
|
|
<node CREATED="1664059513545" ID="ID_540642643" MODIFIED="1664059533917" TEXT="zum Einen das Lösungs-Schema (λ)"/>
|
|
<node CREATED="1664059545013" ID="ID_12537442" MODIFIED="1664059564982" TEXT="außerdem konkret...">
|
|
<node CREATED="1664059565714" ID="ID_49571341" MODIFIED="1664059570221" TEXT="das Canvas-Attachment"/>
|
|
<node CREATED="1664059571305" ID="ID_1576639126" MODIFIED="1664059589554" TEXT="die zeitliche Ausdehnung des Clip"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664059631345" ID="ID_710374893" MODIFIED="1664059636180" TEXT="content-Renderer">
|
|
<node CREATED="1664059679707" ID="ID_1826707626" MODIFIED="1664059710722" TEXT="Name-ID genügt ⟹ Zugang zum konkreten Medium via Steam"/>
|
|
<node CREATED="1664059758792" ID="ID_665980098" MODIFIED="1664059964811" TEXT="[nur temporär] laufende Renderer-Instanz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
analog wie ein Player; während das Content-Rendering läuft muß der Clip eine Registrierung in einem zuständigen OutputManager aufrechterhalten, um die berechneten Pixmaps dann entgegenzunehmen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664059979870" ID="ID_1021249462" MODIFIED="1664060176885" TEXT="Information zu den vorhandenen Pixmaps, sowie deren Bedeutung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wir speichern ganz sicher nicht ein Mini-Bild für jeden Frame eines Video, sondern brauchen hier wohl eine Art lokales Caching; das heißt, die Pixmaps für einen aktiven Bereich plus eine gewisse Umgebung sind direkt greifbar im GUI. Dieses Caching ist aber nur ein 1st-Level, denn wir wollen den (als sehr elaboriert konzipierten) globalen Frame-Cache auch für diesen Zweck mitbenutzen; schließlich dürften diese Vorschaubilder die häufigsten laufenden Rendervorgänge sein...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1664060277055" ID="ID_319446276" MODIFIED="1664136766596" TEXT="Strategy als lokales Front-End anlegen">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1664060308706" ID="ID_346748114" MODIFIED="1664060333637" TEXT="gruppiert die wählbaren Detail-Strategien und Binding-λ"/>
|
|
<node CREATED="1664060335335" ID="ID_210836901" MODIFIED="1664060373437" TEXT="hält die Informationen für den Zugang zu den individuellen Instanz-Werten"/>
|
|
<node CREATED="1664060379716" ID="ID_853921300" MODIFIED="1664060395210" TEXT="und zwar insofern diese zur Verwendung der generischen Strategy notwendig sind"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030148144" FOLDED="true" ID="ID_1938112956" MODIFIED="1664030157478" TEXT="Framework für Content-Renderer">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_1938112956" ENDARROW="Default" ENDINCLINATION="-1219;85;" ID="Arrow_ID_1826503668" SOURCE="ID_596408518" STARTARROW="None" STARTINCLINATION="-2360;-214;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664036078380" ID="ID_750958309" MODIFIED="1664036087161" TEXT="#1237 Design for Content Renderer framework">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665870246870" ID="ID_1369666337" MODIFIED="1665870264462" TEXT="Anforderungs-Analyse">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1665870269397" ID="ID_184617933" MODIFIED="1665870282612" TEXT="was braucht ElementBoxWidget?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1665870390267" ID="ID_1292247563" MODIFIED="1665870468628" TEXT="»die Box« : ein Container">
|
|
<node CREATED="1665870476554" ID="ID_567789239" MODIFIED="1665870487537" TEXT="überspannt eine Hintergrund-Fläche"/>
|
|
<node CREATED="1665870488690" ID="ID_610765229" MODIFIED="1665870505519" TEXT="benötigt generelles Styling">
|
|
<node CREATED="1665870540741" ID="ID_596126312" MODIFIED="1665870553794" TEXT="Ankerpunkt: Klasse auf dem Haupt-Widget"/>
|
|
<node CREATED="1665870613181" ID="ID_1999333910" MODIFIED="1665870634461" TEXT="+eine bekannte Tag-ID zum Binden der CSS-Regeln"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665870683123" ID="ID_334958667" MODIFIED="1665870691416" TEXT="(optional) ein Kind-Widget">
|
|
<node CREATED="1665870701225" ID="ID_1109457189" MODIFIED="1665870734944">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
default == keines ⟹ <i><font color="#501f7e">leer</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665870805291" ID="ID_1283442162" MODIFIED="1665870815346" TEXT="ein Canvas">
|
|
<node CREATED="1665870818719" ID="ID_1999412105" MODIFIED="1665870828436" TEXT="kann darauf symbolischen Platzhalter zeichnen"/>
|
|
<node CREATED="1665870829902" ID="ID_1414104811" MODIFIED="1665870843608" TEXT="kann darauf »Content« darstellen"/>
|
|
<node CREATED="1665870844007" ID="ID_1925501138" MODIFIED="1665871130732" TEXT="kann daran weitere Widgets anhängen">
|
|
<linktarget COLOR="#3d3c58" DESTINATION="ID_1925501138" ENDARROW="Default" ENDINCLINATION="2;45;" ID="Arrow_ID_1045895165" SOURCE="ID_1660585525" STARTARROW="None" STARTINCLINATION="-7;-30;"/>
|
|
<node CREATED="1665870898550" ID="ID_264682173" MODIFIED="1665870903026" TEXT="Icon(s)"/>
|
|
<node CREATED="1665870903899" ID="ID_75342195" MODIFIED="1665870929870" TEXT="Text-Labels und Text-Felder"/>
|
|
<node CREATED="1665870930770" ID="ID_749692462" MODIFIED="1665870936278" TEXT="Steuerelemente"/>
|
|
<node CREATED="1665870937525" ID="ID_378196536" MODIFIED="1665870954394" TEXT="ElementBoxWidget(s)"/>
|
|
<node CREATED="1665870956006" ID="ID_1051993844" MODIFIED="1665871003940" TEXT="Timeline-artiger nested Content"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665871022157" ID="ID_178239069" MODIFIED="1665871030472" TEXT="weitere Alternativen?">
|
|
<node CREATED="1665871047978" ID="ID_1660585525" MODIFIED="1665871130732" TEXT="könnte Widgets direkt einbinden">
|
|
<arrowlink COLOR="#3d3c58" DESTINATION="ID_1925501138" ENDARROW="Default" ENDINCLINATION="2;45;" ID="Arrow_ID_1045895165" STARTARROW="None" STARTINCLINATION="-7;-30;"/>
|
|
</node>
|
|
<node CREATED="1665871160235" ID="ID_247576641" MODIFIED="1665871348368" TEXT="derzeit nur hypothetischer Nutzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es würde sich um irgendwelche ausgefallenen Use-Cases handeln, und das direkte Anheften der Kind-Widgets würde dann Overhead sparen, gegenüber einem Canvas; weiterer Vorteil wäre der direkte <i>push-back </i>für die Allokation von Screen-Extension (was allerdings im Falle eines size-constrained Widget dann wieder ein Nachteil wäre)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665871377691" ID="ID_1824259652" MODIFIED="1665871382745" TEXT="ein Inhalts-Handle">
|
|
<node CREATED="1665871386532" ID="ID_647005980" MODIFIED="1665871407866">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil ElementBoxWidget selbst keine <i>"business logic" </i>bereitstellt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665871536271" ID="ID_1978073457" MODIFIED="1665871567831" TEXT="dieses Handle wird aber nur an den Content-Renderer durchgereicht"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1665871606904" ID="ID_1501688207" MODIFIED="1665871618313" TEXT="was ist für bestimmten Content bereitzustellen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1665871626252" ID="ID_251889202" MODIFIED="1665871631909" TEXT="eine Strategy"/>
|
|
<node CREATED="1665871737765" ID="ID_1798687465" MODIFIED="1665871745120" TEXT="(optional) ein Kind-Widget">
|
|
<node CREATED="1665871862769" ID="ID_442590072" MODIFIED="1665871886917" TEXT="Modell-A">
|
|
<node CREATED="1665871888408" ID="ID_752938606" MODIFIED="1665871897155" TEXT="Kind-Widget ist immer ein Canvas"/>
|
|
<node CREATED="1665871898095" ID="ID_51898797" MODIFIED="1665871912673" TEXT="dieser wird direkt von ElementBox kontrolliert"/>
|
|
<node CREATED="1665871949152" ID="ID_1240018305" MODIFIED="1665871982138" TEXT="ein zusätzlicher "Renderer" operiert auf diesem Canvas"/>
|
|
</node>
|
|
<node CREATED="1665871984835" ID="ID_1759333514" MODIFIED="1665874483095" TEXT="Modell-B">
|
|
<linktarget COLOR="#90c8e3" DESTINATION="ID_1759333514" ENDARROW="Default" ENDINCLINATION="44;114;" ID="Arrow_ID_1003572490" SOURCE="ID_1156085708" STARTARROW="None" STARTINCLINATION="-104;-18;"/>
|
|
<node CREATED="1665871991892" ID="ID_104574738" MODIFIED="1665872003189" TEXT="das Kind-Widget ist eigenständig"/>
|
|
<node CREATED="1665872106235" ID="ID_1051979214" MODIFIED="1665872117349" TEXT="es bietet Hooks an...">
|
|
<node CREATED="1665872129240" ID="ID_1784194423" MODIFIED="1665872322049" TEXT="für die Layout-Steuerung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Aushandeln der benötigten Extension
|
|
</li>
|
|
<li>
|
|
Ändern der Detailtiefe (expand / collapse)
|
|
</li>
|
|
<li>
|
|
Setzen einer Ausdehnungs-Vorgabe
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665872631421" ID="ID_102284502" MODIFIED="1665872716207" TEXT="für das lokale pop-up-Menü">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welches u.U. zwar vom ElementBoxWidget aus eingebunden wird, aber eigentlich auf die Inhalts-Ebene delegiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665873885491" ID="ID_131672642" MODIFIED="1665873982614" TEXT="für Pivot-Content">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wobei das eigentlich nur für den <i>einfachen Use-Case </i>relevant ist; denn im Falle eines komplexen Content-Containers wird die Steuerung, in welche der Container ohnehin eingebunden sein muß (z.B. der Clip-Controller) wohl auf direktem Wege agieren, ohne durch das ElementBox-Widget zu gehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1665872518404" ID="ID_536642669" MODIFIED="1665872555004" TEXT="Struktur-Enscheidungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1665872959841" ID="ID_1538590156" MODIFIED="1665874432390" TEXT="ElementBoxWidget nur als Container anlegen">
|
|
<arrowlink COLOR="#4664b9" DESTINATION="ID_482907124" ENDARROW="Default" ENDINCLINATION="-136;-5;" ID="Arrow_ID_1958020561" STARTARROW="None" STARTINCLINATION="183;12;"/>
|
|
<arrowlink COLOR="#4664b9" DESTINATION="ID_637712334" ENDARROW="Default" ENDINCLINATION="17;-78;" ID="Arrow_ID_1498361777" STARTARROW="None" STARTINCLINATION="188;12;"/>
|
|
</node>
|
|
<node CREATED="1665872986764" ID="ID_1471519235" MODIFIED="1665873002758" TEXT="es gibt zwei grundverschiedene usage-Patterns">
|
|
<node CREATED="1665873005177" ID="ID_1711206809" MODIFIED="1665873013892" TEXT="Labels und einfacher Content">
|
|
<node CREATED="1665873056661" ID="ID_1303900519" MODIFIED="1665873075779" TEXT="hier weitgehende Standardisierung und Automatisierung gewünscht"/>
|
|
<node CREATED="1665873092646" ID="ID_764903267" MODIFIED="1665873111767" TEXT="reduziert sich auf ein Label + einen pop-up-Menu-Provider"/>
|
|
<node CREATED="1665873149175" ID="ID_329681558" MODIFIED="1665873228305" TEXT="(optional) Pivot-Content">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ein Stichwort, eine (ggfs. dynamische) Kurzinformation, ein pivot-Frame als Erkennungszeichen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665873014720" ID="ID_321549471" MODIFIED="1665873024963" TEXT="Clips bzw. Content-Container">
|
|
<node CREATED="1665873235907" ID="ID_438342430" MODIFIED="1665873254132" TEXT="hier soll sich das ElementBoxWidget möglichst passiv verhalten"/>
|
|
<node CREATED="1665873270653" ID="ID_340799218" MODIFIED="1665873303819">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt <i>anderswo </i>einen dedizierten "Content Controller"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665873423045" ID="ID_615133783" MODIFIED="1665873440786" TEXT="das Thema »temporale Extension« ist (natürlich) problematisch">
|
|
<node CREATED="1665873457525" ID="ID_482907124" MODIFIED="1665873562628" TEXT="denn das ElementBoxWidget soll selber in die Zeit-Umrechnung nicht involviert sein">
|
|
<linktarget COLOR="#4664b9" DESTINATION="ID_482907124" ENDARROW="Default" ENDINCLINATION="-136;-5;" ID="Arrow_ID_1958020561" SOURCE="ID_1538590156" STARTARROW="None" STARTINCLINATION="183;12;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1665873578728" ID="ID_1319825496" MODIFIED="1665873612116" TEXT="folglich pollt es eine Pixel-Ausdehnung und drückt die an den Content-Provider weiter"/>
|
|
<node CREATED="1665873632653" ID="ID_1586810839" MODIFIED="1665873651822" TEXT="ohne an diesen auch einen inhaltlichen Link oder eine Layout-Strategie weiterzureichen"/>
|
|
</node>
|
|
<node CREATED="1665873457525" ID="ID_637712334" MODIFIED="1665874432391" TEXT="aufgrund der disparaten Use-Cases....">
|
|
<linktarget COLOR="#4664b9" DESTINATION="ID_637712334" ENDARROW="Default" ENDINCLINATION="17;-78;" ID="Arrow_ID_1498361777" SOURCE="ID_1538590156" STARTARROW="None" STARTINCLINATION="188;12;"/>
|
|
<node CREATED="1665874438345" ID="ID_1156085708" MODIFIED="1665874490650" TEXT="kommt nur Modell-B für das Kind-Widget in Frage">
|
|
<arrowlink COLOR="#90c8e3" DESTINATION="ID_1759333514" ENDARROW="Default" ENDINCLINATION="44;114;" ID="Arrow_ID_1003572490" STARTARROW="None" STARTINCLINATION="-104;-18;"/>
|
|
<node CREATED="1665874929814" ID="ID_103158499" MODIFIED="1665874947504">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar wegen der <i>Separation of Concerns</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1665874948313" ID="ID_293802012" MODIFIED="1665874962785" TEXT="(leider spricht nämlich alles Andere ehr für Modell-A....)"/>
|
|
</node>
|
|
<node CREATED="1665874513335" ID="ID_284819629" MODIFIED="1665874526768" TEXT="Modell-A läßt sich wohl als ein Spezialfall deuten">
|
|
<node CREATED="1665874544130" ID="ID_1578446031" MODIFIED="1665874578715">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und <i><u>das</u></i> wäre der <i>eigentliche Fall </i>für einen <b>Content-Renderer</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1665874586541" ID="ID_1266044104" MODIFIED="1665874598322" TEXT="dieser ist demnach immer ein spezielles Canvas-Widget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665874965521" ID="ID_1819243067" MODIFIED="1665874975801" TEXT="Allokation">
|
|
<node CREATED="1665875003260" ID="ID_1160344881" MODIFIED="1665875034082" TEXT="Modell-A : ElementBox enthält immer ein Canvas-Widget"/>
|
|
<node CREATED="1665874978212" ID="ID_1828608585" MODIFIED="1665875001778" TEXT="Modell-B : Allokation des Kind-Widget muß woanders erfolgen">
|
|
<node CREATED="1665875077974" ID="ID_1931734833" MODIFIED="1665875087061" TEXT="ElementBox übernimmt keine Ownership"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1665875088220" ID="ID_734939153" LINK="#ID_1042919827" MODIFIED="1675385118681" TEXT="Lifecycle ist zu gewährleisten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Kind-Widget muß ElementBox überleben; und das bedeutet, es muß ein Sibling sein... (problematisch für die Struktur vom ClipWidget, es sei denn, man macht ElementBox dort zu einem Member — was allerdings wiederum der Anforderung widerspricht, daß das Clip-Delegate direkt ein Widget ist und sich darstellen kann)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665875444841" ID="ID_544669077" MODIFIED="1665875454532" TEXT="Kompromiß...">
|
|
<node CREATED="1665875461707" ID="ID_194337480" MODIFIED="1665875478696" TEXT="Allokation InPlaceBuffer"/>
|
|
<node CREATED="1665875492299" ID="ID_629065329" MODIFIED="1665875511676" TEXT="aber die Strategy definiert die konkrete Widget-Klasse"/>
|
|
</node>
|
|
<node CREATED="1665875537501" ID="ID_1656529505" MODIFIED="1665875748844" TEXT="der »Renderer« dagegen wäre stets eine globale Komponente">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...würde also z.B. als Meyer's Singleton bereitgestellt, und müßte den konkreten Kontext für jeden Aufruf zugereicht bekommen; auch die <i>Render-Vorgänge </i>könnte man als Pool darstellen, denn es macht ohnehin keinen Sinn, alle Clips auf einmal zu rendern; wenn ein Render-Vorgang beendet ist, bleibt nur noch ein Buffer-Handle übrig für das resultierende Pixmap
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665875357440" ID="ID_320528707" MODIFIED="1665875382101" TEXT="⟹ Zwischenfazit: neige nun doch wieder Modell-A zu">
|
|
<node CREATED="1665875384897" ID="ID_132968061" MODIFIED="1665875408194" TEXT="aber sollte die Encapsulation aus Modell-B übernehmen"/>
|
|
<node CREATED="1665875408990" ID="ID_1304861189" MODIFIED="1665875430814" TEXT="d.h. ElementBox kontrolliert eben diesen Canvas doch nicht direkt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030163430" ID="ID_1789916626" MODIFIED="1664030172407" TEXT="Design: Interface-Komponente">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030181011" ID="ID_741977554" MODIFIED="1664030201167" TEXT="Steuerung via ctor-DSL prüfen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1665868480820" ID="ID_954980728" MODIFIED="1665868517693" TEXT="Typ + Presentation Intent ⟹ Content renderer(Strategy) installieren"/>
|
|
<node CREATED="1665868541647" ID="ID_761057997" MODIFIED="1665874907453" TEXT="+ zusätzlich konkrete Name-ID ⟹ Aufrufkontext für konkreten Render-Vorgang"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030206720" ID="ID_1572928176" MODIFIED="1664031781637" TEXT="Analyse zum Thema: Zeit/Ausdehnung">
|
|
<linktarget COLOR="#5d8bc2" DESTINATION="ID_1572928176" ENDARROW="Default" ENDINCLINATION="74;-5;" ID="Arrow_ID_1521837627" SOURCE="ID_1680520179" STARTARROW="None" STARTINCLINATION="15;42;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1664050286058" ID="ID_1762124621" MODIFIED="1664050305208" TEXT="Vorsicht: Overhead">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664050307047" ID="ID_1064025353" MODIFIED="1664050317347" TEXT="Flyweight-Pattern?">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664054365436" ID="ID_1399625126" MODIFIED="1664054741234" TEXT="Shared Strategy">
|
|
<arrowlink COLOR="#fde2be" DESTINATION="ID_74006008" ENDARROW="Default" ENDINCLINATION="6;128;" ID="Arrow_ID_1045794051" STARTARROW="None" STARTINCLINATION="-266;36;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969213838" ID="ID_405495257" MODIFIED="1665969529899" TEXT="Anzeige-Strategy konfigurieren für Medien-Typ">
|
|
<linktarget COLOR="#b46465" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-539;-35;" ID="Arrow_ID_742470916" SOURCE="ID_1425589285" STARTARROW="None" STARTINCLINATION="-274;362;"/>
|
|
<linktarget COLOR="#f76d6f" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-268;17;" ID="Arrow_ID_1695054562" SOURCE="ID_1851529218" STARTARROW="None" STARTINCLINATION="-225;-219;"/>
|
|
<linktarget COLOR="#e36874" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-2189;115;" ID="Arrow_ID_127305949" SOURCE="ID_207274074" STARTARROW="None" STARTINCLINATION="928;-50;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030240987" ID="ID_1818560319" MODIFIED="1664030267363" TEXT="Verwendung ohne Content-Renderer">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1664030268583" ID="ID_161979546" MODIFIED="1664030302799" TEXT="das ist der Regelfall">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664030284814" ID="ID_1970065313" MODIFIED="1664030295541" TEXT="hierfür geeigneten CSS-Selector vorsehen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664548844498" ID="ID_1075411565" MODIFIED="1664548893098" TEXT="Label-Komponente weiterentwickeln">
|
|
<linktarget COLOR="#feebc1" DESTINATION="ID_1075411565" ENDARROW="Default" ENDINCLINATION="-16;-582;" ID="Arrow_ID_957764469" SOURCE="ID_142928718" STARTARROW="None" STARTINCLINATION="-606;54;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661703437825" ID="ID_1401386216" MODIFIED="1661703453368" TEXT="proportional Head placement">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661703477179" ID="ID_1739233114" MODIFIED="1661703485808" TEXT="#1186 proportional Head placement">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1661703490282" ID="ID_1702374688" MODIFIED="1661703511348" TEXT="als sub-Komponente anlegen">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661703520158" ID="ID_1872452150" MODIFIED="1661703524686" TEXT="Unit-Test schreiben">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661703532196" ID="ID_170724374" MODIFIED="1661703542907" TEXT="anfangs Platzhalter-Implementierung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1661703645714" ID="ID_247022344" MODIFIED="1661704606196" TEXT="Entscheidung: Pixel oder zeitbasiert?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1661703679376" ID="ID_1132759558" MODIFIED="1661704522137" TEXT="Pixel">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1661703686271" ID="ID_876601888" MODIFIED="1661704164479" TEXT="Länge und Fenster-Spec einheitlich in Pixeln">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hierbei ist...
|
|
</p>
|
|
<p>
|
|
<u>Länge</u>: die <i>horizontale</i> Ausdehnung in der <i>zeitartigen Dimension</i>
|
|
</p>
|
|
<p>
|
|
<u>Fenster</u>: die Position und Länge eines Anzeige-Fensters im Verhältnis zur Länge
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1661703733113" ID="ID_1280505961" MODIFIED="1661704551822" TEXT="Angaben müssen angepaßt werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wannimmersich die Display-Metrik ändert (bei jeder Zoom-Anpassung!)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#c14b62" DESTINATION="ID_844385062" ENDARROW="Default" ENDINCLINATION="192;0;" ID="Arrow_ID_418259958" STARTARROW="Default" STARTINCLINATION="192;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1661703818006" ID="ID_1356134223" MODIFIED="1661703862455" TEXT="keine Verbindung zum Layoutmanager notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Naja, stimmt nicht wirklich, denn Pixel-Angaben müssen angepaßt werden, also besteht faktisch eine Verbindung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661703682724" ID="ID_258332905" MODIFIED="1661704522143" TEXT="Zeit">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1661703897467" ID="ID_1062096597" MODIFIED="1661704080771" TEXT="Länge und Fenster-Spec in Timeline-Zeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
egal ob nun absolut oder relativ, aber die Lumiera Time-Koordinaten sind gemein. Das ist nicht die »wall clock time«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1661704028802" ID="ID_844385062" MODIFIED="1661704576860" TEXT="Entscheidungen müssen nach Layoutwechsel erneut getroffen werden">
|
|
<arrowlink COLOR="#c14b4e" DESTINATION="ID_674852170" ENDARROW="Default" ENDINCLINATION="130;0;" ID="Arrow_ID_971214477" STARTARROW="None" STARTINCLINATION="130;0;"/>
|
|
<linktarget COLOR="#c14b62" DESTINATION="ID_844385062" ENDARROW="Default" ENDINCLINATION="192;0;" ID="Arrow_ID_418259958" SOURCE="ID_1280505961" STARTARROW="Default" STARTINCLINATION="192;0;"/>
|
|
</node>
|
|
<node CREATED="1661704046831" ID="ID_1429751432" MODIFIED="1661704592099" TEXT="das Widget braucht Pixel-Angaben ⟹ Übersetzungs-Mechanismus">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1661703881189" ID="ID_1847710987" MODIFIED="1661721501719" TEXT="proportional">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1661704175885" ID="ID_1381922176" MODIFIED="1661704361482" TEXT="die gesamte Positionierungs-Logik arbeitet mit Verhältniszahlen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wobei der Datentyp dieser Verhältniszahlen noch wählbar ist
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
könnte ein Floating-point sein (float würde eigentlich genügen)
|
|
</li>
|
|
<li>
|
|
könnte ein <i>rational</i> sein mit kleinen Integerzahlen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1661704193107" ID="ID_279484931" MODIFIED="1661704240383" TEXT="Bezugspunkt könnte sein">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1661704212873" ID="ID_1162803069" MODIFIED="1661704237529" TEXT="(absolut) eine Einheits-Zeit">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1661704217016" ID="ID_910021722" MODIFIED="1661704233921" TEXT="(relativ) die Länge des Widget">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661704403383" ID="ID_674852170" MODIFIED="1661704558666" TEXT="jeder Layoutwechsel ändert die relative Fenster-Spec ⟹ Neuauswertung">
|
|
<linktarget COLOR="#c14b4e" DESTINATION="ID_674852170" ENDARROW="Default" ENDINCLINATION="130;0;" ID="Arrow_ID_971214477" SOURCE="ID_844385062" STARTARROW="None" STARTINCLINATION="130;0;"/>
|
|
</node>
|
|
<node CREATED="1661704490787" ID="ID_1576808360" MODIFIED="1661704596118" TEXT="(nur) Client muß die absolute Länge wissen">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661703561288" ID="ID_1074390800" MODIFIED="1661703581358" TEXT="endgültige Implementierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661558691874" ID="ID_1119666560" MODIFIED="1661558709710" TEXT="Kontext-Anbindung planen...">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1661558725419" ID="ID_903216053" MODIFIED="1661558736509" TEXT="Zeit/Größen-Übersetzung"/>
|
|
<node CREATED="1661558740744" ID="ID_629101835" MODIFIED="1661558746908" TEXT="Placement-Editor"/>
|
|
<node CREATED="1661558748136" ID="ID_450211999" MODIFIED="1661558766073" TEXT="Anbindung an ein Tangible">
|
|
<node CREATED="1661558767493" ID="ID_984314368" MODIFIED="1661558783560" TEXT="offen lassen: ist es selber ein Tangible?">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664032772511" ID="ID_1018439357" MODIFIED="1664032782461" TEXT="Untersuchungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664032818869" ID="ID_945958753" MODIFIED="1664494574785" TEXT="GTK-Interna">
|
|
<arrowlink COLOR="#4285bf" DESTINATION="ID_217473035" ENDARROW="Default" ENDINCLINATION="-989;57;" ID="Arrow_ID_1041626932" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<arrowlink COLOR="#4272bf" DESTINATION="ID_969143327" ENDARROW="Default" ENDINCLINATION="-1003;96;" ID="Arrow_ID_190980327" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<arrowlink COLOR="#4265bf" DESTINATION="ID_891209068" ENDARROW="Default" ENDINCLINATION="-836;28;" ID="Arrow_ID_120092077" STARTARROW="None" STARTINCLINATION="260;-42;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#793f70" CREATED="1664728013606" FOLDED="true" ID="ID_1113493685" MODIFIED="1664730778937" TEXT="Performance-on-scale">
|
|
<linktarget COLOR="#675f90" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="144;-94;" ID="Arrow_ID_314973122" SOURCE="ID_458393482" STARTARROW="None" STARTINCLINATION="-577;39;"/>
|
|
<linktarget COLOR="#652a49" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="-1026;116;" ID="Arrow_ID_977109999" SOURCE="ID_46750178" STARTARROW="None" STARTINCLINATION="-985;55;"/>
|
|
<linktarget COLOR="#652a49" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="-1026;116;" ID="Arrow_ID_1663742451" SOURCE="ID_499807590" STARTARROW="None" STARTINCLINATION="-985;55;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664730454742" ID="ID_898331208" MODIFIED="1664730461480" TEXT="#1240 evaluate performance of ElementBoxWidget">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1664728161348" ID="ID_541577601" MODIFIED="1664728171859" TEXT="Speicherbedarf">
|
|
<node CREATED="1664728182417" ID="ID_787168469" MODIFIED="1664728197093" TEXT="Speichern der Maximalgröße"/>
|
|
<node CREATED="1664728197911" ID="ID_238915264" MODIFIED="1664728205283" TEXT="Speichern des vollständigen Label-Textes"/>
|
|
<node CREATED="1664728207952" ID="ID_1837798110" MODIFIED="1664728236438" TEXT="Speichern des vorhergehenden Constraints"/>
|
|
</node>
|
|
<node CREATED="1664728246927" ID="ID_502396500" MODIFIED="1664728250323" TEXT="Laufzeit">
|
|
<node CREATED="1664728261343" ID="ID_1345184412" MODIFIED="1664728285571" TEXT="Laufzeit incl Ein/Ausblenden (aller Widgets)"/>
|
|
<node CREATED="1664728287779" ID="ID_382936001" MODIFIED="1664728325578" TEXT="Laufzeit mit/ohne Prüfung redundanter Constraints"/>
|
|
<node CREATED="1664728326686" ID="ID_724874601" MODIFIED="1664728340360" TEXT="Laufzeit mit/ohne Prüfung der Maximalausdehnung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1654445541606" ID="ID_520455096" MODIFIED="1678403536238" TEXT="Integrieren">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1654445546655" FOLDED="true" ID="ID_1539832096" MODIFIED="1675394835906" TEXT="einfaches ElementBoxWidget...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1654445564395" ID="ID_1890406032" MODIFIED="1675394803481" TEXT="testhalber in der HeaderPane unterbringen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1675394806931" ID="ID_1282996631" MODIFIED="1675394828787" TEXT="funktioniert auf Anhieb"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1675394821061" ID="ID_443844677" MODIFIED="1675394826892" TEXT="scheee....">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1654445580312" ID="ID_271330163" MODIFIED="1662051966664" TEXT="testhalber an den Track-Canvas anheften">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1662051865093" ID="ID_586574609" MODIFIED="1662051953551" TEXT="Auslösen via TestControll �� mark-Message">
|
|
<node CREATED="1662051911095" ID="ID_544118617" MODIFIED="1662051953551" TEXT=""mark""/>
|
|
<node CREATED="1662051916686" ID="ID_1007131481" MODIFIED="1662051953551" TEXT="1.Feld: ID der Timeline"/>
|
|
<node CREATED="1662051923037" ID="ID_863517485" MODIFIED="1662051953551" TEXT="2.Feld: magischer Name "box""/>
|
|
<node COLOR="#338800" CREATED="1662051939243" ID="ID_1354069914" MODIFIED="1662051953551" TEXT="funzt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1662051893903" ID="ID_783944635" MODIFIED="1662051953551" TEXT="Impl: TrackPresenter::attachElementBox()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666370244648" ID="ID_306927735" MODIFIED="1675387511544" TEXT="testhalber als Effekt in Ruler legen">
|
|
<arrowlink COLOR="#b12c6e" DESTINATION="ID_613160281" ENDARROW="Default" ENDINCLINATION="-858;-29;" ID="Arrow_ID_1531249433" STARTARROW="None" STARTINCLINATION="-361;27;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1675387513273" ID="ID_866696752" MODIFIED="1675387528379" TEXT="wartet auf: #1270 define CanvasHook for ruler tracks"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1654445594924" FOLDED="true" ID="ID_1266679575" MODIFIED="1666367207990" TEXT="Clip auf ElementBoxWidget umstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969365831" ID="ID_149648314" MODIFIED="1665971950293" TEXT="Design-Probleme">
|
|
<linktarget COLOR="#ff5268" DESTINATION="ID_149648314" ENDARROW="Default" ENDINCLINATION="2;21;" ID="Arrow_ID_441789889" SOURCE="ID_500624074" STARTARROW="None" STARTINCLINATION="-196;23;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1665969380429" ID="ID_438117560" MODIFIED="1665969431276" TEXT="ElementBoxWidget ist "ctor-zentrisch"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1665969406938" ID="ID_964851207" MODIFIED="1665969425517" TEXT="aber Diff liefert viele Aspekte erst später">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1665969444163" ID="ID_1678945295" MODIFIED="1665969448288" TEXT="betrifft...">
|
|
<node CREATED="1665969449092" ID="ID_1852745838" MODIFIED="1665969452839" TEXT="den Clip-Namen">
|
|
<node CREATED="1665969454987" ID="ID_1388522515" MODIFIED="1665969456935" TEXT="die ID"/>
|
|
<node CREATED="1665969457547" ID="ID_1136164363" MODIFIED="1665969461166" TEXT="den lesbaren Namen"/>
|
|
</node>
|
|
<node CREATED="1665969462522" ID="ID_1851529218" MODIFIED="1665969529899">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den <i>Medien-Typ</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#f76d6f" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-268;17;" ID="Arrow_ID_1695054562" STARTARROW="None" STARTINCLINATION="-225;-219;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665971884155" FOLDED="true" ID="ID_1832121467" MODIFIED="1665971971444" TEXT="ansonsten "fast" nichts zu tun">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1665971894646" ID="ID_1038999615" MODIFIED="1665971943555" TEXT="ElementBoxWidget als Basisklasse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665971906399" ID="ID_500624074" MODIFIED="1665971950292" TEXT="die ctor-DSL einbinden">
|
|
<arrowlink COLOR="#ff5268" DESTINATION="ID_149648314" ENDARROW="Default" ENDINCLINATION="2;21;" ID="Arrow_ID_441789889" STARTARROW="None" STARTINCLINATION="-196;23;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1665971952866" ID="ID_953567994" MODIFIED="1665971966677" TEXT="für den size-constraint: von push auf pull umstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665971975191" FOLDED="true" ID="ID_1645965443" MODIFIED="1666286274777" TEXT="size-constraint-Code wird zu früh aufgerufen">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1665972027480" ID="ID_1481599747" MODIFIED="1665972094845">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#f12b4f"><b>ASSERTION</b></font> : widget muß bereits realized sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0000001052: INFO: steam-dispatcher.cpp:301: worker_2: processCommands: +++ dispatch Command("test_fake_injectSequence_1") {exec}
|
|
</p>
|
|
<p>
|
|
0000001053: INFO: steam-dispatcher.cpp:306: worker_2: processCommands: +++ -------->>> bang!
|
|
</p>
|
|
<p>
|
|
0000001055: TODO: dummy-session-connection.cpp:259: worker_2: applyCopy: build internal diagnostic data structure, apply a copy of the message
|
|
</p>
|
|
<p>
|
|
0000001060: TODO: track-body.cpp:93: worker_3: setTrackName: is the track name of any relevance for the TrackBody widget?
|
|
</p>
|
|
<p>
|
|
0000001061: INFO: ui-style.cpp:145: worker_3: prepareStyleContext: Body-CSS: path=window.background box.vertical box[2/3].horizontal widget[2/2] widget paned.vertical widget box.vertical notebook[1/1].frame paned.horizontal.timeline__page.timeline box.vertical.timeline__body.timeline fork.timeline__fork
|
|
</p>
|
|
<p>
|
|
0000001062: INFO: ui-style.cpp:154: worker_3: prepareStyleContext: RulerCSS: path=window.background box.vertical box[2/3].horizontal widget[2/2] widget paned.vertical widget box.vertical notebook[1/1].frame paned.horizontal.timeline__page.timeline box.vertical.timeline__body.timeline fork.timeline__fork frame.timeline__ruler
|
|
</p>
|
|
<p>
|
|
Clip:: hsize=25
|
|
</p>
|
|
<p>
|
|
Clip:: hsize=50
|
|
</p>
|
|
<p>
|
|
Clip:: hsize=25
|
|
</p>
|
|
<p>
|
|
0000001085: ASSERTION: element-box-widget.cpp:327: worker_3: imposeSizeConstraint: (label_.get_realized()) ElementBoxWidget layout constraint imposed on widget not yet realized by GTK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665972100310" ID="ID_1747925228" MODIFIED="1666285341589" TEXT="seltsam? in den bisherigen Experimenten war das nie ein Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn ich ging von der Annahme aus, daß dieser Code erst im nachfolgenden draw()-Event aufgerufen wird; und diese Annahme hatte sich bisher stets bestätigt, obwohl im ctor von ElementBox direkt ein show_all() aufgerufen wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666285192130" ID="ID_1871565379" MODIFIED="1666285218266" TEXT="diese Experimente haben nur ein freistehendes Widget erstellt"/>
|
|
<node CREATED="1666285219022" ID="ID_302141230" MODIFIED="1666285226609" TEXT="und dann sofort angezeigt"/>
|
|
<node CREATED="1666285228583" ID="ID_1205342322" MODIFIED="1666285243030" TEXT="und dann erst durch das nächste Experiment vergrößert oder verkleinert"/>
|
|
<node CREATED="1666285244355" ID="ID_1478837494" MODIFIED="1666285373268" TEXT="insofern waren diese Experimente noch zu vereinfacht...">
|
|
<arrowlink COLOR="#bc8db2" DESTINATION="ID_616953706" ENDARROW="Default" ENDINCLINATION="109;-4;" ID="Arrow_ID_1798465605" STARTARROW="None" STARTINCLINATION="269;13;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665972186386" ID="ID_1077613088" MODIFIED="1666286272226" TEXT="per Debugger zu untersuchen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1666053399781" ID="ID_1669190642" MODIFIED="1666053539901" TEXT="schwierig....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...kann nicht recht erkennen, woher der call kommt.
|
|
</p>
|
|
<p>
|
|
Klar ist nur, die Objekte sind schon konstruiert aber die neue Timeline noch nicht angezeigt; genauer kann man sogar sagen, der Fehler tritt erst auf, wenn das GUI sichtbar werden soll, denn wenn ich sofort in den Konstruktoren Breakpoints setze, und damit dann zum Eclipse-Fenster wechsle, tritt die AssertionFailure nicht auf, solange bis man dem Lumiera-Fenster wieder den Fokus gibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666284884372" ID="ID_1055383793" MODIFIED="1666285096886">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
liegt an der <i>inkrementellen Natur</i> der Layout-Zuteilung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666284904368" ID="ID_1996100999" MODIFIED="1666284943639" TEXT="nach Erstellen der Clips liegen mehrere Events in der Queue"/>
|
|
<node CREATED="1666284945010" ID="ID_1390825899" MODIFIED="1666285354320" TEXT="das folgt aus dem schrittweisen Aufspielen des Diff...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1666284979905" ID="ID_435939391" MODIFIED="1666284988311" TEXT="der Diff wird auf Einmal gesendet"/>
|
|
<node CREATED="1666284988711" ID="ID_1944889144" MODIFIED="1666284996640" TEXT="und auch auf Einmal in den UI-Thread zugestellt"/>
|
|
<node CREATED="1666284997558" ID="ID_929855789" MODIFIED="1666285046065" TEXT="aber das Anwenden estellt erst halb-leere Container"/>
|
|
<node CREATED="1666285046869" ID="ID_925433658" MODIFIED="1666285057773" TEXT="setzt dann Zeiten und Namen"/>
|
|
<node CREATED="1666285058499" ID="ID_1175866676" MODIFIED="1666285084060">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und danach feuert der <i>StructuralChange</i>-Listener
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666285269465" ID="ID_616953706" MODIFIED="1666285373268" TEXT="⟹ Konsequenz: draw-Events gefolgt von mehreren resize-Events">
|
|
<linktarget COLOR="#bc8db2" DESTINATION="ID_616953706" ENDARROW="Default" ENDINCLINATION="109;-4;" ID="Arrow_ID_1798465605" SOURCE="ID_1478837494" STARTARROW="None" STARTINCLINATION="269;13;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666286169242" ID="ID_1143284469" MODIFIED="1666286222589" TEXT="Einschränkung kann wegfallen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1666286191972" ID="ID_616576732" MODIFIED="1666286216556" TEXT="ASSERTION gar nicht notwendig">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1666286198651" ID="ID_513481742" MODIFIED="1666286219025" TEXT="der Code funktioniert nämlich auch im halb-realisierten Zustand">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1666286233294" ID="ID_1774329269" MODIFIED="1666286266184" TEXT="visible ⟹ liefert Größe | not visible ⟹ Größe = 0">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666286511402" FOLDED="true" ID="ID_901100748" MODIFIED="1666308082637" TEXT="Constraint-handling versagt u.U für das Label">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1666286569009" ID="ID_571211770" MODIFIED="1666367130923" TEXT="Beispiel: Clip-1 : Duration 1s">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1666286612844" ID="ID_1960027917" MODIFIED="1666286659485" TEXT="die Icons werden ausgeblendet">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1666286619572" ID="ID_111104208" MODIFIED="1666286649529" TEXT="aber das Text-Label ist sichtbar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1666286629675" ID="ID_178314716" MODIFIED="1666286646133" TEXT="und der Text schreibt über das Ende hinaus">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666286588511" ID="ID_1014622465" MODIFIED="1666308061322" TEXT="Untersuchung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1666307200947" ID="ID_712219112" MODIFIED="1666307460841" TEXT="Verdacht: setCaption() manipuliert visibility">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1666307233042" ID="ID_1411306141" MODIFIED="1666307262873" TEXT="...und würde dadurch das differenzierte, partielle Verbergen stören"/>
|
|
<node CREATED="1666307264414" ID="ID_594632089" MODIFIED="1666307445275" TEXT="⟹ sollte den tatsächlichen visibility-Status wiederherstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nach dem Setzen eines neuen Label-Texts müssen wir die Länge des IDLabel erneut ausmessen, und dazu müssen alle seine Komponenten vorrübergehend visible() gesetzt werden; hatte bisher darauf gesetzt, daß der size-constraint-Algo dann von selber wieder auf den richtigen Status kommt...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666307446440" ID="ID_165108662" MODIFIED="1666307458008" TEXT="aber das bewirkt rein gar nix">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1666307466288" ID="ID_1621773970" MODIFIED="1666307492593" TEXT="Hilfe... was passiert hier — Kontrollverlust">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1666307500030" ID="ID_999771663" MODIFIED="1666307518501" TEXT="alle Caption-Setter auskommentiert"/>
|
|
<node CREATED="1666307519219" ID="ID_757987414" MODIFIED="1666307528695" TEXT="der komische Text ist immer noch da"/>
|
|
<node CREATED="1666307529508" ID="ID_990701944" MODIFIED="1666307578878" TEXT="und auch der Size-Constraint ist sonderbar(falsch)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Höhe nur 16px, obwohl doch das Icon mindestens 18px braucht (incl.Border), und das get_required_height() diesen Wert eigentlich liefern sollte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#db10ad" CREATED="1666307585634" ID="ID_1666781450" MODIFIED="1666307620469" TEXT="AUA!!">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1666307623237" ID="ID_1740179483" MODIFIED="1666307643118" TEXT="ClipWidget ruft immer noch Frame::set_label() auf"/>
|
|
<node CREATED="1666307644363" ID="ID_1158991887" MODIFIED="1666307653429" TEXT="ja in der Tat, die Funktion ist noch sichtbar"/>
|
|
<node CREATED="1666307654257" ID="ID_662041930" MODIFIED="1666307709729" TEXT="sie schießt unser tolles Custom IDLabel ins Nirvana">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und schaltet den Frame wieder zurück auf ein Text-Label, das natürlich dann in keinster Weise der size-Constraint-Kontrolle unterliegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666308020848" ID="ID_1559858341" MODIFIED="1666308033677" TEXT="puh das war aber gut versteckt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666308048044" ID="ID_1668793880" MODIFIED="1666308056987" TEXT="dann besser diese Setter überdecken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666308065995" ID="ID_1843697802" MODIFIED="1666308081223" TEXT="Fazit: hat gar nicht versagt...">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666286684491" FOLDED="true" ID="ID_825575865" MODIFIED="1666367282400" TEXT="Clip-Dragging funktioniert nur eingeschränkt">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1666286711357" ID="ID_118648001" MODIFIED="1666286724325" TEXT="wohl ein Event-Handling-Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666286731340" ID="ID_306299052" MODIFIED="1666367153546" TEXT="Dragging auf den Container spricht überhaupt nicht an">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1666286814794" ID="ID_507527806" MODIFIED="1666367151520" TEXT="anscheinend wird der Event-Handler gar nicht aufgerufen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...den eingebauten Debug-Meldungen zufolge zu urteilen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1666313907945" ID="ID_2075291" MODIFIED="1666314192593" TEXT="man muß da wohl erst etwas einrichten">
|
|
<arrowlink COLOR="#7788e0" DESTINATION="ID_775914278" ENDARROW="Default" ENDINCLINATION="-1021;-87;" ID="Arrow_ID_632223489" STARTARROW="None" STARTINCLINATION="-1049;77;"/>
|
|
<node CREATED="1666315741368" ID="ID_581715301" MODIFIED="1666315759423" TEXT="und die Voraussetzung: man braucht ein zugeordnetes GdkWindow"/>
|
|
<node CREATED="1666315760552" ID="ID_491760379" MODIFIED="1666315831393" TEXT="Diagnose: Gtk::Frame hat kein Window">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
get_has_window()  ➔ <font face="Monospaced" color="#6c13de">false</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666316633184" ID="ID_387720838" MODIFIED="1666367275837" TEXT="⟹ Konsequenz: EventBox im ElementBoxWidget fest einrichten">
|
|
<arrowlink COLOR="#526674" DESTINATION="ID_519294969" ENDARROW="Default" ENDINCLINATION="1268;576;" ID="Arrow_ID_860609088" STARTARROW="None" STARTINCLINATION="-1409;-62;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1666286786740" ID="ID_100457080" MODIFIED="1666286890547" TEXT="Dragging auf die Buttons nur mit mittlerer/rechter Maustaste">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1666286833126" ID="ID_645351939" MODIFIED="1666286935400" TEXT="bei Links-Klick spricht der Event-Handler gar nicht an">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1666286902148" ID="ID_716610692" MODIFIED="1666286932721" TEXT="das ist aber genau so korrekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
per default greift sich ein Button ja den links-Klick, und das soll auch so sein!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666367167006" ID="ID_314408274" MODIFIED="1666367197804" TEXT="allein das Einführen der Gtk::EventBox hat dieses Problem komplett und sauber gelöst">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666452411624" ID="ID_998825618" MODIFIED="1675897301157" TEXT="Display-Metrik im TimelineLayout verankern">
|
|
<arrowlink COLOR="#525d93" DESTINATION="ID_1827001710" ENDARROW="Default" ENDINCLINATION="873;-869;" ID="Arrow_ID_892468806" STARTARROW="None" STARTINCLINATION="-1738;113;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666367210627" ID="ID_922603771" MODIFIED="1666367245412" TEXT="Umstellung erfolgreich">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1666367222167" ID="ID_130129636" MODIFIED="1666367225553" TEXT="sieht sauber aus"/>
|
|
<node CREATED="1666367226358" ID="ID_967912847" MODIFIED="1666367235416" TEXT="reagiert korrekt auf Längenbeschränkung"/>
|
|
<node CREATED="1666367236236" ID="ID_1153020202" MODIFIED="1666367243679" TEXT="erzeugt keinerlei Assertions mehr"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661695361415" ID="ID_1615822639" MODIFIED="1661695374805" TEXT="Integration mit Pop-up-Menü/Framework">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666369999741" ID="ID_1289871763" MODIFIED="1666370009341" TEXT="weiter ausbauen...">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1666370017462" ID="ID_1120283579" MODIFIED="1666370022975" TEXT="CSS-Styles steuern">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1666370024371" ID="ID_1853406335" MODIFIED="1666370067320" TEXT="definierte CSS-Selektoren">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1664669909170" HGAP="54" ID="ID_353257786" MODIFIED="1664670075595" TEXT="frame#element.elementbox" VSHIFT="-10">
|
|
<edge COLOR="#493d57" STYLE="linear"/>
|
|
<node CREATED="1664670077106" ID="ID_23637100" MODIFIED="1664670080590" TEXT="box#idlabel">
|
|
<node CREATED="1664670436370" ID="ID_169682858" MODIFIED="1664670440905" TEXT=".idlabel"/>
|
|
<node CREATED="1664671305061" ID="ID_1650353361" MODIFIED="1664671309328" TEXT="Kinder...">
|
|
<node CREATED="1664671310329" ID="ID_96245401" MODIFIED="1664671312682" TEXT=".idlabel__icon"/>
|
|
<node CREATED="1664671313875" ID="ID_858160172" MODIFIED="1664671319782" TEXT=".idlabel__menu"/>
|
|
<node CREATED="1664671320674" ID="ID_19239170" MODIFIED="1664671325085" TEXT=".idlabel__name"/>
|
|
</node>
|
|
<node CREATED="1664670133617" ID="ID_1907146399" MODIFIED="1664670140958" TEXT=".elementbox__idlabel">
|
|
<node CREATED="1664670252291" ID="ID_423384579" MODIFIED="1664670271427" TEXT="Achtung: nur wenn in einer ElementBox">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664670174435" ID="ID_54680565" MODIFIED="1664670179225" TEXT="zusätzlich...">
|
|
<node CREATED="1664670194762" ID="ID_1459999893" MODIFIED="1664670202630" TEXT=".elementbox--video"/>
|
|
<node CREATED="1664670203554" ID="ID_471735544" MODIFIED="1664670210996" TEXT=".elementbox--audio"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480639267600" ID="ID_671046048" MODIFIED="1557498707223" TEXT="Clip"/>
|
|
<node CREATED="1480639365715" ID="ID_743867283" MODIFIED="1557498707223" TEXT="Bin"/>
|
|
</node>
|
|
<node CREATED="1480639327169" HGAP="36" ID="ID_700485676" MODIFIED="1557498707223" TEXT="Root" VSHIFT="-2">
|
|
<linktarget COLOR="#3b4877" DESTINATION="ID_700485676" ENDARROW="Default" ENDINCLINATION="430;-874;" ID="Arrow_ID_454081114" SOURCE="ID_362749694" STARTARROW="Default" STARTINCLINATION="-170;534;"/>
|
|
<node CREATED="1504459308239" HGAP="47" ID="ID_247672235" MODIFIED="1557498707223" TEXT="Assets" VSHIFT="-26">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1504459300720" ID="ID_1860702149" MODIFIED="1557498707223" TEXT="Einstellungen"/>
|
|
<node CREATED="1504459315798" ID="ID_888900532" MODIFIED="1557498707223" TEXT="Zugang zum Model">
|
|
<arrowlink COLOR="#3c5879" DESTINATION="ID_1847844548" ENDARROW="Default" ENDINCLINATION="-41;-263;" ID="Arrow_ID_1586720666" STARTARROW="None" STARTINCLINATION="41;-1;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1476376913589" HGAP="42" ID="ID_1887326939" MODIFIED="1557498707223" TEXT="Timeline" VSHIFT="-17">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1477599995452" FOLDED="true" HGAP="10" ID="ID_97568136" MODIFIED="1557498707223" TEXT="Bestandteile" VSHIFT="-4">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1476377043180" ID="ID_1179709828" MODIFIED="1557498707223" TEXT="Head">
|
|
<node CREATED="1476377067729" ID="ID_896843893" MODIFIED="1557498707223" TEXT="Patchbay"/>
|
|
<node CREATED="1476377071072" ID="ID_745594295" MODIFIED="1557498707223" TEXT="in-sync with body"/>
|
|
</node>
|
|
<node CREATED="1476377048043" ID="ID_994927647" MODIFIED="1557498707223" TEXT="Body">
|
|
<node CREATED="1476377078839" ID="ID_331565543" MODIFIED="1557498707223" TEXT="the Fork">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1476377087942" ID="ID_26794000" MODIFIED="1557498707223" TEXT="expandable"/>
|
|
</node>
|
|
<node CREATED="1476377059386" ID="ID_363001687" MODIFIED="1557498707223" TEXT="Control">
|
|
<node CREATED="1476377117290" ID="ID_179386424" MODIFIED="1557498707223" TEXT="scolling"/>
|
|
<node CREATED="1480694668090" ID="ID_792729651" MODIFIED="1557498707223" TEXT="TimelineWidget">
|
|
<node CREATED="1480694675624" ID="ID_1512443419" MODIFIED="1557498707223" TEXT="Einstiegspunkt"/>
|
|
<node CREATED="1480694679232" ID="ID_1344733448" MODIFIED="1557498707223">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sets für <b>eine feste</b> session::Timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480694854057" HGAP="32" ID="ID_577309407" MODIFIED="1557498707223" TEXT="TimelinePane" VSHIFT="7">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694860696" ID="ID_1847844548" MODIFIED="1557498707223" TEXT="hängt am Model-Root">
|
|
<linktarget COLOR="#5d6386" DESTINATION="ID_1847844548" ENDARROW="Default" ENDINCLINATION="35;-168;" ID="Arrow_ID_1483178089" SOURCE="ID_827558797" STARTARROW="Default" STARTINCLINATION="-2;95;"/>
|
|
<linktarget COLOR="#3c5879" DESTINATION="ID_1847844548" ENDARROW="Default" ENDINCLINATION="-41;-263;" ID="Arrow_ID_1586720666" SOURCE="ID_888900532" STARTARROW="None" STARTINCLINATION="41;-1;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1504459404130" ID="ID_1800175742" MODIFIED="1557498707223" TEXT="InteractionDirector verwaltet Platzhalter"/>
|
|
<node CREATED="1504459419584" ID="ID_1339072222" MODIFIED="1557498707223" TEXT="in der TimelinePane leben die zugehörigen Widgets"/>
|
|
<node CREATED="1504459462330" ID="ID_791513915" MODIFIED="1557498707223">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verwaltung <i>autmatisch</i> via ViewLocator -> PanelLocator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480694897443" ID="ID_402490324" MODIFIED="1557498707223" TEXT="verwaltet die Timelines"/>
|
|
<node CREATED="1480694918056" ID="ID_789731200" MODIFIED="1557498707223">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt eine <i>EmptyTimeline</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1480694930990" ID="ID_1289595423" MODIFIED="1557498707223" TEXT="interface == Widget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480694624879" HGAP="37" ID="ID_1678741068" MODIFIED="1557498707223" TEXT="TimelineController" VSHIFT="21">
|
|
<node CREATED="1480694630302" ID="ID_10965216" MODIFIED="1557498707223" TEXT="hat das Sagen"/>
|
|
<node CREATED="1480694652219" ID="ID_1232910852" MODIFIED="1557498707223" TEXT="Widget wird passiv"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477600006370" FOLDED="true" ID="ID_1328755612" MODIFIED="1557498707223" TEXT="Konzept">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1504387810549" ID="ID_599967369" MODIFIED="1557498707223" TEXT="Identität">
|
|
<node CREATED="1504387825051" ID="ID_281718898" MODIFIED="1557498707223" TEXT="eine View pro Model-Komponente"/>
|
|
<node CREATED="1504387834601" ID="ID_798058080" MODIFIED="1557498707223" TEXT="Slave-Views kaskadiert">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504387844840" ID="ID_1591380172" MODIFIED="1557498707223" TEXT="TimelineView verwaltet eigene Sklaven"/>
|
|
<node CREATED="1504387856919" ID="ID_198003145" MODIFIED="1557498707224" TEXT="nach außen hin transparent"/>
|
|
<node CREATED="1504387865853" ID="ID_519067212" MODIFIED="1557498707224" TEXT="delegiert automatisch"/>
|
|
</node>
|
|
<node CREATED="1504387896417" ID="ID_1112793361" MODIFIED="1557498707224" TEXT="EntryID<Timeline>"/>
|
|
</node>
|
|
<node CREATED="1477600020776" ID="ID_955842824" MODIFIED="1557498707224" TEXT="Einteilung"/>
|
|
<node CREATED="1477600027128" ID="ID_1592196047" MODIFIED="1557498707224" TEXT="Handhabung">
|
|
<node CREATED="1477600041886" ID="ID_1241593972" MODIFIED="1557498707224" TEXT="User"/>
|
|
<node CREATED="1477600044069" ID="ID_217967290" MODIFIED="1557498707224" TEXT="technisch">
|
|
<node COLOR="#435e98" CREATED="1477600126514" ID="ID_1433799303" MODIFIED="1561827465248" TEXT="grundsätzlich....">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477600134217" ID="ID_1352260964" MODIFIED="1576282358100" TEXT="wie viel selber machen?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Frage ist, wie viel des Verhaltens programmieren wir selber explizit aus,
|
|
</p>
|
|
<p>
|
|
und welchen Teil des Verhaltens überlassen wir GTK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1477600216950" ID="ID_1935952349" MODIFIED="1518487921079" TEXT="focus">
|
|
<node CREATED="1477600231756" ID="ID_1744616929" MODIFIED="1518487921079" TEXT="Tabbing">
|
|
<node CREATED="1477600258865" ID="ID_112614309" MODIFIED="1518487921079" TEXT="GTK überlassen">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1477600275118" ID="ID_1701392398" MODIFIED="1518487921079" TEXT="Ordnung explizit setzen">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1477600285685" ID="ID_195435447" MODIFIED="1518487921079" TEXT="effektiv unterbinden">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477600234036" ID="ID_957445675" MODIFIED="1518487921079" TEXT="Navigation">
|
|
<node CREATED="1477600335934" ID="ID_1021991791" MODIFIED="1518487921079" TEXT="räumliche Metapher"/>
|
|
<node CREATED="1477600353036" ID="ID_529949426" MODIFIED="1518487921079" TEXT="brauche Orts-Repräsentation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477600385264" ID="ID_734925174" MODIFIED="1518487921079" TEXT="Darstellung">
|
|
<node CREATED="1477600397934" ID="ID_224014088" MODIFIED="1518487921079" TEXT="GTK alles geben">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1477600402110" ID="ID_375405149" MODIFIED="1518487921079" TEXT="nur eine aktuelle Auswahl">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541858017069" HGAP="7" ID="ID_1165638730" MODIFIED="1541858026121" TEXT="Fazit" VSHIFT="5">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1541858031423" ID="ID_1183173385" MODIFIED="1576282358100">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Standard</i> UI-Mechanik überlassen wir GTK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das heißt, wir betreiben ggfs sogar erheblichen Aufwand,
|
|
</p>
|
|
<p>
|
|
um Standard-Mechanik auch über die Standard-Mechanismen abzubilden.
|
|
</p>
|
|
<p>
|
|
Aus Gründen der Konsistenz und Zukunftsfähigkeit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1541858088132" ID="ID_303565989" MODIFIED="1576282358099">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unser <b>InteractionControl</b> ist eine Zwischenschicht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
InteractionControl
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
ist ein eigenständiges Framework in der Obhut des InteractionDirector
|
|
</li>
|
|
<li>
|
|
lauscht und empfängt die Benutzer-Events zweiten Grades (nicht absolut low-level Pixel und Mausbewegung)
|
|
</li>
|
|
<li>
|
|
erzeugt Trigger, auf die die normale UI-Mechanik reagiert (z.B. setzt den Fokus, scrollt)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1477600431489" ID="ID_741336406" MODIFIED="1561827465248" TEXT="gtk::Layout">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1477600442792" ID="ID_143840935" MODIFIED="1518487921079" TEXT="ist das offizielle Canvas-Control"/>
|
|
<node CREATED="1477600450463" ID="ID_293636936" MODIFIED="1518487921079" TEXT="scheint sehr mächtig"/>
|
|
<node CREATED="1477600454470" ID="ID_1255426760" MODIFIED="1518487921079" TEXT="ist ein gtk::Container"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1479678484210" FOLDED="true" ID="ID_1561971595" MODIFIED="1557498707224" TEXT="Struktur">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1479678496272" ID="ID_807567871" LINK="file:///home/hiv/devel/lumi/wiki/renderengine.html#GuiTimelineWidgetStructure" MODIFIED="1557498707224" TEXT="Analyse">
|
|
<node CREATED="1479678503071" ID="ID_806149006" MODIFIED="1576282358098" TEXT="Grid bringt nix">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das war zwar schon meine Bauchgefühl,
|
|
</p>
|
|
<p>
|
|
habe aber sicherheitshalber diese Analyse nochmal gemacht.
|
|
</p>
|
|
<p>
|
|
Details im  TiddlyWiki....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1479678634213" ID="ID_432405176" MODIFIED="1557498707224" TEXT="rekursive Struktur schaffen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1479678509822" ID="ID_915690336" MODIFIED="1557498707224" TEXT="Scrolling ist notwendig speziell"/>
|
|
<node CREATED="1479678717961" ID="ID_946163885" MODIFIED="1666448945214" TEXT="ist ein top-Level-Widget">
|
|
<node CREATED="1479678723576" ID="ID_666987913" MODIFIED="1557498707224" TEXT="Layout Grundmuster: zweigeteilt"/>
|
|
<node CREATED="1479678736655" ID="ID_1313901406" MODIFIED="1666449894104" TEXT="Service-Interface: DisplayManager">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1666449011536" ID="ID_1899624895" MODIFIED="1666449022436" TEXT="gesteuert vom TimelineController"/>
|
|
<node CREATED="1666448989358" ID="ID_975440536" MODIFIED="1666450191353" TEXT="Hintergrund-Implementierung: TimelineLayout">
|
|
<arrowlink COLOR="#4c445e" DESTINATION="ID_426582453" ENDARROW="Default" ENDINCLINATION="-16;-29;" ID="Arrow_ID_1677833273" STARTARROW="None" STARTINCLINATION="-80;5;"/>
|
|
</node>
|
|
<node CREATED="1666449028556" ID="ID_1698685222" MODIFIED="1666449045090" TEXT="Koordiniert die Anzeige für die ganze TimelinePane"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1666449046546" ID="ID_1275285489" MODIFIED="1666449073667" TEXT="(davon kann es aber mehrere geben)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also bitte nicht mit statischen Globals arbeiten!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480723110777" HGAP="24" ID="ID_1197860604" MODIFIED="1679088318143" TEXT="Kontrollstruktur" VSHIFT="7">
|
|
<icon BUILTIN="pencil"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1480723136861" ID="ID_839909208" MODIFIED="1561151251774" TEXT="Einstiegspunkt">
|
|
<arrowlink COLOR="#8d8ba5" DESTINATION="ID_1295897045" ENDARROW="Default" ENDINCLINATION="534;-456;" ID="Arrow_ID_150397161" STARTARROW="None" STARTINCLINATION="440;114;"/>
|
|
<node CREATED="1666449980712" ID="ID_1809581731" MODIFIED="1666450343013" TEXT="TimelinePane erzeugt...">
|
|
<arrowlink COLOR="#3f3a50" DESTINATION="ID_420419439" ENDARROW="Default" ENDINCLINATION="-47;-3;" ID="Arrow_ID_970542864" STARTARROW="None" STARTINCLINATION="-37;0;"/>
|
|
</node>
|
|
<node CREATED="1480723144188" HGAP="31" ID="ID_420419439" MODIFIED="1666450343013" TEXT="TimelineWidget" VSHIFT="10">
|
|
<linktarget COLOR="#3f3a50" DESTINATION="ID_420419439" ENDARROW="Default" ENDINCLINATION="-47;-3;" ID="Arrow_ID_970542864" SOURCE="ID_1809581731" STARTARROW="None" STARTINCLINATION="-37;0;"/>
|
|
<node CREATED="1666450105721" ID="ID_426582453" MODIFIED="1666450189897" TEXT="unique-ptr ➔ TimelineLayout">
|
|
<linktarget COLOR="#4c445e" DESTINATION="ID_426582453" ENDARROW="Default" ENDINCLINATION="-16;-29;" ID="Arrow_ID_1677833273" SOURCE="ID_975440536" STARTARROW="None" STARTINCLINATION="-80;5;"/>
|
|
</node>
|
|
<node CREATED="1666450198571" ID="ID_24486297" MODIFIED="1666450207211" TEXT="unique-ptr ➔ TimelineController">
|
|
<node CREATED="1666450210672" ID="ID_1592122110" MODIFIED="1666450285747" TEXT="≙Tangible"/>
|
|
<node CREATED="1666450215299" ID="ID_989517522" MODIFIED="1666450222555" TEXT="hällt Sub-Collections">
|
|
<node CREATED="1666450231766" ID="ID_1034848356" MODIFIED="1666450235961" TEXT="markers_"/>
|
|
<node CREATED="1666450236790" ID="ID_1918436254" MODIFIED="1666450269863" TEXT="fork_ (≔Tracks)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480723200765" ID="ID_1498754065" MODIFIED="1557498707224" TEXT="aktiv">
|
|
<node CREATED="1480723223938" ID="ID_1057816659" MODIFIED="1557498707224" TEXT="UI-Mechanik">
|
|
<node CREATED="1480723246207" ID="ID_988556037" MODIFIED="1557498707224" TEXT="Scrollen"/>
|
|
<node CREATED="1480723270492" ID="ID_1057899601" MODIFIED="1557498707224" TEXT="Zoomen"/>
|
|
<node CREATED="1480723288521" ID="ID_238022948" MODIFIED="1557498707224" TEXT="Navigieren">
|
|
<node CREATED="1480723291697" ID="ID_486282572" MODIFIED="1557498707224" TEXT="delegiert"/>
|
|
<node CREATED="1480723296128" ID="ID_681787776" MODIFIED="1557498707224" TEXT="timeline::NavigatorWidget"/>
|
|
</node>
|
|
<node CREATED="1480723797453" ID="ID_451406554" MODIFIED="1557498707224" TEXT="Benachrichtigungen"/>
|
|
</node>
|
|
<node CREATED="1480723989315" ID="ID_1314277524" MODIFIED="1557498707224" TEXT="zentral">
|
|
<node CREATED="1480724166868" ID="ID_1338884424" MODIFIED="1557498707224" TEXT="Strukturänderung">
|
|
<node CREATED="1480724385214" ID="ID_1913904871" MODIFIED="1557498707224" TEXT="DiffMutable bieten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480724171371" ID="ID_410013238" MODIFIED="1557498707224" TEXT="Strukturänderung vorbereiten">
|
|
<node CREATED="1480724215437" ID="ID_1953691654" MODIFIED="1557498707224" TEXT="Kontextmenü"/>
|
|
<node CREATED="1480724317120" ID="ID_1898649980" MODIFIED="1557498707224" TEXT="Fokus + Befehl / Taste"/>
|
|
<node CREATED="1480724346548" ID="ID_200646693" MODIFIED="1557498707224" TEXT="markieren + Kommando schicken">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480724417722" HGAP="55" ID="ID_940232384" MODIFIED="1557498707224" TEXT="drei Möglichkeiten" VSHIFT="5">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1480724450958" FOLDED="true" ID="ID_493402962" MODIFIED="1561827465249" TEXT="Widget is Tangible">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1480724706739" ID="ID_1043502336" MODIFIED="1518487921080" TEXT="kann dann direkt Notifications implementieren"/>
|
|
<node CREATED="1480724724585" ID="ID_576219568" MODIFIED="1518487921080" TEXT="muß für alle Strukturänderungen delegieren"/>
|
|
<node CREATED="1480724738583" ID="ID_403933116" MODIFIED="1518487921080" TEXT="Achtung: Tangible is noncopyable">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1480724761876" ID="ID_335451126" MODIFIED="1576282358098" TEXT="wegen BusTerm">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
braucht feste Speicher-Addresse
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480724781801" ID="ID_198046255" MODIFIED="1518487921080" TEXT="folglich: nicht in STL-Container">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480724461860" ID="ID_865875607" MODIFIED="1561827465249" TEXT="Controller is Tangible">
|
|
<linktarget COLOR="#1017b1" DESTINATION="ID_865875607" ENDARROW="Default" ENDINCLINATION="-67;4;" ID="Arrow_ID_1321400081" SOURCE="ID_1683703083" STARTARROW="Default" STARTINCLINATION="-78;4;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1480724851312" ID="ID_1653680733" MODIFIED="1576282358097" TEXT="erzeugt Rückbezug für Notifications">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
..d.h. der Controller muß wieder auf das Widget zugreifen
|
|
</p>
|
|
<p>
|
|
und sei es auch bloß über ein Interface!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480724910096" ID="ID_874781354" MODIFIED="1518487921080" TEXT="kann direkt das View-Modell manipulieren"/>
|
|
<node CREATED="1480724927814" ID="ID_1912287440" MODIFIED="1518487921080" TEXT="ist nicht direkt erreichbar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1480724935397" ID="ID_1279073903" MODIFIED="1518487921080" TEXT="Modell-Vater muß DiffMutable sehen">
|
|
<arrowlink COLOR="#2817aa" DESTINATION="ID_550796340" ENDARROW="Default" ENDINCLINATION="129;0;" ID="Arrow_ID_1199115828" STARTARROW="None" STARTINCLINATION="129;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480724468283" ID="ID_1683703083" MODIFIED="1561827465250" TEXT="expose DiffMutable">
|
|
<arrowlink COLOR="#1017b1" DESTINATION="ID_865875607" ENDARROW="Default" ENDINCLINATION="-67;4;" ID="Arrow_ID_1321400081" STARTARROW="Default" STARTINCLINATION="-78;4;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1480724983774" ID="ID_845297603" MODIFIED="1518487921080" TEXT="heißt: Manipulation außerhalb des Diff-Systems"/>
|
|
<node CREATED="1480725000029" ID="ID_1586514211" MODIFIED="1518487921080" TEXT="wir steigen stets auf Ebene einer Timeline ein"/>
|
|
<node CREATED="1480725012731" ID="ID_9332776" MODIFIED="1576282358097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>aber:</i> Binding im Diff-System durchaus möglich
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn:
|
|
</p>
|
|
<p>
|
|
das Diff-System verlangt nicht, daß Kinder in der Collection auch Tangible sind.
|
|
</p>
|
|
<p>
|
|
Es verlangt nur
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
daß wir wissen, wie wir Kinder machen
|
|
</li>
|
|
<li>
|
|
daß wir für ein gegebenes Kind ein DiffMutable beschaffen können
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1480725106478" ID="ID_550796340" MODIFIED="1518487921080" TEXT="effektiv auch die Lösung für Alternative-2">
|
|
<linktarget COLOR="#2817aa" DESTINATION="ID_550796340" ENDARROW="Default" ENDINCLINATION="129;0;" ID="Arrow_ID_1199115828" SOURCE="ID_1279073903" STARTARROW="None" STARTINCLINATION="129;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569711492828" HGAP="32" ID="ID_1144480887" MODIFIED="1569711513200" TEXT="Zustands- und Darstellungs-Steuerung" VSHIFT="-15">
|
|
<node CREATED="1569711514311" ID="ID_966535115" MODIFIED="1569711525152" TEXT="kniffeliges strukturelles Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1569711527039" ID="ID_492957941" MODIFIED="1569711539256" TEXT="Zustand wird lokal, in den Widgets verwaltet"/>
|
|
<node CREATED="1569711540189" ID="ID_1641306694" MODIFIED="1576282358096" TEXT="diese brauchen jedoch Zugang zu zentralen Strukuren, speziell für die Präsentation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wichtigstes Beispiel: wir verwenden einen gemeinsamen <b>Canvas</b>  (Gtk::Layout) zur Darstellung.
|
|
</p>
|
|
<p>
|
|
Das bedeutet: viele Kind-Widgets werden auf diesem Canvas platziert und müssen daher mit ihm interagieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569711684335" HGAP="68" ID="ID_1964864197" MODIFIED="1666448072593" VSHIFT="2">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verwende eine <b>Beziehungs-Entität</b>
|
|
</p>
|
|
<p>
|
|
  <font face="Monospaced" color="#1528ca">ViewHook  </font><font face="SansSerif" color="#1528ca"> ⁐ </font><font face="Monospaced" color="#1528ca">  CanvasHook</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_465735263" SOURCE="ID_27191288" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<linktarget COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_756780463" SOURCE="ID_1246108677" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<linktarget COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_992148976" SOURCE="ID_1031858777" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<node CREATED="1569796860718" ID="ID_1579412894" MODIFIED="1569796865185" TEXT="Eigenschaften">
|
|
<node CREATED="1569796881999" ID="ID_1495741440" MODIFIED="1569796893280" TEXT="ist nie leer"/>
|
|
<node CREATED="1569796899453" ID="ID_665830244" MODIFIED="1569797486161" TEXT="hat eine eindeutige Identität (übertragbar, aber nicht duplizierbar)"/>
|
|
<node CREATED="1569796925567" ID="ID_737561546" MODIFIED="1569796955277" TEXT="wird erzeugt durch "Einfügen" eines Elementes in die Anzeige"/>
|
|
<node CREATED="1569796959970" ID="ID_894452722" MODIFIED="1573241985243" STYLE="fork" TEXT="beim Zerstören "entfernt" es dieses Element aus der Anzeige"/>
|
|
<node CREATED="1569797018132" ID="ID_609962345" MODIFIED="1573241988838" STYLE="fork" TEXT="während der Lebensdauer erlaubt es dieses Element in der Anzeige zu repositionieren"/>
|
|
<node CREATED="1569797689767" ID="ID_454948151" MODIFIED="1576282358096" STYLE="fork" TEXT="kann Kind-ViewHooked relativ zum platzierten Element erzeugen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. das durch dieses ViewHooked eingefügte Element definiert auch ein lokales Koordinatensystem.
|
|
</p>
|
|
<p>
|
|
Allerdings lebt das erzeugte Kind-ViewHooked danach eigenständig und es gibt keine weitere Beziehung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569798407650" ID="ID_1008276733" MODIFIED="1569798417575" TEXT="Konsequenzen">
|
|
<node CREATED="1569798611601" ID="ID_1075698833" MODIFIED="1569798622052" TEXT="zwei Pointer notwendig">
|
|
<node CREATED="1569798623199" ID="ID_97526784" MODIFIED="1569798641033" TEXT="Rück-Pointer auf die eingefügte Entität"/>
|
|
<node CREATED="1569798642005" ID="ID_463960789" MODIFIED="1569798703836" TEXT="Ziel-Pointer auf den Anzeigerahmen/Canvas"/>
|
|
</node>
|
|
<node CREATED="1569799685975" ID="ID_1899453702" MODIFIED="1569799698129" TEXT="zunächst einmal ziemlich festgelegt">
|
|
<node CREATED="1569799719906" ID="ID_201546085" MODIFIED="1576282358095" TEXT="Lambdas würden einen Ziel-Pointer pro Lambda erfordern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Erläuterung: man könnte auf die Idee kommen, die vier notwendigen Operationen auf dem Ziel durch Lambdas zu verkapseln. Wenn man dann aber nicht aufpaßt, resultiert das in einer Closure für jedes dieser vier Lamdas, und diese Closure hält zumindest einen Pointer auf das Zielobjekt. <i>Der Vorteil eines solchen Ansatzes </i>wäre natürlich, daß der konkrete Typ von Quelle und Ziel aus der Definition des ViewHook verschwindet (allerdings auch nur, wenn diese Lambdas in std::function-Objekte gewickelt sind)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1569800105842" ID="ID_403274133" MODIFIED="1569800125569" TEXT="wünschenswert wäre, den konkreten Zieltyp zu entkoppeln"/>
|
|
<node CREATED="1569800749930" ID="ID_1631103689" MODIFIED="1576282358094" TEXT="wünschenswer wäre aber auch Quer-Beweglichkeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
von Element-Typ A nach Element-Typ B...
|
|
</p>
|
|
<p>
|
|
Konkret:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
gegeben ein ViewHook<TrackBody>
|
|
</li>
|
|
<li>
|
|
kann ich daraus einen ViewHook<Gtk::Widget> gewinnen?
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#61a5df" DESTINATION="ID_1550703494" ENDARROW="Default" ENDINCLINATION="-180;0;" ID="Arrow_ID_1915156143" STARTARROW="None" STARTINCLINATION="-615;17;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569800892774" ID="ID_513027776" MODIFIED="1569800904118" TEXT="Idee: halb-generisches Design">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1569800905877" ID="ID_49362333" MODIFIED="1569800929374" TEXT="Richtung Ziel(Canvas) wird über ein OO-Interface abstrahiert"/>
|
|
<node CREATED="1569800980203" ID="ID_1663628523" MODIFIED="1569801006667" TEXT="das Element dagegen ist ein Typ-Parameter"/>
|
|
<node CREATED="1569800938265" ID="ID_501232684" MODIFIED="1569800973086" TEXT="die typische Doppelkapsel: Generische Hülle, polymorphe Innereien"/>
|
|
</node>
|
|
<node CREATED="1573744962237" ID="ID_1240251301" MODIFIED="1576282358094" TEXT="»Dreiecks-Anordnung« erscheint sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da der ViewHook schon zwei Pointer zu zwei Entitäten halten muß, kann man Redundanzen vermeiden, indem man ihn <i>an einem dritten Ort</i> anbringt. Nämlich an einem Ort, an dem ohnehin schon eine Dreiecksbeziehung mit diesen beiden Elementen besteht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575579594451" ID="ID_1173527513" MODIFIED="1575579601366" TEXT="Ergebnisse der Analyse">
|
|
<node CREATED="1575579666545" ID="ID_960953308" MODIFIED="1575579689498" TEXT="dekoriert anderweitig bestehende Implementierungs-Strukturen"/>
|
|
<node CREATED="1575579602882" ID="ID_1722144544" MODIFIED="1575579616442" TEXT="dies ist ein generisches Implementierungsschema"/>
|
|
<node CREATED="1575579617408" ID="ID_568101313" MODIFIED="1575579625178" TEXT="bleibt aber nur eine dünne Abstraktion"/>
|
|
<node CREATED="1575579645700" ID="ID_672054447" MODIFIED="1575579701947" TEXT="smart-Handle ist der Kern">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573751565872" ID="ID_274573678" MODIFIED="1582926752028" TEXT="Vertiefte Design-Analyse">
|
|
<linktarget COLOR="#2e1d90" DESTINATION="ID_274573678" ENDARROW="Default" ENDINCLINATION="-1890;235;" ID="Arrow_ID_1905963364" SOURCE="ID_1007243980" STARTARROW="None" STARTINCLINATION="537;68;"/>
|
|
<node CREATED="1575580479206" ID="ID_871786644" MODIFIED="1576282358093" TEXT="Frage: kann das zu einem Konstruktionsschema ausgebaut werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dies wäre dann das Rückgrat in der View-Behandlung in der Timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1573314915266" FOLDED="true" ID="ID_1550703494" MODIFIED="1576797030290" TEXT="Quer-Beweglichkeit zwischen Typen">
|
|
<arrowlink COLOR="#b80305" DESTINATION="ID_912776786" ENDARROW="Default" ENDINCLINATION="-582;30;" ID="Arrow_ID_739783685" STARTARROW="None" STARTINCLINATION="212;897;"/>
|
|
<linktarget COLOR="#61a5df" DESTINATION="ID_1550703494" ENDARROW="Default" ENDINCLINATION="-180;0;" ID="Arrow_ID_1915156143" SOURCE="ID_1631103689" STARTARROW="None" STARTINCLINATION="-615;17;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1573314974409" ID="ID_1458279581" MODIFIED="1573315247762" TEXT="konzeptionelle Erweiterung auf einen douple-Dispatch (?)">
|
|
<linktarget COLOR="#684be4" DESTINATION="ID_1458279581" ENDARROW="Default" ENDINCLINATION="-1681;0;" ID="Arrow_ID_1672277618" SOURCE="ID_1957325688" STARTARROW="None" STARTINCLINATION="788;-76;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1573315038764" ID="ID_343459571" MODIFIED="1573315057034" TEXT="TrackBody -> ClipWidget"/>
|
|
<node CREATED="1573315059821" ID="ID_1755997468" MODIFIED="1575137031097" TEXT="weitere Fälle?">
|
|
<arrowlink COLOR="#3457ce" DESTINATION="ID_1625046942" ENDARROW="Default" ENDINCLINATION="-227;8;" ID="Arrow_ID_534191130" STARTARROW="None" STARTINCLINATION="309;5;"/>
|
|
</node>
|
|
<node CREATED="1575580103422" ID="ID_1611596584" MODIFIED="1575580107429" TEXT="RLY?"/>
|
|
</node>
|
|
<node CREATED="1573315274074" ID="ID_1371762683" MODIFIED="1573315282925" TEXT="ggfs auch Manipulations-Operationen pro Typ">
|
|
<node CREATED="1573315287336" ID="ID_270346811" MODIFIED="1573315294042" TEXT="Widget: auf Canvas repositionieren"/>
|
|
<node CREATED="1573315295318" ID="ID_557973678" MODIFIED="1573935809890" TEXT="TrackBody: Reihenfolge umordnen">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1573935984203" ID="ID_1150598318" MODIFIED="1573936001642" TEXT="TrackHeadWidget: Reihenfolge der Kind-Header">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573937032136" ID="ID_1315004509" MODIFIED="1573937056873" TEXT="des Genaueren: es handelt sich um Vater-Kinder-Manipulation">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1573937096058" ID="ID_1596055753" MODIFIED="1575133301506" TEXT="bisher habe ich das durch eine Konstruktor-Closure gelöst">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Jeder neue TrackPresenter bekommt zur Erzeugung einen Funktor, mit dem sich der von ihm gehaltene DisplayFrame in einen Vater-Kontext "einhäkeln" kann...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#63bcba" DESTINATION="ID_709169542" ENDARROW="Default" ENDINCLINATION="648;-124;" ID="Arrow_ID_1775236750" STARTARROW="None" STARTINCLINATION="661;33;"/>
|
|
</node>
|
|
<node CREATED="1573937269636" ID="ID_1582747384" MODIFIED="1573937284837" TEXT="Analyse: benötigte Operationen">
|
|
<node CREATED="1573937286849" ID="ID_1940401544" MODIFIED="1573937327296" TEXT="neuen Kind-ViewHook einhängen"/>
|
|
<node CREATED="1573937348618" ID="ID_1592677163" MODIFIED="1573937358756" TEXT="(Kind-ViewHook zerstört sich selbst)"/>
|
|
<node CREATED="1573937496810" ID="ID_1178421844" MODIFIED="1573937511202" TEXT="Reihenfolge der Kind-Hooks aktualisieren"/>
|
|
</node>
|
|
<node CREATED="1573937563111" ID="ID_587192425" MODIFIED="1573937570371" TEXT="Kritik: unnötig indirekt">
|
|
<node CREATED="1573937575410" ID="ID_1241025784" MODIFIED="1573937584696" TEXT="direkt würde auch gehen">
|
|
<node CREATED="1573937594363" ID="ID_1916446916" MODIFIED="1573937626786" TEXT="TrackHeadWidget wird unter TrackHeadWidget eingehängt"/>
|
|
<node CREATED="1573937632100" ID="ID_1460511973" MODIFIED="1573937642417" TEXT="TrackBody wird unter TrackBody eingehängt"/>
|
|
<node CREATED="1573937750100" ID="ID_280534075" MODIFIED="1573937761305" TEXT="nur für Clip-Widgets gibt es ein Problem"/>
|
|
</node>
|
|
<node CREATED="1573937803628" ID="ID_1368972121" MODIFIED="1573937832776" TEXT="Schlußfolgerung: es geht um das Strukturieren ohnehin vorhandener Operationen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1573937928747" ID="ID_1387457475" MODIFIED="1573937967254" TEXT="demnach wäre »ViewHookable« bedeutender denn »ViewHook«"/>
|
|
<node CREATED="1573940988387" ID="ID_173071400" MODIFIED="1573941008242" TEXT="was stört an diesem Design?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1573941015368" ID="ID_1975430834" MODIFIED="1573941024610" TEXT="die »move«-Operation">
|
|
<node CREATED="1573941030461" ID="ID_1374594092" MODIFIED="1573941049700" TEXT="sie macht nur Sinn für Widget-an-Canvas"/>
|
|
</node>
|
|
<node CREATED="1573941080479" ID="ID_311245443" MODIFIED="1575240030260" TEXT="generell die Proxy-Rolle von ViewHook">
|
|
<linktarget COLOR="#3f8a72" DESTINATION="ID_311245443" ENDARROW="Default" ENDINCLINATION="693;198;" ID="Arrow_ID_1560507426" SOURCE="ID_1632364154" STARTARROW="None" STARTINCLINATION="647;33;"/>
|
|
<node CREATED="1573941092749" ID="ID_1895119352" MODIFIED="1575055282173" TEXT="auch sie ist notwendig für Widget-an-Canvas"/>
|
|
<node CREATED="1573941102985" ID="ID_463060333" MODIFIED="1573941123933" TEXT="und überflüssig für TrackBody und TrackHeadWidget"/>
|
|
</node>
|
|
<node CREATED="1573944816092" ID="ID_1520827984" MODIFIED="1575057093965" TEXT="könnte man auf diese Design-Elemente verzichten?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wohl ehr nicht, aber sie sind nicht allgemeingültig, das ist das Problem
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573940830088" ID="ID_31747089" MODIFIED="1573941010957" TEXT="wo / wie muß ViewHookable flexibel sein?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575057316383" ID="ID_1565606328" MODIFIED="1575566385152" TEXT="relatives Verankern">
|
|
<linktarget COLOR="#146b9a" DESTINATION="ID_1565606328" ENDARROW="Default" ENDINCLINATION="-218;27;" ID="Arrow_ID_1877360800" SOURCE="ID_827160586" STARTARROW="None" STARTINCLINATION="-76;-196;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1575134071522" ID="ID_1625046942" MODIFIED="1575137022510" TEXT="bekannte Fälle">
|
|
<linktarget COLOR="#3457ce" DESTINATION="ID_1625046942" ENDARROW="Default" ENDINCLINATION="-227;8;" ID="Arrow_ID_534191130" SOURCE="ID_1755997468" STARTARROW="None" STARTINCLINATION="309;5;"/>
|
|
<node CREATED="1575134076354" ID="ID_537930190" MODIFIED="1575134110312" TEXT="TrackHeadWidget in einer Zeile(ViewHook) des Parent-Track"/>
|
|
<node CREATED="1575134130065" ID="ID_552878714" MODIFIED="1575134156106" TEXT="(sub)-TrackBody in dem TrackBody(ViewHook) des Parent-Track"/>
|
|
<node CREATED="1575134170811" ID="ID_987078230" MODIFIED="1575134188948" TEXT="Clip-Widget mit Offset zum TrackBody des zugehörigen Track"/>
|
|
<node CREATED="1575135009974" ID="ID_1814850214" MODIFIED="1575135018550" TEXT="dto für MarkerWidget"/>
|
|
<node CREATED="1575134951065" ID="ID_313036103" MODIFIED="1575134991516" TEXT="Effect-Decorator-Balken relativ zum Clip"/>
|
|
<node CREATED="1575135216791" ID="ID_586238473" MODIFIED="1575135242494" TEXT="alle diese Fälle auch relativ zum Canvas in einem Clip">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575135330291" ID="ID_1582980743" MODIFIED="1575135337718" TEXT="was für eine Operation ist das?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575135994929" ID="ID_512385556" MODIFIED="1575136011161" TEXT="Vorsicht: es geht um ein Kind, nicht um einen Sibling">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1575135436554" ID="ID_1066824862" MODIFIED="1575135450367" TEXT="verankere T relativ zu ViewHook<T>">
|
|
<node CREATED="1575135577727" ID="ID_1869481109" MODIFIED="1575135774534" TEXT="viewHook<T>::viewHookable<T>.getChildHookable(T elm)"/>
|
|
<node CREATED="1575136039163" ID="ID_1481685114" MODIFIED="1575136173596" TEXT="dann: dieses childHookable.hook(T childOfElm)"/>
|
|
</node>
|
|
<node CREATED="1575135837216" ID="ID_374890623" MODIFIED="1575135846257" TEXT="verankere U relativ zu ViewHook<T>">
|
|
<node CREATED="1575135577727" ID="ID_1723372649" MODIFIED="1575136907824" TEXT="viewHook<T>::viewHookable<T>.getChildHookable<U>(T elm)"/>
|
|
<node CREATED="1575136039163" ID="ID_739622730" MODIFIED="1575136816490" TEXT="dann: dieses childHookable.hook(U childOfElm)"/>
|
|
</node>
|
|
<node CREATED="1575137053568" ID="ID_691795394" MODIFIED="1575137136026" TEXT="also: es ist tatsächlich ein (impliziter) double-Dispatch">
|
|
<arrowlink COLOR="#73117e" DESTINATION="ID_1052180334" ENDARROW="Default" ENDINCLINATION="84;-157;" ID="Arrow_ID_352116559" STARTARROW="None" STARTINCLINATION="-209;11;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575137069638" ID="ID_1052180334" MODIFIED="1575137136027" TEXT="...und es verlangt nach einem double-Dispatch">
|
|
<linktarget COLOR="#73117e" DESTINATION="ID_1052180334" ENDARROW="Default" ENDINCLINATION="84;-157;" ID="Arrow_ID_352116559" SOURCE="ID_691795394" STARTARROW="None" STARTINCLINATION="-209;11;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1575137161390" HGAP="117" ID="ID_836172889" MODIFIED="1575216227850" TEXT="wo steckt der Visitor?" VSHIFT="-18">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575137194277" ID="ID_553288287" MODIFIED="1575137207031" TEXT="im konkreten ViewHookable<X>"/>
|
|
<node CREATED="1575137218682" ID="ID_1616234672" MODIFIED="1575137239795" TEXT="dieses bietet freiwillig zusätzliche Methoden zur Quer-Verankerung"/>
|
|
<node CREATED="1575137261020" ID="ID_1063963760" MODIFIED="1575137323290" TEXT="ist dazu eine explizite Spezialisierung erforderlich?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575137347737" ID="ID_233527180" MODIFIED="1575137356468" TEXT="nur wenn die Methoden virtuell wären">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575137365580" ID="ID_1719972158" MODIFIED="1575137394537">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alternativ kann man eine konkrete Template-Funktion <i>deklarieren</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575137397730" ID="ID_1450922559" MODIFIED="1575137405507" TEXT="aber nicht definieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575137466745" ID="ID_868835405" MODIFIED="1575137486075" TEXT="weil die Definition auch die konkrete Implementierung des ViewHook kennen müßte"/>
|
|
<node CREATED="1575137513915" ID="ID_609895063" MODIFIED="1575137519437" TEXT="konkretes Beispiel">
|
|
<node CREATED="1575137520689" ID="ID_1629077992" MODIFIED="1575137528276" TEXT="Platzieren eines Clip in einen Track"/>
|
|
<node CREATED="1575137530000" ID="ID_1549354408" MODIFIED="1575137545858" TEXT="das ViewHookable für den Track ist ein TrackBody"/>
|
|
<node CREATED="1575137593448" ID="ID_1943445611" MODIFIED="1575137620619" TEXT="aber das ViewHookable für Clips muß den Canvas kennen"/>
|
|
<node CREATED="1575137655263" ID="ID_1676433364" MODIFIED="1575137687391" TEXT="eigentlich genügt hier ein ViewHookable<Widget>..."/>
|
|
<node CREATED="1575137689003" ID="ID_1830279546" MODIFIED="1575137694603" TEXT="...aber mit Kenntnis der Basis-Koordinatenn des Track">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575137719063" ID="ID_814850780" MODIFIED="1575137729754" TEXT="zwei Umsetzungs-Modelle">
|
|
<node CREATED="1575137730885" ID="ID_1572825790" MODIFIED="1575137756310" TEXT="(totale) Template-Spezialisierung">
|
|
<node CREATED="1575137764457" ID="ID_487433925" MODIFIED="1575137780219" TEXT="ViewHookable<TrackBody>">
|
|
<node CREATED="1575137781918" ID="ID_1341117592" MODIFIED="1575137869750" TEXT="hat virtuelle Methode(n)">
|
|
<node CREATED="1575137871085" ID="ID_1181038301" MODIFIED="1575137871085" TEXT="getChildHookable_for_Clip(TrackBody elm)"/>
|
|
<node CREATED="1575137872571" ID="ID_1426948011" MODIFIED="1575137884469" TEXT="getChildHookable_for_Marker(TrackBody elm)"/>
|
|
</node>
|
|
<node CREATED="1575137898463" ID="ID_1536688578" MODIFIED="1575137949950" TEXT="diese werden in TrackBody selber implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn, ohne daß dies nach Außen sichtbar wäre, ist TrackBody selbst die ViewHookable-Implementierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575137955327" ID="ID_1209911283" MODIFIED="1575138018363" TEXT="und diese Implementierung muß nun den Canvas finden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575138020526" ID="ID_61932847" MODIFIED="1575138278815" TEXT="kann sie aber (im Moment) gar nicht">
|
|
<linktarget COLOR="#e84746" DESTINATION="ID_61932847" ENDARROW="Default" ENDINCLINATION="201;0;" ID="Arrow_ID_252942839" SOURCE="ID_1025355091" STARTARROW="None" STARTINCLINATION="201;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575138045842" ID="ID_799349707" MODIFIED="1575138054270" TEXT="undefinierte Template-Methoden">
|
|
<node CREATED="1575138061353" ID="ID_1984732238" MODIFIED="1575138085281" TEXT="ViewHookable<T>.getChildHookable<U>(T elm)"/>
|
|
<node CREATED="1575138103780" ID="ID_1710088811" MODIFIED="1575138116855" TEXT="konkret werden die zusammen mit TrackBody implementiert">
|
|
<node CREATED="1575138118295" ID="ID_1373735987" MODIFIED="1575150501923" TEXT="ViewHookable<TrackBody>::getChildHookable<Clip>(TrackBody elm)"/>
|
|
<node CREATED="1575138118295" ID="ID_704904358" MODIFIED="1575150496404" TEXT="ViewHookable<TrackBody>::getChildHookable<Marker>(TrackBody elm)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575138190691" ID="ID_773972977" MODIFIED="1575138205137" TEXT="und diese Implementierung...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575138206253" ID="ID_655738081" MODIFIED="1575150462624" TEXT="muß einen static_cast machen">
|
|
<node CREATED="1575138216103" ID="ID_1538804684" MODIFIED="1575138222839" TEXT="ViewHookable<TrackBody>"/>
|
|
<node CREATED="1575138223763" ID="ID_1581544549" MODIFIED="1575138245579" TEXT="auf die konkrete Implementierung (=TrackBody selber)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575138250151" ID="ID_1642915025" MODIFIED="1575138269107" TEXT="und dieser wieder muß nun den Canvas finden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575138271076" ID="ID_1025355091" MODIFIED="1575138284257" TEXT="gleiches Problem">
|
|
<arrowlink COLOR="#e84746" DESTINATION="ID_61932847" ENDARROW="Default" ENDINCLINATION="201;0;" ID="Arrow_ID_252942839" STARTARROW="None" STARTINCLINATION="201;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575215636577" ID="ID_1948387656" MODIFIED="1575215647790" TEXT="neige ehr dem "generischen Visitor" zu">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node COLOR="#435e98" CREATED="1575215649416" ID="ID_1591288650" MODIFIED="1575216005833" TEXT="also den undefinierten Template-Methoden">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1575215660550" ID="ID_34068201" MODIFIED="1575215996537" TEXT="pro">
|
|
<icon BUILTIN="up"/>
|
|
<node CREATED="1575215791195" ID="ID_398909879" MODIFIED="1575215821034" TEXT="wenig Code-Overhead">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man muß nicht eine explizite Spezialisierung des ganzen Interfaces schreiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575215838399" ID="ID_859406608" MODIFIED="1575215879417" TEXT="natürliche Code-Organisation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man schreibt die konkrete Implementierung direkt bei der Implementierung des Zieltyps mit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575215924451" ID="ID_643524989" MODIFIED="1575215973324" TEXT="weniger implizite Konventionen"/>
|
|
</node>
|
|
<node CREATED="1575215663190" ID="ID_906295451" MODIFIED="1575215991848" TEXT="con">
|
|
<icon BUILTIN="down"/>
|
|
<node CREATED="1575215665957" ID="ID_1196326876" MODIFIED="1575215723907" TEXT="Kein Interface"/>
|
|
<node CREATED="1575215724926" ID="ID_134909462" MODIFIED="1575215743342" TEXT="fehlende Implementierung wird erst bei Verwendung ersichtlich"/>
|
|
<node CREATED="1575215758830" ID="ID_550543628" MODIFIED="1575215766856" TEXT="static_cast (Insider-Wissen)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575216033496" ID="ID_1987929560" MODIFIED="1575216053261" TEXT="double-dispatch wird also durch die Verwendung eines konkreten Typs angetrieben">
|
|
<node CREATED="1575216082111" ID="ID_606766126" MODIFIED="1575216098040" TEXT="Dimension-1: das konkrete ViewHookable"/>
|
|
<node CREATED="1575216098994" ID="ID_548123128" MODIFIED="1575216156142" TEXT="Dimension-2: konkrete Unterstützung für einen bestimmten Widget-Typ in jenem"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575216188742" HGAP="334" ID="ID_1821357488" MODIFIED="1575579109843" TEXT="bleibt der Zugang zum Canvas zu lösen" VSHIFT="46">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1575216248349" ID="ID_512721194" MODIFIED="1575216253000" TEXT="bisheriger Stand">
|
|
<node CREATED="1575216253845" ID="ID_587308673" MODIFIED="1575216292655" TEXT="Problem ist nicht wirklich gelöst">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir könnten zwar Widgets aufbauen, diese aber dann später nicht umordnen oder zerstören
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1575216303885" ID="ID_715859179" MODIFIED="1575216335980" TEXT="top-Level (TimelineController) bietet den Ankerpunkt im DisplayManager"/>
|
|
<node CREATED="1575216337106" ID="ID_661291056" MODIFIED="1575216352962" TEXT="TrackPresenter bekommt jeweils einen Ankerpunkt bei der Erstellung"/>
|
|
<node CREATED="1575216354061" ID="ID_1311913961" MODIFIED="1575216373533" TEXT="TrackPresenter gibt sich selber als Ankerpunkt bei der Erstellung der Kinder mit"/>
|
|
</node>
|
|
<node CREATED="1575216544532" ID="ID_1540315113" MODIFIED="1575216549799" TEXT="warum wünschenswert?">
|
|
<node CREATED="1575216551690" ID="ID_935473263" MODIFIED="1575216559964" TEXT="one concept to rule them all"/>
|
|
<node CREATED="1575216581519" ID="ID_887541808" MODIFIED="1575216601256" TEXT="Komponentenzugriff in komplexen GUIs ist notorisch verworren"/>
|
|
</node>
|
|
<node CREATED="1575216399512" ID="ID_507337771" MODIFIED="1575216403380" TEXT="Möglichkeiten">
|
|
<node CREATED="1575216670419" ID="ID_702645692" MODIFIED="1575217442829" TEXT="anderweitig lösen">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
<node CREATED="1575216681761" ID="ID_1830792442" MODIFIED="1575220615843" TEXT="die Presenter kennen typischerweise den DisplayManager">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1575220602792" ID="ID_1011365806" MODIFIED="1575220612560" TEXT="STOP! das stimmt gar nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1575220620374" ID="ID_1278909200" MODIFIED="1575220767695" TEXT="genau das hab ich trickreich vermieden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
durch die Lösung mit dem "Einhäkeln" via temporär durchgereichtem Lambda!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#688bdc" DESTINATION="ID_1278909200" ENDARROW="Default" ENDINCLINATION="604;42;" ID="Arrow_ID_268017738" SOURCE="ID_1816173955" STARTARROW="None" STARTINCLINATION="182;25;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575216724123" ID="ID_1691573472" MODIFIED="1575216735670" TEXT="dieser hätte dann ein API "getWidgetHookable""/>
|
|
<node CREATED="1575216766414" ID="ID_1123775276" MODIFIED="1575216777744" TEXT="der Vater müßte seine eigenen Koordinaten kennen"/>
|
|
<node CREATED="1575216778548" ID="ID_1190748757" MODIFIED="1575216796416" TEXT="er würde dann bei der Erstellung die relativen Kind-Koordinaten ausrechnen und mitgeben"/>
|
|
<node CREATED="1575216835596" ID="ID_629102178" MODIFIED="1575216885510" TEXT="die Template-Visitor-Methode wird mit einem static_fail implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
um zu dokumentieren, daß wir in diesem Visitor-Mischfall am Konzept vorbei implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1575217033169" ID="ID_1460431220" MODIFIED="1575217050486" TEXT="für Timelines hätten wir einen Dienst pro Timeline"/>
|
|
<node CREATED="1575217051398" ID="ID_1214822231" MODIFIED="1575217061441" TEXT="und Clips müßten ebenfalls einen lokalen Dienst bieten"/>
|
|
<node CREATED="1575216926792" ID="ID_1215187417" MODIFIED="1575220655549" TEXT="die Implementierung ist aber auch tatsächlich flach">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und nicht hierarchisch! Letzten Endes geht es nur darum, Widgets an einen gemeinsamen Canvas zu heften
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575217471564" ID="ID_1483844411" MODIFIED="1575223136572" TEXT="nach Schema-f umsetzen">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1575217494446" ID="ID_1143595794" MODIFIED="1575217521744" TEXT="Implementiere: ViewHookable<TrackBody>::getChildHookable<Clip>(TrackBody elm)"/>
|
|
<node CREATED="1575217549604" ID="ID_280485004" MODIFIED="1575217592722" TEXT="ViewHookable<TrackBody> ist de-facto selber ein TrackBody">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich der Vater-TrackBody
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575219131000" ID="ID_1060211288" MODIFIED="1575219133937" TEXT="TrackBody">
|
|
<node CREATED="1575219136371" ID="ID_1651052012" MODIFIED="1575219154957" TEXT="hält eine Liste der Sub-Body*"/>
|
|
<node CREATED="1575219156445" ID="ID_1566022490" MODIFIED="1575219175060" TEXT="managed (unique_ptr) eine Liste der Ruler-Tracks">
|
|
<node CREATED="1575219179824" ID="ID_1534908547" MODIFIED="1575219188210" TEXT="RulerTrack ist ein Tangible"/>
|
|
<node CREATED="1575219189014" ID="ID_911375667" MODIFIED="1575558646518" TEXT="diese Liste ist vom TrackPresenter her in den Diff eingehängt"/>
|
|
</node>
|
|
<node CREATED="1575219217817" ID="ID_1289207727" MODIFIED="1575219235893" TEXT="kennt seine eigene startLine_ auf dem Canvas"/>
|
|
<node CREATED="1575219240879" ID="ID_1411296086" MODIFIED="1575219249858" TEXT="plus einige weitere Render-Parameter"/>
|
|
</node>
|
|
<node CREATED="1575219314942" ID="ID_1292453963" MODIFIED="1575219334463" TEXT="TrackBody müßte nun ViewHookable<Clip> implementieren">
|
|
<node CREATED="1575219336874" ID="ID_1662726515" MODIFIED="1575219344931" TEXT="und zwar durch Delegation/Dekoration">
|
|
<node CREATED="1575219383148" ID="ID_1184072772" MODIFIED="1575219395047" TEXT="auf den top-level ViewHookable<Widget>"/>
|
|
<node CREATED="1575219396781" ID="ID_141339762" MODIFIED="1575219406522" TEXT="welches vom DisplayManager bereitgestellt wird"/>
|
|
<node CREATED="1575219409161" ID="ID_820984223" MODIFIED="1575219425490" TEXT="und (vermutl) vom Canvas selber zu implementieren ist"/>
|
|
<node CREATED="1575219434581" ID="ID_1020948818" MODIFIED="1575219474436" TEXT="die Dekoration dabei justiert den Y-offset anhand der startLine_"/>
|
|
</node>
|
|
<node CREATED="1575219354624" ID="ID_1863458674" MODIFIED="1575219365787" TEXT="oder alternativ via direkt-Zugriff auf den Canvas">
|
|
<node CREATED="1575219523764" ID="ID_1012093929" MODIFIED="1575219544539" TEXT="das wäre eine (indirekt) zirkuläre Beziehung zwischen Implementierungs-Enitäten"/>
|
|
<node CREATED="1575219832435" ID="ID_1357635182" MODIFIED="1575219937587" TEXT="die aber effektiv (noch) nicht realisiert wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
will sagen: es gibt keinen Zugriff, der vom Canvas ausgeht, durch die TrackBodies durchsteigt, und dann indirekt in den Cavas zurück greift. Denn -- zumindest im Moment -- handelt es sich um zwei klar geschiedene Belange: einmal das Rendern der Track-Struktur, und andererseits das platzieren von Clips auf dem Canvas
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575219941761" ID="ID_1070253348" MODIFIED="1575220419798" TEXT="das einzige Verbindungsglied ist die startLine_">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn diese wird von der Auswertung der Track-Struktur (vor dem Zeichnen) etabliert, und andererseits beim Platzieren eines Clip genutzt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#439be7" DESTINATION="ID_1070253348" ENDARROW="Default" ENDINCLINATION="-100;6;" ID="Arrow_ID_406976845" SOURCE="ID_378686648" STARTARROW="None" STARTINCLINATION="235;7;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575220057456" ID="ID_1106262862" MODIFIED="1575220073987" TEXT="die leidige Konsequenz...">
|
|
<node CREATED="1575220074975" ID="ID_29395675" MODIFIED="1575220102936" TEXT="jeder TrackBody hat einen (Rück)Zeiger auf den Canvas oder DisplayManager"/>
|
|
<node CREATED="1575220114002" ID="ID_840603253" MODIFIED="1575220144732">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und diese Info ist komplett <b>redundant</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575220123929" ID="ID_830381506" MODIFIED="1575220138837">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle anderen Daten in TrackBody sind <b>nicht redundant</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575220252783" ID="ID_1344785124" MODIFIED="1575223142078" TEXT="Belange auseinandernehmen?">
|
|
<linktarget COLOR="#c1eb45" DESTINATION="ID_1344785124" ENDARROW="Default" ENDINCLINATION="-706;53;" ID="Arrow_ID_1568915503" SOURCE="ID_1508786364" STARTARROW="None" STARTINCLINATION="731;48;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1575220262166" ID="ID_378686648" MODIFIED="1575220419798" TEXT="kann man diese (anscheinend) nahezu vollständig geschiedenen Belange nicht auftrennen?">
|
|
<arrowlink COLOR="#439be7" DESTINATION="ID_1070253348" ENDARROW="Default" ENDINCLINATION="-100;6;" ID="Arrow_ID_406976845" STARTARROW="None" STARTINCLINATION="235;7;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1575220439150" ID="ID_1245542782" MODIFIED="1575220514498" TEXT="warum muß der TrackBody das ViewHookable<Clip> sein?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1575220534273" ID="ID_1963867099" MODIFIED="1575220684466" TEXT="der TrackPresenter selber hält ebenfalls diese redundante Info">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1575220686308" ID="ID_1816173955" MODIFIED="1575220767695" TEXT="nein, tut er nicht">
|
|
<arrowlink COLOR="#688bdc" DESTINATION="ID_1278909200" ENDARROW="Default" ENDINCLINATION="604;42;" ID="Arrow_ID_268017738" STARTARROW="None" STARTINCLINATION="182;25;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575221690053" ID="ID_391530319" MODIFIED="1575221756022" TEXT="genau diese Info aber brauche ich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn der Display/Manager bzw Canvas ist zwar "quasi global", aber eben nicht wirklich, denn er ist für eine Timeline zuständig. Also genau die Art Relation, für die man typischerweise DI macht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575220914655" ID="ID_646969276" MODIFIED="1575220994424" TEXT="nur TrackPresenter oder DisplayFrame kämen in Frage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil nach hier etablierter Policy diesen erlaubt wäre, "von oben" in den trackPresenter.displayFrame.trackBody reinzugreifen für die startLine_
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575222540955" ID="ID_1068095065" MODIFIED="1575222555271" TEXT="in den sauren Apfel beißen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575222560056" ID="ID_1526676047" MODIFIED="1575222576688" TEXT="DisplayFrame hält eine Referenz auf ViewHookable<Widget>"/>
|
|
<node CREATED="1575222583789" ID="ID_1835575914" MODIFIED="1575222601128" TEXT="und implementiert selber ViewHookable<Clip> und ViewHookable<Marker>"/>
|
|
<node CREATED="1575222608314" ID="ID_1403410704" MODIFIED="1575222624827" TEXT="und zieht zur Dekoration die trackBody.startLine_ heran"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575223154399" ID="ID_1681994818" MODIFIED="1576705095215" TEXT="also wird der DisplayFrame ausgebaut">
|
|
<linktarget COLOR="#3c62b6" DESTINATION="ID_1681994818" ENDARROW="Default" ENDINCLINATION="-1457;26;" ID="Arrow_ID_1666541151" SOURCE="ID_665871359" STARTARROW="None" STARTINCLINATION="898;63;"/>
|
|
<node CREATED="1575223172838" ID="ID_1606686104" MODIFIED="1575223181392" TEXT="zum großen ViewHook">
|
|
<node CREATED="1575223418428" ID="ID_463428688" MODIFIED="1575223429207" TEXT="hält einen ViewHook<TrackBody>"/>
|
|
<node CREATED="1575223430819" ID="ID_1357751249" MODIFIED="1575223441611" TEXT="hält einen ViewHook<TrackHeaderWidget>"/>
|
|
<node CREATED="1575223465392" ID="ID_260241369" MODIFIED="1575223488960" TEXT="hält eine Referenz auf ViewHookable<Widget>"/>
|
|
<node CREATED="1575223491827" ID="ID_130394978" MODIFIED="1575223504573" TEXT="implementiert selber ViewHookable<Clip>"/>
|
|
<node CREATED="1575223505705" ID="ID_405837155" MODIFIED="1575223520899" TEXT="implementiert selber ViewHookable<Marker>"/>
|
|
</node>
|
|
<node CREATED="1575223585142" ID="ID_436178463" MODIFIED="1575223590265" TEXT="so einige Redundanzen">
|
|
<node CREATED="1575223603060" ID="ID_1419915992" MODIFIED="1575223619285" TEXT="Referenz auf ViewHookable<Widget> ist unvermeidbar">
|
|
<node CREATED="1575223624281" ID="ID_1458214193" MODIFIED="1575223647750" TEXT="weil die dahinter stehende Impl (der Canvas) nicht global ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sondern zur Timeline gehört
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575223656716" ID="ID_1189941110" MODIFIED="1575223672718" TEXT="weil sonst keine der angeschlossenen Strukturen einen aufwärts-Link hat"/>
|
|
<node CREATED="1611436973802" ID="ID_1355357060" MODIFIED="1611436991322" TEXT="übrigens: man könnte hier auch ein Wurmloch einsetzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575223786739" ID="ID_926999216" MODIFIED="1575223802333" TEXT="aber ViewHook<TrackBody> hat einen TrackBody*"/>
|
|
<node CREATED="1575223803377" ID="ID_1526084839" MODIFIED="1575223813779" TEXT="auf das direkt daneben stehende TrackBody-Objekt"/>
|
|
</node>
|
|
<node CREATED="1575239328453" ID="ID_1096729219" MODIFIED="1575667946076" TEXT="Idee: ViewHooked<Widget>">
|
|
<linktarget COLOR="#e79332" DESTINATION="ID_1096729219" ENDARROW="Default" ENDINCLINATION="-1237;46;" ID="Arrow_ID_1348207622" SOURCE="ID_1416159951" STARTARROW="None" STARTINCLINATION="2421;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1575239353279" ID="ID_1137161464" MODIFIED="1575239358488" TEXT="statt frei stehendem "ViewHook""/>
|
|
<node CREATED="1575239360140" ID="ID_1769045218" MODIFIED="1575239745292" TEXT="also direkt an die Lebensdauer des Widget gekoppelt"/>
|
|
<node CREATED="1575239401247" ID="ID_1821251711" MODIFIED="1575566053491" TEXT="dann geht der hook()-Vorgang anders herum"/>
|
|
<node CREATED="1575239411717" ID="ID_1412083065" MODIFIED="1575239472817" TEXT="ViewHooked braucht als ctor-Parameter ein ViewHookable&">
|
|
<node CREATED="1575667806989" ID="ID_334793743" MODIFIED="1575667821044" TEXT="ViewHookable::hook() wird eine void-Operation"/>
|
|
<node CREATED="1575667821800" ID="ID_722923687" MODIFIED="1575667833698" TEXT="aber der ctor garantiert (RAII) daß sie aufgerufen wurde"/>
|
|
</node>
|
|
<node CREATED="1575239483404" ID="ID_397271082" MODIFIED="1575239488770" TEXT="und wird noncopyable">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1575239505442" ID="ID_907757822" MODIFIED="1575240706224" TEXT="lassen sich damit alle Operationen durchführen?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1575239796865" ID="ID_1427807363" MODIFIED="1575240713921" TEXT="move... warum nicht?">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575239815831" ID="ID_129305740" MODIFIED="1575240715198" TEXT="destroy: geht völlig analog">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575239830833" ID="ID_475200834" MODIFIED="1575240716553" TEXT="Lebenszyklus">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575239835573" ID="ID_1985812443" MODIFIED="1575239849286" TEXT="das Widget muß vor dem ViewHooked existieren"/>
|
|
<node CREATED="1575239850434" ID="ID_28316843" MODIFIED="1575239862705" TEXT="das ist realisierbar...">
|
|
<node CREATED="1575239863536" ID="ID_1456405590" MODIFIED="1575239869276" TEXT="indem man von dem Widget erbt">
|
|
<node CREATED="1575239905163" ID="ID_1933259507" MODIFIED="1575239950041" TEXT="hätte den Charme, daß das smart-ptr/proxy-Verhalten sich erübrigt"/>
|
|
<node CREATED="1575239958334" ID="ID_1632364154" MODIFIED="1575240030260" TEXT="...welches mir ohnehin nicht so besonders gut gefallen hat">
|
|
<arrowlink COLOR="#3f8a72" DESTINATION="ID_311245443" ENDARROW="Default" ENDINCLINATION="693;198;" ID="Arrow_ID_1560507426" STARTARROW="None" STARTINCLINATION="647;33;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575239889645" ID="ID_1523224980" MODIFIED="1575239896424" TEXT="indem man das Widget als Member hat"/>
|
|
</node>
|
|
<node CREATED="1575240151529" ID="ID_75365412" MODIFIED="1575240172988" TEXT="Umordnen">
|
|
<node CREATED="1575240174231" ID="ID_109571586" MODIFIED="1575240188790" TEXT="Referenz bleibt Referenz"/>
|
|
<node CREATED="1575240189724" ID="ID_1392238474" MODIFIED="1575240203713" TEXT="und ein dekorierender Iterator ist davon auch nicht betroffen"/>
|
|
<node CREATED="1575240210241" ID="ID_213831335" MODIFIED="1575240228387" TEXT="es wird damit sogar viel schöner...."/>
|
|
<node CREATED="1575240229191" ID="ID_1613381810" MODIFIED="1575240275180" TEXT="weil ja nun eigentlich "die Widgets" per generischem Handle geliefert werden"/>
|
|
<node CREATED="1575240261155" ID="ID_767586605" MODIFIED="1575240266665" TEXT="in neuer Reihenfolge ">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575240305717" ID="ID_1992149674" MODIFIED="1575240717518" TEXT="relatives Verankern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575240328218" ID="ID_154585759" MODIFIED="1575240345695">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ViewHooked wird nun zum <b>eigentlichen Front-End</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575240582411" ID="ID_333144229" MODIFIED="1575240611444" TEXT="der ViewHook muß weiterhin die double-dispatch-Funktion (generisch) implementieren"/>
|
|
<node CREATED="1575240613131" ID="ID_1177550523" MODIFIED="1575558144539" TEXT="und es bleibt das gleiche Zugriffs-Problem bestehen">
|
|
<arrowlink COLOR="#b99d8f" DESTINATION="ID_1311566312" ENDARROW="Default" ENDINCLINATION="112;-141;" ID="Arrow_ID_1836497090" STARTARROW="None" STARTINCLINATION="-263;67;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d8ce8e" COLOR="#435e98" CREATED="1575240647678" ID="ID_356124839" MODIFIED="1575240690707" TEXT="also das ist jetz mal ein Design, das mir richtig gut gefällt">
|
|
<linktarget COLOR="#c1eb45" DESTINATION="ID_356124839" ENDARROW="Default" ENDINCLINATION="-876;36;" ID="Arrow_ID_522684276" SOURCE="ID_1146450018" STARTARROW="None" STARTINCLINATION="420;38;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575240723741" HGAP="-92" ID="ID_1311566312" MODIFIED="1575558113173" TEXT="damit bleibt (wieder nur) das Zugriffs-Problem" VSHIFT="73">
|
|
<linktarget COLOR="#b99d8f" DESTINATION="ID_1311566312" ENDARROW="Default" ENDINCLINATION="112;-141;" ID="Arrow_ID_1836497090" SOURCE="ID_1177550523" STARTARROW="None" STARTINCLINATION="-263;67;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575240751305" ID="ID_1522311652" MODIFIED="1575240770023" TEXT="ich habe also jetzt ViewHook<Clip> eine Ebene hochgeschoben"/>
|
|
<node CREATED="1575240786532" ID="ID_1787997117" MODIFIED="1575240818729" TEXT="demnach müßte nun der TrackBody an seinen Parent (=DisplayFrame rankommen)">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1575240824295" ID="ID_895299596" MODIFIED="1575240844874" TEXT="AUA">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1575243069122" ID="ID_1544444255" MODIFIED="1575243101578" TEXT="muß ich jetzt auch den ViewHook<TrackBody> in den DisplayFrame hochschieben??">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1575558950482" ID="ID_1971888026" MODIFIED="1575566297637" TEXT="was für Möglichkeiten habe ich hier.....">
|
|
<node CREATED="1575558966759" ID="ID_1387494834" MODIFIED="1575559186143" TEXT="wer auch immer ViewHook<Clip> implementiert, muß die globale Referenz halten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie ich's auch drehe und wende, daran führt kein Weg vorbei. Weil die Referenz eben nicht wirklich global ist, sondern einen root-Kontext darstellt (nämlich die umschließende Timeline).
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575559189338" ID="ID_508619525" MODIFIED="1575561473297" TEXT="und diesen müssen wir für die »Quer-Bewegung« auch selber erreichen können">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...also wenn wir ViewHook für einen anderen Kinder-Typ brauchen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575561914272" ID="ID_1374284644" MODIFIED="1575561939182">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
fragt sich <i>von wem </i>wir dieses Hookable für einen andern Typ bekommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575566180271" ID="ID_176621579" MODIFIED="1575566192073" TEXT="systematisches Vorgehen ist über den Vater"/>
|
|
<node CREATED="1575566412391" ID="ID_1169508306" MODIFIED="1575566415455" TEXT="Baumuster">
|
|
<node CREATED="1575566428429" ID="ID_1388581284" MODIFIED="1575566447758" TEXT="TrackBody ist Hub">
|
|
<node CREATED="1575566452714" ID="ID_222642690" MODIFIED="1575566508542" TEXT="er implementiert diverse ViewHook"/>
|
|
<node CREATED="1575566516521" ID="ID_448634950" MODIFIED="1575566530291" TEXT="aber ViewHook<TrackHead> ist außen vor"/>
|
|
<node CREATED="1575566573350" ID="ID_1319751632" MODIFIED="1575566581969" TEXT="man könnte generisch quer-Navigieren">
|
|
<node CREATED="1575566591719" ID="ID_159346735" MODIFIED="1575566622379" TEXT="TrackBody -> parent==ViewHook -> Child-TrackBody(=hooked)"/>
|
|
<node CREATED="1575566626210" ID="ID_668544074" MODIFIED="1575566899896" TEXT="ist dann aber eigentlich redundant">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn wenn alle Methoden auf dem TrackBody liegen, kann man diese auch von außen direkt aufrufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575566951102" ID="ID_1015186173" MODIFIED="1575566961313" TEXT="Vorteil: Implementierung ist lokal">
|
|
<node CREATED="1575566967870" ID="ID_332189375" MODIFIED="1575566971407" TEXT="nah an den Daten"/>
|
|
<node CREATED="1575566972523" ID="ID_994405337" MODIFIED="1575566977094" TEXT="Kapselung macht Sinn"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575567003652" ID="ID_1512925167" MODIFIED="1575567014083" TEXT="DisplayFrame ist Hub">
|
|
<linktarget COLOR="#c1eb45" DESTINATION="ID_1512925167" ENDARROW="Default" ENDINCLINATION="-919;120;" ID="Arrow_ID_141584628" SOURCE="ID_1776619352" STARTARROW="None" STARTINCLINATION="253;17;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1575567064023" ID="ID_76686633" MODIFIED="1575567071225" TEXT="er kann alle ViewHook implementieren"/>
|
|
<node CREATED="1575567072693" ID="ID_924709829" MODIFIED="1575567088431" TEXT="muß dafür aber die Widget-Komponenten zu Hilfe nehmen">
|
|
<node CREATED="1575567095418" ID="ID_77144446" MODIFIED="1575567134769" TEXT="TrackHead-Widget muß Kinder hinzufügen/löschen"/>
|
|
<node CREATED="1575567163086" ID="ID_1288204921" MODIFIED="1575567173868" TEXT="TrackBody muß sub-Bodies verwalten"/>
|
|
<node CREATED="1575568155559" ID="ID_1687939618" MODIFIED="1575568163670" TEXT="TrackBody muß mit startLine_ helfen"/>
|
|
</node>
|
|
<node CREATED="1575567271739" ID="ID_1984519300" MODIFIED="1575567288468" TEXT="Nachteil: jede Implementierung ist über ein Delegate aufgedoppelt"/>
|
|
<node CREATED="1575567212827" ID="ID_485232452" MODIFIED="1575567224029" TEXT="Vorteil: ein einziger API-Zugangspunkt"/>
|
|
<node CREATED="1575567369501" ID="ID_887475852" MODIFIED="1575567383327" TEXT="damit wäre aber die Abstraktion insgesamt unnötig">
|
|
<node CREATED="1575567405016" ID="ID_1063862742" MODIFIED="1575567426746" TEXT="sie reduziert sich auf ein Baumuster oder Schema"/>
|
|
<node CREATED="1575567451546" ID="ID_44733153" MODIFIED="1575567459989" TEXT="Quer-Beweglichkeit wird nicht gebraucht"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575567467201" ID="ID_1069949271" MODIFIED="1575567481970" TEXT="Presenter ist Hub">
|
|
<node CREATED="1575567483982" ID="ID_1504212494" MODIFIED="1575567502728" TEXT="so auf den ersten Bilck die "natürlichste" (naive) Lösung"/>
|
|
<node CREATED="1575567512106" ID="ID_832303486" MODIFIED="1575567561873" TEXT="für den Clip muß es sogar so sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es sei denn, man packt dann den ViewHook in eine eigene Sub-Komponente
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575567684219" ID="ID_1290720271" MODIFIED="1575567718882" TEXT="Subkomponenten werden reine Daten-Records">
|
|
<node CREATED="1575567721534" ID="ID_1940087241" MODIFIED="1575567728856" TEXT="Implementierung bleibt im Presenter"/>
|
|
<node CREATED="1575567729637" ID="ID_1789840142" MODIFIED="1575567750110" TEXT="und pfuscht in den Daten der Subkomponenten herum"/>
|
|
<node CREATED="1575567774463" ID="ID_245632912" MODIFIED="1575567786913" TEXT="oder zumindest der DisplayFrame ist eigentlich redundant dann"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575567820241" ID="ID_1754646137" MODIFIED="1575567827915" TEXT="ohne Hub arbeiten">
|
|
<node CREATED="1575567830495" ID="ID_1915385608" MODIFIED="1575567834642" TEXT="dann ist">
|
|
<node CREATED="1575567836054" ID="ID_1970611196" MODIFIED="1575573897945" TEXT="HeadWidget== ViewHook<HeadWidget>"/>
|
|
<node CREATED="1575567875297" ID="ID_250597251" MODIFIED="1575573902795" TEXT="TrackBody==ViewHook<TrackBody>"/>
|
|
<node CREATED="1575567918819" ID="ID_394065409" MODIFIED="1575573916225" TEXT="DisplayFrame== delegierendes ViewHook Widget->Canvas"/>
|
|
</node>
|
|
<node CREATED="1575572351704" ID="ID_495661835" MODIFIED="1575578991270" TEXT="DisplayFrame braucht Hilfe vom TrackBody für die Koordinaten"/>
|
|
<node CREATED="1575572208718" ID="ID_1348762816" MODIFIED="1575572218384" TEXT="Quer-Bewegung generisch nicht möglich">
|
|
<node CREATED="1575572230080" ID="ID_960143192" MODIFIED="1575572242283" TEXT="HeadWidget -> HeadWidget : ja"/>
|
|
<node CREATED="1575572244839" ID="ID_1428458926" MODIFIED="1575572249394" TEXT="dto für TrackBody"/>
|
|
<node CREATED="1575572250135" ID="ID_1947902368" MODIFIED="1575572281213" TEXT="aber TrackBody -> Clip : nein"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1575579000019" ID="ID_61935554" MODIFIED="1575579470137" TEXT="Fazit: keine Quer-Beweglichkeit">
|
|
<linktarget COLOR="#8e253d" DESTINATION="ID_61935554" ENDARROW="Default" ENDINCLINATION="-750;14;" ID="Arrow_ID_588110348" SOURCE="ID_912776786" STARTARROW="Default" STARTINCLINATION="827;0;"/>
|
|
<linktarget COLOR="#8e253d" DESTINATION="ID_61935554" ENDARROW="Default" ENDINCLINATION="-750;14;" ID="Arrow_ID_157891410" SOURCE="ID_1941316386" STARTARROW="None" STARTINCLINATION="111;10;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1575579010066" ID="ID_508240119" MODIFIED="1575579021148" TEXT="entweder sie ist wünschenswert aber nicht realisierbar"/>
|
|
<node CREATED="1575579022092" ID="ID_1571784139" MODIFIED="1575579029890" TEXT="oder sie ist realisierbar aber nicht notwendig"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#c23d5c" CREATED="1575579158699" ID="ID_912776786" MODIFIED="1575579350247" TEXT="Fazit: nicht relisierbar und nicht notwendig">
|
|
<arrowlink COLOR="#8e253d" DESTINATION="ID_61935554" ENDARROW="Default" ENDINCLINATION="-750;14;" ID="Arrow_ID_588110348" STARTARROW="Default" STARTINCLINATION="827;0;"/>
|
|
<linktarget COLOR="#b80305" DESTINATION="ID_912776786" ENDARROW="Default" ENDINCLINATION="-582;30;" ID="Arrow_ID_739783685" SOURCE="ID_1550703494" STARTARROW="None" STARTINCLINATION="212;897;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1575579329678" HGAP="38" ID="ID_965561857" MODIFIED="1575579364023" TEXT="nur als generisches Schema nützlich" VSHIFT="20">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611437583831" HGAP="33" ID="ID_149706819" MODIFIED="1611438463655" TEXT="aber diverse Design-Verbesserungen bleiben" VSHIFT="8">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....durch den Versuch, "die Hooks" zu einem allgemeinem Gui-Konstruktionsframework mit double-Dispatch auszubauen, habe ich das bestehende Design erheblich geschärft, und für einige Teilaspekte viel sinnigere Lösungen gefunden. Am Ende hat sich gezeigt, daß meine Vision nicht realisierbar ist, und zwar fehlte eigentlich nur "eine ganz kleine Lücke" ― aber ich bin erfahren genug, um zu wissen, daß man eine solche Situation nicht <i>durch Zaubertricks retten</i> kann. Daher habe ich diese Vision in aller Form begraben, aber die Design-Verbesserungen entsprechend heruntergestuft und so erhalten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1611437583831" HGAP="41" ID="ID_1146450018" MODIFIED="1611438446847" TEXT="Widget selber als ViewHooked" VSHIFT="33">
|
|
<arrowlink COLOR="#c1eb45" DESTINATION="ID_356124839" ENDARROW="Default" ENDINCLINATION="-876;36;" ID="Arrow_ID_522684276" STARTARROW="None" STARTINCLINATION="420;38;"/>
|
|
</node>
|
|
<node CREATED="1611437583831" HGAP="35" ID="ID_1776619352" MODIFIED="1611438451215" TEXT="DisplayFrame ist/bleibt zentraler Vermittler" VSHIFT="-1">
|
|
<arrowlink COLOR="#c1eb45" DESTINATION="ID_1512925167" ENDARROW="Default" ENDINCLINATION="-919;120;" ID="Arrow_ID_141584628" STARTARROW="None" STARTINCLINATION="253;17;"/>
|
|
</node>
|
|
<node CREATED="1611437583831" HGAP="51" ID="ID_1508786364" MODIFIED="1611438457158" TEXT="es sind zwei nahezu getrennte Belange" VSHIFT="-2">
|
|
<arrowlink COLOR="#c1eb45" DESTINATION="ID_1344785124" ENDARROW="Default" ENDINCLINATION="-706;53;" ID="Arrow_ID_1568915503" STARTARROW="None" STARTINCLINATION="731;48;"/>
|
|
<node CREATED="1611438384466" HGAP="34" ID="ID_591262659" MODIFIED="1611438409972" TEXT="Subtrack in Grid-Layout" VSHIFT="27"/>
|
|
<node CREATED="1611438377955" ID="ID_105340776" MODIFIED="1611438383736" TEXT="Clip an Canvas"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1575057178202" ID="ID_1208770677" MODIFIED="1678382938128" TEXT="relatives Positionieren">
|
|
<linktarget COLOR="#4f94d2" DESTINATION="ID_1208770677" ENDARROW="Default" ENDINCLINATION="207;339;" ID="Arrow_ID_1505912691" SOURCE="ID_802422598" STARTARROW="None" STARTINCLINATION="-349;-21;"/>
|
|
<linktarget COLOR="#4567f1" DESTINATION="ID_1208770677" ENDARROW="Default" ENDINCLINATION="-696;74;" ID="Arrow_ID_1555581659" SOURCE="ID_969058360" STARTARROW="None" STARTINCLINATION="1109;48;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582410135584" ID="ID_460685639" MODIFIED="1582410225517" TEXT="#1207 relative attachment and (custom) drawing of sub-widgets">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1575057198430" ID="ID_1171619130" MODIFIED="1575057213917" TEXT="neues ViewHooked relativ zu einem Bezugs-ViewHooked">
|
|
<node CREATED="1575057268873" ID="ID_827160586" MODIFIED="1575566385152" TEXT="das könnte Quer-Beweglichkeit zwischen Typen implizieren">
|
|
<arrowlink COLOR="#146b9a" DESTINATION="ID_1565606328" ENDARROW="Default" ENDINCLINATION="-218;27;" ID="Arrow_ID_1877360800" STARTARROW="None" STARTINCLINATION="-76;-196;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1575579158699" ID="ID_1941316386" MODIFIED="1575579470137" TEXT="diese ist aber nicht realisierbar">
|
|
<arrowlink COLOR="#8e253d" DESTINATION="ID_61935554" ENDARROW="Default" ENDINCLINATION="-750;14;" ID="Arrow_ID_157891410" STARTARROW="None" STARTINCLINATION="111;10;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1575057228579" ID="ID_795117396" MODIFIED="1575578199510" TEXT="Frage: ist diese Relation nur transient (pro Aufruf)?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575578007856" ID="ID_439314478" MODIFIED="1575578191294" TEXT="geht es nur um ein implizit hereingereichtes Koordinatensystem">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1575578027621" ID="ID_1172679585" MODIFIED="1575578188347" TEXT="oder gibt es eine rückwärts-Verzeigerung auf den Vaterknoten?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575578203678" ID="ID_340739196" MODIFIED="1575578346354" TEXT="Gefahr aufgedoppelter Systeme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1575580959187" ID="ID_936515442" MODIFIED="1678382955232" TEXT="damit besser lokal implementieren">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1575580975033" ID="ID_1555659203" MODIFIED="1575580996268" TEXT="d.h. als ein Implementierungsdetail für einen speziellen Typ"/>
|
|
<node CREATED="1575580999173" ID="ID_1385039665" MODIFIED="1575581013895" TEXT="das ist dann eine dekorierende/delegierende Implementierung"/>
|
|
<node CREATED="1575581015219" ID="ID_1015965713" MODIFIED="1575581026974" TEXT="für den Widget -> Canvas - Fall"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678383001172" ID="ID_1151442798" MODIFIED="1678383448071" TEXT="Konzept inzwischen grundsätzlich klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und funktioniert gut für Clip-Widgets auf der Timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666371419810" ID="ID_613160281" MODIFIED="1678383462720" TEXT="sicherstellen daß dieses Konzept auch in den Overview-Rulern funktioniert">
|
|
<linktarget COLOR="#b12c6e" DESTINATION="ID_613160281" ENDARROW="Default" ENDINCLINATION="-858;-29;" ID="Arrow_ID_1531249433" SOURCE="ID_306927735" STARTARROW="None" STARTINCLINATION="-361;27;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1675386676167" ID="ID_235963160" MODIFIED="1675387243008" TEXT="aktuell noch nicht klar welchen Content es hier geben wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
2/2023
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
diff-Binding UNIMPLEMENTED
|
|
</li>
|
|
<li>
|
|
TrackBody hat eine Collection vector<unique_ptr<RulerTrack>>
|
|
</li>
|
|
<li>
|
|
er verwendet diesen bisher aber nur, um die vertikale Ausdehnung zu berechnen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#e6345a" DESTINATION="ID_235963160" ENDARROW="Default" ENDINCLINATION="127;6;" ID="Arrow_ID_517947545" SOURCE="ID_284910451" STARTARROW="None" STARTINCLINATION="99;-7;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1675386889583" ID="ID_842520211" MODIFIED="1675386896697" TEXT="#1270 CanvasHook für Ruler">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1675387040398" ID="ID_184557686" MODIFIED="1675387059617" TEXT="DisplayFrame::getClipHook() ⟼ liefert DisplayFrame selber"/>
|
|
<node CREATED="1675387061219" ID="ID_317712434" MODIFIED="1675387122437" TEXT="⟹ DisplayFrame implementiert CanvasHook nur für eigentlichen Track-Content">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" color="#312a7f">int hookAdjY (int yPos)  override { return yPos + body_.getContentOffsetY(); };</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1675387200347" ID="ID_284910451" MODIFIED="1675387251007" TEXT="TODO: Zugriffsweg für Content definieren">
|
|
<arrowlink COLOR="#e6345a" DESTINATION="ID_235963160" ENDARROW="Default" ENDINCLINATION="127;6;" ID="Arrow_ID_517947545" STARTARROW="None" STARTINCLINATION="99;-7;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1675387257113" ID="ID_324465991" MODIFIED="1675387413606" TEXT="Anhaltspunkt: TreeMutator für Clips im TrackPresenter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieser greift im »Constructor« binding...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
vom TrackPresenter auf den DisplayFrame zu, um sich dort den CanvasHook zu holen (das ist der DisplayFrame selber, was aber opaque bleibt)
|
|
</li>
|
|
<li>
|
|
und gibt eine Referenz auf diesen CanvasHook dann an den ClipPresenter-ctor weiter....
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576757730509" FOLDED="true" ID="ID_1949130658" MODIFIED="1612002019554" TEXT="»Widget-Position« heraus-abstrahieren">
|
|
<linktarget COLOR="#47cdcd" DESTINATION="ID_1949130658" ENDARROW="Default" ENDINCLINATION="-1150;77;" ID="Arrow_ID_662295339" SOURCE="ID_730955223" STARTARROW="None" STARTINCLINATION="877;53;"/>
|
|
<linktarget COLOR="#605bb8" DESTINATION="ID_1949130658" ENDARROW="Default" ENDINCLINATION="204;611;" ID="Arrow_ID_993970158" SOURCE="ID_1816490333" STARTARROW="None" STARTINCLINATION="299;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576757867075" ID="ID_1947629675" MODIFIED="1576757891150" TEXT="der Themenkomplex "move()" steht isoliert da">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576757893399" ID="ID_309464876" MODIFIED="1576757905274" TEXT="eigentlich ein orthogonaler Belang"/>
|
|
<node CREATED="1576757919627" ID="ID_1712747746" MODIFIED="1576757937781" TEXT="tifft nur auf Widgets zu"/>
|
|
<node CREATED="1576757938869" ID="ID_89045363" MODIFIED="1576757947183" TEXT="könnte man nach innen weg abstrahieren?"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576757948912" ID="ID_441928116" MODIFIED="1584894637483" TEXT="Idee: Spezialisierung für Positioned<Widget>">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1576973905681" ID="ID_1230527469" MODIFIED="1584894640972" TEXT="Frage: sollte das seine Position kennen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1584889312752" ID="ID_606340373" MODIFIED="1584894649772" TEXT="Problem: redundante Storage ">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1584889354160" ID="ID_1826251720" MODIFIED="1584889364042" TEXT="immer genau wenn es attached ist"/>
|
|
<node CREATED="1584889364726" ID="ID_1490833507" MODIFIED="1584889375017" TEXT="sind seine Koordinaten im Canvas gespeichert"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584889393669" ID="ID_444152936" MODIFIED="1584894656821" TEXT="eigenes Interface -- näher am DisplayManager">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1584889606542" MODIFIED="1584889606542" TEXT="man könnte es sogar direkt in den display-manager.hpp packen"/>
|
|
<node CREATED="1584889606543" MODIFIED="1584889606543" TEXT="allerdings spielt es oft die Rolle eines "vereinfachten DisplayManager""/>
|
|
<node CREATED="1584889606544" ID="ID_298422140" MODIFIED="1584889621323" TEXT="und daher dann doch besser in einem eigenen Header"/>
|
|
<node CREATED="1584889621957" ID="ID_814318826" MODIFIED="1584889641912" TEXT="und ohne die Abhängigkeit auf Gtk::Widget">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erleichtert das Testen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894608428" ID="ID_1214957016" MODIFIED="1584932472009" TEXT="Sub-Interface CanvasHooked herauslösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1584894703681" ID="ID_101352353" MODIFIED="1584894725463" TEXT="ViewHook / CanvasHook">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1584894715892" ID="ID_70510619" MODIFIED="1584894722576" TEXT="oh Ja... viel schöner">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894728286" ID="ID_414399172" MODIFIED="1584894738145" TEXT="Test umschreiben auf CanvasHook">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894739041" ID="ID_1191395338" MODIFIED="1584932467447" TEXT="separaten Test für den Basis-Fall">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894751623" ID="ID_674921950" MODIFIED="1584932474570" TEXT="Interfaces in DisplayManager differenzieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894766013" ID="ID_1003825239" MODIFIED="1584932476358" TEXT="Interfaces im TrackPresenter differenzieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584894775935" ID="ID_241955108" MODIFIED="1584932477944" TEXT="Interfaces im ClipPresenter differenzieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1584932523675" ID="ID_715711411" MODIFIED="1584932535644" TEXT="hat auf allen Ebenen den Code verbessert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612002421081" ID="ID_704646941" MODIFIED="1666477585185">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber dieses Design ist <i>schief</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#ab3058" DESTINATION="ID_704646941" ENDARROW="Default" ENDINCLINATION="434;181;" ID="Arrow_ID_932322384" SOURCE="ID_781800644" STARTARROW="None" STARTINCLINATION="240;20;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1612002459090" ID="ID_336676484" MODIFIED="1612002485623" TEXT="und zwar die Code-reuse-Inheritance">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1612002487402" ID="ID_922768406" MODIFIED="1612002504506" TEXT="dadurch sind beide Belange übereinander geschichtet"/>
|
|
<node COLOR="#690f14" CREATED="1612002505382" ID="ID_1693567978" MODIFIED="1666475856413" TEXT="Bug: deshalb wird ein Widget zweimal an den Canvas geheftet">
|
|
<linktarget COLOR="#c16b96" DESTINATION="ID_1693567978" ENDARROW="Default" ENDINCLINATION="223;491;" ID="Arrow_ID_624678696" SOURCE="ID_1950742827" STARTARROW="None" STARTINCLINATION="1328;54;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666475819996" ID="ID_684542599" MODIFIED="1666475939536" TEXT="gelöst durch komplette Trennung ViewHook und CanvasHook">
|
|
<arrowlink DESTINATION="ID_1362647591" ENDARROW="Default" ENDINCLINATION="97;5;" ID="Arrow_ID_1885653608" STARTARROW="None" STARTINCLINATION="1;13;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612008761963" ID="ID_1362647591" MODIFIED="1612008774354" TEXT="die beiden Varianten komplett voneinander getrennt">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1362647591" ENDARROW="Default" ENDINCLINATION="97;5;" ID="Arrow_ID_1885653608" SOURCE="ID_684542599" STARTARROW="None" STARTINCLINATION="1;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575057172259" ID="ID_1193961919" MODIFIED="1575670553256" TEXT="Umordnen">
|
|
<linktarget COLOR="#507b9b" DESTINATION="ID_1193961919" ENDARROW="Default" ENDINCLINATION="-877;88;" ID="Arrow_ID_1469804818" SOURCE="ID_876124745" STARTARROW="None" STARTINCLINATION="576;33;"/>
|
|
<linktarget COLOR="#507b9b" DESTINATION="ID_1193961919" ENDARROW="Default" ENDINCLINATION="-877;88;" ID="Arrow_ID_624713040" SOURCE="ID_673183519" STARTARROW="None" STARTINCLINATION="483;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1575057384974" FOLDED="true" ID="ID_1385277309" MODIFIED="1576973973893" TEXT="komplexe Interaktion, die den ViewHook nur involviert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1575057402196" ID="ID_876005200" MODIFIED="1575057410423" TEXT="auch eine Vater-Kinder-Manipulation"/>
|
|
<node CREATED="1575057430215" ID="ID_581733037" MODIFIED="1575062500354" TEXT="Ablauf einer Umordnung">
|
|
<node CREATED="1575057417551" ID="ID_1701493626" MODIFIED="1575057429828" TEXT="Vater wird über Struktur-Änderung der Kinder informiert"/>
|
|
<node CREATED="1575059512193" ID="ID_921856520" MODIFIED="1575062511751" TEXT="zwei Lösungswege">
|
|
<node CREATED="1575059518703" ID="ID_1764144586" MODIFIED="1575059524142" TEXT="Ansatz-1">
|
|
<node CREATED="1575059530358" ID="ID_404301157" MODIFIED="1575059537927" TEXT="Vater iteriert über Kinder in neuer Reihenfolge"/>
|
|
<node CREATED="1575059541155" ID="ID_610399981" MODIFIED="1575059580051" TEXT="Vater fügt jedes Kind neu ein">
|
|
<node CREATED="1575059581239" ID="ID_754785544" MODIFIED="1575059601896" TEXT="Variante-a: an einer explizit angegebnen Stelle"/>
|
|
<node CREATED="1575059611327" ID="ID_459563354" MODIFIED="1575059649370" TEXT="Variante-b: an einer generischen (mitwandernden) Einfügestelle">
|
|
<node CREATED="1575059653776" ID="ID_619380343" MODIFIED="1575059668559" TEXT="OutputIterator"/>
|
|
<node CREATED="1575060060671" ID="ID_489178340" MODIFIED="1575060070529" TEXT="natürlicherweise (implizit) am Ende"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575059691448" ID="ID_420302373" MODIFIED="1575059695411" TEXT="Ansatz-2">
|
|
<node CREATED="1575059732675" ID="ID_719030510" MODIFIED="1575059745812" TEXT="Vater teilt einem geeigneten API die neue Reihenfolge mit"/>
|
|
<node CREATED="1575059756079" ID="ID_1636730345" MODIFIED="1575059762339" TEXT="hier zu klären...">
|
|
<node CREATED="1575059763481" ID="ID_550480062" MODIFIED="1575059844065" TEXT="wer trägt das "geeignete API"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575059772989" ID="ID_1511886975" MODIFIED="1575059778050" TEXT="das ViewHooked?"/>
|
|
<node CREATED="1575059778756" ID="ID_649016277" MODIFIED="1575059786031" TEXT="der ViewHook?"/>
|
|
<node CREATED="1575059787307" ID="ID_358129647" MODIFIED="1575059818627" TEXT="ein globaler Service?"/>
|
|
<node CREATED="1575059827654" ID="ID_1326854368" MODIFIED="1575059833698" TEXT="ein sonstwie bekannter Partner?"/>
|
|
</node>
|
|
<node CREATED="1575059851539" ID="ID_1623871336" MODIFIED="1575059862540" TEXT="wie ist die Reihenfolge gegeben?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575059874351" ID="ID_1396733200" MODIFIED="1575059902344" TEXT="als Index-Nummern der alten Ordnungs-Sequenz?">
|
|
<node CREATED="1575059903491" ID="ID_1689949230" MODIFIED="1575059908027" TEXT="d.h. als Permutation"/>
|
|
</node>
|
|
<node CREATED="1575059916074" ID="ID_186282838" MODIFIED="1575059947348" TEXT="als neue Positionsnummer auf dem jeweiligen Kind (=ViewHooked)?"/>
|
|
<node CREATED="1575059954461" ID="ID_469326705" MODIFIED="1575059965348" TEXT="als Iterator<ViewHooked>"/>
|
|
</node>
|
|
<node CREATED="1575062320101" ID="ID_1222751501" MODIFIED="1575062382290" TEXT="wer treibt das neu-Einfügen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575062383956" ID="ID_886243501" MODIFIED="1575062394950" TEXT="der Vater (push)?"/>
|
|
<node CREATED="1575062395713" ID="ID_1131423486" MODIFIED="1575062416276" TEXT="der Empfänger der neuen Ordnung (pull)?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575062926828" ID="ID_1755767601" MODIFIED="1575670525681" TEXT="geeignete Form finden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575062976413" ID="ID_332468301" MODIFIED="1575062979193" TEXT="Diskussion">
|
|
<node CREATED="1575062980979" ID="ID_1034492398" MODIFIED="1575062997550" TEXT="Ansatz-1 Variante-b">
|
|
<node CREATED="1575063012169" ID="ID_1112616431" MODIFIED="1575063016956" TEXT="erscheint natürlich"/>
|
|
<node CREATED="1575063075462" ID="ID_1658596486" MODIFIED="1575063094666" TEXT="zwei Ausprägungen möglich">
|
|
<node CREATED="1575063095757" ID="ID_1339415707" MODIFIED="1575063137739" TEXT="Ausprägung α">
|
|
<node CREATED="1575063150438" ID="ID_1366830537" MODIFIED="1575063158185" TEXT="Vater hat Zugang zum ViewHook"/>
|
|
<node CREATED="1575063163433" ID="ID_275623631" MODIFIED="1576282358093" TEXT="was grundsätzlich der Fall sein muß">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil der Vater ja auch neue Kinder "hooken" kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575063138735" ID="ID_1205459588" MODIFIED="1575063142611" TEXT="Ausprägung β">
|
|
<node CREATED="1575063213437" ID="ID_45088920" MODIFIED="1575653931186" TEXT="ViewHooked bietet eine rehook()-Operation an"/>
|
|
<node CREATED="1575063249066" ID="ID_1247469918" MODIFIED="1576282358092" TEXT="das löst das Problem des atomaren Umhängens">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. zugleich wird die alte Verbindung gelöst und die neue konstruiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575063323319" ID="ID_1005995191" MODIFIED="1575063331122" TEXT="Ansatz-2 Iterator-Variante">
|
|
<node CREATED="1575063332677" ID="ID_502498553" MODIFIED="1575063341072" TEXT="erscheint architektonisch geradlinig">
|
|
<node CREATED="1575063400796" ID="ID_247534963" MODIFIED="1575063415462" TEXT="nur der Vater kennt die konkrete Kind-Collection"/>
|
|
<node CREATED="1575063417093" ID="ID_540147437" MODIFIED="1575063426861" TEXT="das Umhängen ist dann aber eine einzige Operation"/>
|
|
</node>
|
|
<node CREATED="1575063438812" ID="ID_867929873" MODIFIED="1575063465918" TEXT="das Umhängen ist dann vom ViewHook zu leisten"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1575063488816" ID="ID_1685904360" MODIFIED="1575063652942" TEXT="Entscheidung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1575063493532" ID="ID_1153540378" MODIFIED="1575063501539" TEXT="neige der Iterator-Variante zu"/>
|
|
<node CREATED="1575063552664" ID="ID_485217910" MODIFIED="1575653993146" TEXT="mit PULL durch den ViewHook"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575062533708" ID="ID_246125405" MODIFIED="1575062538774" TEXT="Effekt am Ende">
|
|
<node CREATED="1575062539783" ID="ID_1502077216" MODIFIED="1575062550138" TEXT="die bestehenden, angebundenen Entitäten..."/>
|
|
<node CREATED="1575062551054" ID="ID_472742450" MODIFIED="1575062580390" TEXT="bestehen weiter, einschließlich aller iherer Kinder"/>
|
|
<node CREATED="1575062582191" ID="ID_1988970307" MODIFIED="1575062609909" TEXT="wurde jedoch mit dem Anfüge-Mechanismus erneut platziert"/>
|
|
<node CREATED="1575062611574" ID="ID_1786392621" MODIFIED="1575062625733" TEXT="und außerdem (vorher/nachher) aus der alten Platzierung herausgelöst"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575062654000" ID="ID_491999909" MODIFIED="1575062874337" TEXT="Fehlerbehandlung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1575062659140" ID="ID_1145995477" MODIFIED="1576282358092" TEXT="im Regelfall ist die Umordnung erfolgreich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt keinen prinzipiellen Grund, warum sie scheitern könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575062711080" ID="ID_883309689" MODIFIED="1575062740669" TEXT="die Umordnung findet in einer UI-Aktion statt"/>
|
|
<node CREATED="1575062743864" ID="ID_1277056906" MODIFIED="1575062754750" TEXT="alle anderen UI-Aktionen ruhen währenddessen"/>
|
|
<node CREATED="1575062772988" ID="ID_1056250153" MODIFIED="1575062785175" TEXT="alle Seiteneffekte und Nebenläufigkeiten können ignoriert werden"/>
|
|
<node CREATED="1575062787206" ID="ID_41541395" MODIFIED="1575062803994" TEXT="alle Konsequenzen der neu-Einfügung wirken sich erst nach Abschluß der Umordnung aus"/>
|
|
<node CREATED="1575062831427" ID="ID_147124730" MODIFIED="1575062863316" TEXT="auftretende Probleme sind fatal, korrumpieren das UI und beenden daher die Applikation">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575063747039" ID="ID_46486640" MODIFIED="1575670509535" TEXT="versuchsweise (im Test) zu implementieren">
|
|
<arrowlink COLOR="#4983c7" DESTINATION="ID_1374959238" ENDARROW="Default" ENDINCLINATION="-123;-10;" ID="Arrow_ID_463400867" STARTARROW="None" STARTINCLINATION="-428;25;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575063819852" FOLDED="true" ID="ID_1018000905" MODIFIED="1576973963964" TEXT="versuchsweise für Track-Head und Track-Body zu konkretisieren">
|
|
<arrowlink COLOR="#261eb7" DESTINATION="ID_237283777" ENDARROW="Default" ENDINCLINATION="551;-700;" ID="Arrow_ID_119083900" STARTARROW="None" STARTINCLINATION="-962;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575132495642" ID="ID_1247972866" MODIFIED="1575132530605" TEXT="Konsequenzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1575129919632" ID="ID_802422598" MODIFIED="1576973941306" TEXT="verlangt nach einem parent-ViewHooked">
|
|
<arrowlink COLOR="#4f94d2" DESTINATION="ID_1208770677" ENDARROW="Default" ENDINCLINATION="207;339;" ID="Arrow_ID_1505912691" STARTARROW="None" STARTINCLINATION="-349;-21;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575133551292" ID="ID_835255010" MODIFIED="1575133568929" TEXT="das verschachtelte "Einhäkeln" abstrahiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575133607557" ID="ID_72044277" MODIFIED="1575133623289" TEXT="muß (wohl) seinen eigenen Parent gar nicht kennen"/>
|
|
</node>
|
|
<node CREATED="1575132407767" ID="ID_29287629" MODIFIED="1575132523987" TEXT="ViewHook ist selber hierarchisch">
|
|
<linktarget COLOR="#3c3061" DESTINATION="ID_29287629" ENDARROW="Default" ENDINCLINATION="-725;0;" ID="Arrow_ID_1727524131" SOURCE="ID_1273254233" STARTARROW="None" STARTINCLINATION="-243;9;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1575132543936" ID="ID_427533687" MODIFIED="1576282358091" TEXT="im ursprünglichen Design hat mich der Canvas auf eine falsche Spur geschickt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn auch der Canvas ist ein Gtk::Container und hat eine Liste von Widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575132576721" ID="ID_386992526" MODIFIED="1575132611477" TEXT="der Canvas-Fall ist nämlich ehr die Ausnahme: hier brauche ich nur den Zugang"/>
|
|
<node CREATED="1575132621739" ID="ID_1654720759" MODIFIED="1575654907535" TEXT="ViewHook muß anhängen können">
|
|
<node CREATED="1575132630180" ID="ID_1788883872" MODIFIED="1575132645504" TEXT="daher muß es auf der jeweilgen Vater-Ebene liegen"/>
|
|
<node CREATED="1575132646516" ID="ID_252396856" MODIFIED="1575132656503" TEXT="und damit das Korrelat der Kinder als Collection halten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575133264914" ID="ID_1326993395" MODIFIED="1575133268453" TEXT="offen bleibt">
|
|
<node CREATED="1575133269937" ID="ID_94504130" MODIFIED="1575133810751" TEXT="genaue Rolle für den Canvas-Fall">
|
|
<node CREATED="1575133484429" ID="ID_1038579760" MODIFIED="1575133496775" TEXT="ist vermutlich gar nicht zu klären"/>
|
|
<node CREATED="1575133497534" ID="ID_1220643531" MODIFIED="1575133517054" TEXT="weil wir in diesem Fall weder Hierarchie noch Umordnen benötigen"/>
|
|
<node CREATED="1611434912899" ID="ID_625634456" MODIFIED="1611435039862" TEXT="nebenbei bemerkt: auch der Canvas-Fall ist letztlich verschachtelt/hierarchisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern nämlich auf dem Canvas einzelne Clip-Widgets liegen, und diese können wiederum einen eingebetteten Canvas haben, den man ggfs auch in Form eines nested ViewHook handhaben möchte. Die Details dazu sind aber im Moment noch nebulös, und ich sollte diesem Fall (noch) nicht zu viel Beachtung schenken.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575577935290" ID="ID_1062727687" MODIFIED="1575577945740" TEXT="wie viel Abstraktion ist hilfreich/notwendig?"/>
|
|
</node>
|
|
<node CREATED="1666476057276" ID="ID_1151114899" MODIFIED="1666476103630" TEXT="es sind also zwei getrennte (strukturell änliche Fälle)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und letztlich habe ich sie auch im Code komplett getrennt. CanvasHook und ViewHook haben nichts (mehr) miteinander zu tun
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575580539468" ID="ID_24590290" MODIFIED="1575580543581" TEXT="Fazit">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1575580549178" ID="ID_1674450886" MODIFIED="1575580561759" TEXT="es ist höchstens ein Baumuster"/>
|
|
<node CREATED="1575580565313" ID="ID_402497986" MODIFIED="1575580575171" TEXT="dieses kann durch generische Interfaces markiert werden"/>
|
|
<node CREATED="1575580576263" ID="ID_1283152567" MODIFIED="1575580591992" TEXT="an Kernfunktionalität bleibt aber eigentlich nur ein smart-Handle übrig"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573242004064" FOLDED="true" ID="ID_1106243162" MODIFIED="1576166469126" TEXT="Lib-Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1573242012238" ID="ID_870466825" MODIFIED="1573242115695" TEXT="halb generisch, halb OO"/>
|
|
<node COLOR="#990000" CREATED="1573242085554" ID="ID_1566257148" MODIFIED="1573242111268" TEXT="Ctor auf Friend limitiert">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1573242119197" ID="ID_1160468015" MODIFIED="1576282358091" TEXT="geht nicht ohne Weiteres">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"the children of your friends ain't necessarily your friends"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1573242125353" ID="ID_1681214217" MODIFIED="1576282358091" TEXT="KISS">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sonst müßte man das Einfügen als eine weitere (protected)-Operation auf dem ViewHook ausdrücken und könnte dann die Erzeugung des ViewHooked fest in den ViewHook ABC implementieren....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573242026324" ID="ID_760500508" MODIFIED="1573242047152" TEXT="verkapselte Ptr / Referenz">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573242048514" ID="ID_1803806630" MODIFIED="1573242060330" TEXT="automatische Deregistrierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575580315474" ID="ID_543063249" MODIFIED="1576282358090" TEXT="Neuordnung Namen und Interfaces (nach Analyse)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...hab mich davon überzeugt, daß die Namen <i>anders herum </i>verwendet werden sollten.
|
|
</p>
|
|
<p>
|
|
Das hängt auch damit zusammen, daß in der Praxsis die urspünglich konzipierte »Beziehungs-Entität« niemals eigens und eigenständig auftretend wird; vielmehr bekommen wir es mit einem speziellen Dekorator zu tun. Und dieser wird besser <b>ViewHooked</b><X> heißen. Damit ist das bisher schon verwirrend benannte "ViewHookable" komplett daneben, und es erscheint viel sinnvoller, diesem den titelgebenenden Namen <b>ViewHook</b>  zu zuzuordnen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575667886287" FOLDED="true" ID="ID_1416159951" MODIFIED="1582835881291" TEXT="Umbau auf ein ViewHooked<W>">
|
|
<arrowlink COLOR="#e79332" DESTINATION="ID_1096729219" ENDARROW="Default" ENDINCLINATION="-1237;46;" ID="Arrow_ID_1348207622" STARTARROW="None" STARTINCLINATION="2421;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575239353279" HGAP="53" ID="ID_777015627" MODIFIED="1575668026370" TEXT="statt frei stehendem ViewHook" VSHIFT="32">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1575239360140" ID="ID_1324997848" MODIFIED="1575239745292" TEXT="also direkt an die Lebensdauer des Widget gekoppelt"/>
|
|
<node CREATED="1575239401247" ID="ID_460745873" MODIFIED="1575566053491" TEXT="dann geht der hook()-Vorgang anders herum"/>
|
|
<node CREATED="1575239411717" ID="ID_1117119564" MODIFIED="1575239472817" TEXT="ViewHooked braucht als ctor-Parameter einen ViewHook&">
|
|
<node CREATED="1575667806989" ID="ID_553544414" MODIFIED="1575667821044" TEXT="ViewHook::hook() wird eine void-Operation"/>
|
|
<node CREATED="1575667821800" ID="ID_394226309" MODIFIED="1575667833698" TEXT="aber der ctor garantiert (RAII) daß sie aufgerufen wurde"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575833524632" HGAP="120" ID="ID_231779182" MODIFIED="1575835599586" TEXT="Problem ctor" VSHIFT="1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575833555676" ID="ID_737726791" MODIFIED="1576282358089" TEXT="keine zwingende Verknüpfung mehr möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil nun ViewHooked schon als ctor-Parameter einen ViewHook bekommen muß...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1575833618837" ID="ID_887542907" MODIFIED="1575833631133" TEXT="ist aber auch nicht schlecht"/>
|
|
<node CREATED="1575833632321" ID="ID_1044442678" MODIFIED="1575833656034" TEXT="denn andererseits ist ja jetzt ein Ctor-Parameter (ViewHook) Pflicht"/>
|
|
</node>
|
|
<node CREATED="1575833658571" ID="ID_655849348" MODIFIED="1575833684255" TEXT="Organisieren der zusätzlichen ctor-Parameter">
|
|
<node CREATED="1575833685238" ID="ID_82723715" MODIFIED="1575833692549" TEXT="das Widget kann beliebige Parameter haben"/>
|
|
<node CREATED="1575833693396" ID="ID_277553736" MODIFIED="1575833711002" TEXT="(optional) kann der Hook sofort mit Koordinaten gemacht werden"/>
|
|
<node CREATED="1575833718110" ID="ID_1601089341" MODIFIED="1575833729995" TEXT="das wird eine problematische Signatur...">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1575833751257" ID="ID_1701112838" MODIFIED="1575833756633" TEXT="Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1575833758080" ID="ID_1219297677" MODIFIED="1575833762271" TEXT="zwei overloads"/>
|
|
<node CREATED="1575833763086" ID="ID_1612844126" MODIFIED="1575833769762" TEXT="mit einem Parameter-Objekt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1575845525564" HGAP="47" ID="ID_960595364" MODIFIED="1575845553029" VSHIFT="2">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung: <b>NonCopoyable</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1575845555959" ID="ID_525736994" MODIFIED="1575845568687" TEXT="auch wenn manches dadurch etwas mühsam wird">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1575845569870" ID="ID_1676564226" MODIFIED="1576282358089" TEXT="es kann niemals in Ordnung sein, wenn ein ViewHooked-Widget irgendwohin verschoben wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn vernünftigerweise muß man davon ausgehen, daß der Canvas (oder wo auch immer das element platziert wird) sich einen Pointer speichert, und diesen später auch aktiv verwenden wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1575845652221" ID="ID_421248587" MODIFIED="1575845662717" TEXT="Probleme mit dem Diff?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#338800" CREATED="1575845663683" ID="ID_1462842573" MODIFIED="1575845666297" TEXT="Nein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1575845667928" ID="ID_1075657908" MODIFIED="1575845691162" TEXT="genau deshalb verwenden wir vector<unique_ptr<XYZ>>">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575580366411" ID="ID_1747264667" MODIFIED="1575670501324" TEXT="API für Umordnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1575660738481" ID="ID_316759979" MODIFIED="1575660770786" TEXT="einfachst mögliche Iterator-Lösung">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575660751327" ID="ID_1263771356" MODIFIED="1575670503370" TEXT="generische Standard-Implementierung mit entwerfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582503131945" FOLDED="true" ID="ID_1439869815" MODIFIED="1582835809970" TEXT="Problem Covarianz">
|
|
<linktarget COLOR="#66226c" DESTINATION="ID_1439869815" ENDARROW="Default" ENDINCLINATION="-760;97;" ID="Arrow_ID_655919678" SOURCE="ID_1081924103" STARTARROW="None" STARTINCLINATION="1574;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582503148935" ID="ID_10487556" MODIFIED="1582503193549" TEXT="ViewHooked<WiX> für ViewHook<WID> mit WiX <: WID">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1582503195681" ID="ID_1990820177" MODIFIED="1582503216832" TEXT="d.h. der ViewHook kann für einen Basistyp sein (Gtk::Widget)"/>
|
|
<node CREATED="1582503217854" ID="ID_251546067" MODIFIED="1582503228370" TEXT="aber das ViewHooked muß definitiv auf den konkreten Typ laufen"/>
|
|
<node COLOR="#338800" CREATED="1582503985261" ID="ID_257480805" MODIFIED="1582833223291" TEXT="formale Probleme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582503991839" ID="ID_1202924681" MODIFIED="1582503998695" TEXT="C++ unterstützt keine Covarianz">
|
|
<node CREATED="1582504004549" ID="ID_1855610953" MODIFIED="1582504013861" TEXT="d.h. an einer Seite "klemmt" es immer"/>
|
|
<node CREATED="1582504016734" ID="ID_973744286" MODIFIED="1582504028245" TEXT="entweder wir verlangen einen zu konkreten Typ"/>
|
|
<node CREATED="1582504058994" ID="ID_638337039" MODIFIED="1582504106019" TEXT="oder der Callback auf den generischen ViewHook wird vom Typsystem abgelehnt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dieses nicht weiß, daß es sich um eine Subtyp-Beziehung handelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582504116207" ID="ID_1623671836" MODIFIED="1582833196285" TEXT="Versuch, einen 2.Template-Parameter einzuführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582504139651" ID="ID_1687494401" MODIFIED="1582504144187" TEXT="analoges Problem"/>
|
|
<node COLOR="#338800" CREATED="1582504145369" ID="ID_580143907" MODIFIED="1582832828804" TEXT="die rehook()-Funktion ist virtuell">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582504155332" ID="ID_1039269734" MODIFIED="1582504165753" TEXT="aber auf welchen Argument-Typ soll sie gehen"/>
|
|
<node COLOR="#752823" CREATED="1582504166485" ID="ID_1815913326" MODIFIED="1582832879268" TEXT="leider steckt im Argument-Typ das konkrete ViewHookable">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1582832787665" ID="ID_770114878" MODIFIED="1582832790629" TEXT="warum?"/>
|
|
<node CREATED="1582832791081" ID="ID_921622013" MODIFIED="1582833095134" TEXT="aus logischen Gründen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ich wollte dadurch ausdrücken, daß das übergebene ViewHooked<Widget>& ursprünglich schon einmal geHooked worden war. Tatsächlich hat ja im originalen Design der ViewHook das Hookable sogar erst konstruiert, und niemand sonst konnte das. Da wir aber nun inzwischen immer mit einem ViewHookable mit eingebettetem Widget arbeiten, muß dieses freistehend konstruiert werden, und des gibt keine direkte Möglichkeit mehr, diese "Verdongelung" auszudrücken. Und außerdem sind auch alle weiteren Ideen aufgegeben, welche auf eine engere Verzahnung der Interfaces aufbauen würden (Stichwort "quer-Beweglichkeit").
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582832796288" ID="ID_1100021505" MODIFIED="1582833171700" TEXT="praktisch wird es nie gebraucht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...praktisch könnte es zwar sein, daß wir darauf angewiesen sind, das Widget schon zu kennen. Konkret ist das aber im Moment nicht der Fall, und ich sollte mir darüber jetzt auch keine Gedanken machen; das Design muß ohnehin später nochmal überarbeitet werden...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582832808423" ID="ID_1387322839" MODIFIED="1582833220634" TEXT="zurückbauen; rehook(Widget&,...) genügt">
|
|
<arrowlink COLOR="#26405f" DESTINATION="ID_397336403" ENDARROW="Default" ENDINCLINATION="144;5;" ID="Arrow_ID_782941996" STARTARROW="None" STARTINCLINATION="112;14;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582833177077" ID="ID_397336403" MODIFIED="1582833220634" TEXT="damit geht das dann, und ist auch nicht besonders schlimm">
|
|
<linktarget COLOR="#26405f" DESTINATION="ID_397336403" ENDARROW="Default" ENDINCLINATION="144;5;" ID="Arrow_ID_782941996" SOURCE="ID_1387322839" STARTARROW="None" STARTINCLINATION="112;14;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582833227086" ID="ID_895188425" MODIFIED="1582833268779" TEXT="man kann das Problem im Moment "umschiffen"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und ich glaube, das ganze Konstrukt wird nicht wesentlich "tiefer" werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582833292120" ID="ID_476079369" MODIFIED="1582833303018" TEXT="der ViewHook arbeitet eben implizit immer mit dem Basistyp"/>
|
|
<node CREATED="1582833303639" ID="ID_1136204632" MODIFIED="1582833315633" TEXT="und konvertiert die Referenzen automatisch hoch"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612003404589" ID="ID_1629772875" MODIFIED="1612008746849" TEXT="Problem Code-reuse-Inheritance">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612003423875" ID="ID_781800644" MODIFIED="1612003549567">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ursache ist ein <i>schiefes Design</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist wohl entstanden, weil ich ursprünglich einen generischen Visitor im Blick hatte; es hat sich aber dann gezeigt, daß eine solche universelle "Quer-Beweglichkeit" weder notwendig noch wünschenswert ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#ab3058" DESTINATION="ID_704646941" ENDARROW="Default" ENDINCLINATION="434;181;" ID="Arrow_ID_932322384" STARTARROW="None" STARTINCLINATION="240;20;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612003579934" ID="ID_852410527" MODIFIED="1612008743069" TEXT="Refactoring: ViewHook und CanvasHook komplett trennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573242259267" ID="ID_1903570032" MODIFIED="1576166466194" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1573242271641" ID="ID_226481127" MODIFIED="1573242355581" TEXT="Basisfall">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573242278975" ID="ID_1541691410" MODIFIED="1573245310701" TEXT="Verschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575835636260" ID="ID_586282311" MODIFIED="1575850911796" TEXT="umgebautes API">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1575845706047" ID="ID_648457397" MODIFIED="1575850810943" TEXT="Bugs im Test">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1575845717980" ID="ID_1253092913" MODIFIED="1575850755101" TEXT="Move-Construction does not detach automatically">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1575850756523" ID="ID_1734105343" MODIFIED="1575850759529" TEXT="well...."/>
|
|
<node CREATED="1575850759950" ID="ID_355300034" MODIFIED="1575850769568" TEXT="it can not possibly be expected to do so">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575845743838" ID="ID_1827383151" MODIFIED="1582503290754" TEXT="testContainsSequence()-predicate does not work properly in the initial base check">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
again the problem with the reversed order due to forward_list
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575063870245" ID="ID_1374959238" MODIFIED="1575670505352" TEXT="Umordnen">
|
|
<linktarget COLOR="#4983c7" DESTINATION="ID_1374959238" ENDARROW="Default" ENDINCLINATION="-123;-10;" ID="Arrow_ID_463400867" SOURCE="ID_46486640" STARTARROW="None" STARTINCLINATION="-428;25;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563019044455" ID="ID_1947863751" MODIFIED="1563019051553" TEXT="Style / CSS-Struktur">
|
|
<node CREATED="1563019065682" ID="ID_277910782" MODIFIED="1563019083259" TEXT="grundsätzlich durch Widget im UI definiert"/>
|
|
<node CREATED="1563019091550" ID="ID_342336016" MODIFIED="1563019113940" TEXT="Struktur im TimelineWidget">
|
|
<node CREATED="1563019373733" ID="ID_412703124" MODIFIED="1563019379308" TEXT="Widget-Struktur">
|
|
<node CREATED="1563019390913" ID="ID_197164350" MODIFIED="1563019403082" TEXT="teilweise ein Implementierungs-Detail"/>
|
|
</node>
|
|
<node CREATED="1563019380597" ID="ID_7366061" MODIFIED="1563019384050" TEXT="Kontrollstruktur"/>
|
|
</node>
|
|
<node CREATED="1563019137720" ID="ID_1085825572" MODIFIED="1563019142563" TEXT="systematisch">
|
|
<node CREATED="1563019146591" ID="ID_105242868" MODIFIED="1563036084505" TEXT=""auf was können CSS-Selektoren aufbauen"?">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_105242868" ENDARROW="Default" ENDINCLINATION="1295;0;" ID="Arrow_ID_708537872" SOURCE="ID_180592409" STARTARROW="None" STARTINCLINATION="825;-325;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1563019196947" ID="ID_1289853928" MODIFIED="1563019204755" TEXT="Ankerpunkt">
|
|
<node CREATED="1563019232304" ID="ID_206396832" MODIFIED="1563019237151" TEXT="Class: .timeline-page"/>
|
|
<node CREATED="1563019248349" ID="ID_795857264" MODIFIED="1563019257692" TEXT="Element: paned"/>
|
|
</node>
|
|
<node CREATED="1563019278662" ID="ID_649362322" MODIFIED="1563019282193" TEXT="Kinder">
|
|
<node CREATED="1563019283116" ID="ID_1537337657" MODIFIED="1563019286632" TEXT="head.timeline"/>
|
|
<node CREATED="1563019287444" ID="ID_262145100" MODIFIED="1563019291575" TEXT="body.timeline">
|
|
<node CREATED="1563019321399" ID="ID_1831987488" MODIFIED="1563019329149" TEXT="fork.timeline"/>
|
|
<node CREATED="1563019330262" ID="ID_847433793" MODIFIED="1563019334721" TEXT="canvas.timeline"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563019421405" ID="ID_985036312" MODIFIED="1563019426415" TEXT="Beispiele">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1563019440558" ID="ID_1321598849" MODIFIED="1576282358088" TEXT="Scope-Insets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Vertiefungen im Anzeige-Profil
|
|
</p>
|
|
<p>
|
|
auf der rechten Seite, wo der Content angezeigt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node COLOR="#435e98" CREATED="1563019476308" ID="ID_83481977" MODIFIED="1563044164753" TEXT=".timeline-page > box.timeline-body fork.timeline">
|
|
<linktarget COLOR="#419bcf" DESTINATION="ID_83481977" ENDARROW="Default" ENDINCLINATION="666;0;" ID="Arrow_ID_1386111155" SOURCE="ID_1803180287" STARTARROW="None" STARTINCLINATION="-787;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1479688613990" ID="ID_1537299376" MODIFIED="1582988088360" TEXT="Strukturänderung">
|
|
<linktarget COLOR="#7aacc3" DESTINATION="ID_1537299376" ENDARROW="Default" ENDINCLINATION="-632;83;" ID="Arrow_ID_1708561781" SOURCE="ID_1883527171" STARTARROW="None" STARTINCLINATION="806;36;"/>
|
|
<node CREATED="1479688621637" ID="ID_71591229" MODIFIED="1557498707224" TEXT="notwendig: strukturelles Modell">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1479688633483" ID="ID_1301490505" MODIFIED="1557498707224" TEXT="Elemente in diesem halten einen display-context"/>
|
|
<node CREATED="1479688653913" ID="ID_1435784278" MODIFIED="1557498707224" TEXT="dieser wiederum muß für jede Erweiterung konsultiert werden"/>
|
|
<node CREATED="1573408604958" ID="ID_1376892828" MODIFIED="1576282358088" TEXT="Vorsicht: Struktur ist teilsweise in der Display-Implentierung aufgedoppelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das muß auch so sein, denn sonst wäre das systematische Modell und die Controller zu eng mit dem Display-Code verwoben. Der Nachteil ist aber, daß derart aufgedoppelte Struktur bei jeder Strukturänderung invalide wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1575576966709" ID="ID_1527842637" MODIFIED="1575576970675" TEXT="Lösung">
|
|
<node CREATED="1575576971732" ID="ID_876124745" MODIFIED="1575577071507" TEXT="slave-Elemente über Beziehungs-Entität angekoppelt">
|
|
<arrowlink COLOR="#507b9b" DESTINATION="ID_1193961919" ENDARROW="Default" ENDINCLINATION="-877;88;" ID="Arrow_ID_1469804818" STARTARROW="None" STARTINCLINATION="576;33;"/>
|
|
</node>
|
|
<node CREATED="1575050510878" ID="ID_646844971" MODIFIED="1575577381370" TEXT="Diff bietet automatische Benachrichtigung bei Strukturänderung">
|
|
<arrowlink COLOR="#624d7d" DESTINATION="ID_101148427" ENDARROW="Default" ENDINCLINATION="-3637;-782;" ID="Arrow_ID_498364014" STARTARROW="None" STARTINCLINATION="2862;94;"/>
|
|
<node COLOR="#338800" CREATED="1576168044826" ID="ID_1758473434" MODIFIED="1576441607969" TEXT="#1206 diff structure change listener">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487465759930" HGAP="19" ID="ID_923619509" MODIFIED="1557498707224" VSHIFT="26">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#d71313">Problem</font>: Slave-Timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1487465830224" ID="ID_614775878" MODIFIED="1557498707224" TEXT="mehrere Ansichten für die gleiche Timeline"/>
|
|
<node CREATED="1487465882513" ID="ID_347013155" MODIFIED="1557498707224" TEXT="Gründe">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1487465847518" ID="ID_1430621359" MODIFIED="1557498707224" TEXT="bewußt verschiedene Ausschnitte"/>
|
|
<node CREATED="1487465854653" ID="ID_921534930" MODIFIED="1557498707224" TEXT="unbeabsichtigt in verschiedenen Fenstern"/>
|
|
<node CREATED="1487465866499" ID="ID_354960009" MODIFIED="1557498707224" TEXT="Fokussierte Ansicht einer nested sequence"/>
|
|
</node>
|
|
<node CREATED="1487465918884" ID="ID_1775013701" MODIFIED="1557498707224" TEXT="Lösungs-Ansätze">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1487465924572" ID="ID_542870958" MODIFIED="1557498707224" TEXT="auf Widget-Ebene doppeln">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1487465932554" ID="ID_450673459" MODIFIED="1557498707224" TEXT="greift in die direkte Diff-Mechanik ein"/>
|
|
<node CREATED="1487465947504" ID="ID_284663745" MODIFIED="1557498707224" TEXT="Timeline-Komponenten sind selber beliebig komplex"/>
|
|
<node CREATED="1487465960198" ID="ID_1257024935" MODIFIED="1557498707224" TEXT="Annahme war immer, daß Presenter nahe am Widget arbeitet"/>
|
|
</node>
|
|
<node CREATED="1487465985315" ID="ID_1891341453" MODIFIED="1557498707224" TEXT="Timeline-Controller-Slaves">
|
|
<node CREATED="1487465996906" ID="ID_1882876532" MODIFIED="1557498707224" TEXT="machbar"/>
|
|
<node CREATED="1487465999417" ID="ID_1034026426" MODIFIED="1557498707224" TEXT="typische Clustering-Probleme"/>
|
|
<node CREATED="1487466005952" ID="ID_465457871" MODIFIED="1557498707224" TEXT="Scheitern in-Memory unwahrscheinlich"/>
|
|
<node CREATED="1487466021990" ID="ID_212586057" MODIFIED="1557498707224" TEXT="Controller muß aktiv mitwirken"/>
|
|
</node>
|
|
<node CREATED="1487466040524" ID="ID_646231524" MODIFIED="1557498707224" TEXT="Timeline-Slave in der Session">
|
|
<linktarget COLOR="#5793da" DESTINATION="ID_646231524" ENDARROW="Default" ENDINCLINATION="186;21;" ID="Arrow_ID_431447729" SOURCE="ID_1227431164" STARTARROW="None" STARTINCLINATION="26;-3;"/>
|
|
<node CREATED="1487466064520" ID="ID_1607482571" MODIFIED="1557498707224" TEXT="macht Doppelung explizit"/>
|
|
<node CREATED="1487466078743" ID="ID_1134944510" MODIFIED="1557498707224" TEXT="Problem mit den Element-IDs"/>
|
|
<node CREATED="1487466090917" ID="ID_1611961848" MODIFIED="1557498707224" TEXT="UI -> Session ist unproblematisch"/>
|
|
<node CREATED="1487466100372" ID="ID_1630288830" MODIFIED="1557498707224" TEXT="Session/Builder muß aufdoppeln">
|
|
<node CREATED="1487466111930" ID="ID_966355925" MODIFIED="1557498707224" TEXT="Diff-Nachrichten"/>
|
|
<node CREATED="1487466115154" ID="ID_260455064" MODIFIED="1557498707224" TEXT="Fehler-Markierungen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487466966478" ID="ID_479759046" MODIFIED="1557498707224" TEXT="#1083 solution for Timeline slave">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1487466997138" ID="ID_1028434909" MODIFIED="1557498707224" TEXT="auf später vertagt">
|
|
<linktarget COLOR="#bfb5ce" DESTINATION="ID_1028434909" ENDARROW="Default" ENDINCLINATION="-1311;-1012;" ID="Arrow_ID_1339464508" SOURCE="ID_1624061939" STARTARROW="None" STARTINCLINATION="505;-47;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1487466986523" ID="ID_39632539" MODIFIED="1557498707224" TEXT="zunächst unterbinden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1539258805201" ID="ID_1227431164" MODIFIED="1576282358087" TEXT="gegenwärtig Präferenz erkennbar....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...für die dritte Lösung, die Repräsentation bereits in der Session
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5793da" DESTINATION="ID_646231524" ENDARROW="Default" ENDINCLINATION="186;21;" ID="Arrow_ID_431447729" STARTARROW="None" STARTINCLINATION="26;-3;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539388923323" ID="ID_430199880" MODIFIED="1557498707224">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#e71c1c">Problem</font>: alle Timelines der Session repräsentieren?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#c8a1fe" DESTINATION="ID_430199880" ENDARROW="Default" ENDINCLINATION="-629;0;" ID="Arrow_ID_1293894659" SOURCE="ID_585499856" STARTARROW="None" STARTINCLINATION="-505;56;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1539389184120" ID="ID_1213259045" MODIFIED="1557498707224" TEXT="vorläufig: immer">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1539389333308" ID="ID_1581229247" MODIFIED="1557498707224" TEXT="wer kann das entscheiden?">
|
|
<node CREATED="1539389339515" ID="ID_1778009129" MODIFIED="1557498707224" TEXT="Entscheider muß am UI-Bus hängen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1539389345674" ID="ID_742174622" MODIFIED="1557498707224" TEXT="also der TimelineController">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539389243488" ID="ID_1100284261" MODIFIED="1557498707224" TEXT="man könnte das als GUI-State auslegen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1539389266141" ID="ID_1321613506" MODIFIED="1557498707224" TEXT="collapsed?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1479774700668" FOLDED="true" HGAP="47" ID="ID_1407821684" MODIFIED="1557498707224" TEXT="Mutation" VSHIFT="13">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1479774705839" FOLDED="true" ID="ID_301222108" MODIFIED="1679088613181" TEXT="Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#d30f0f" CREATED="1479774731141" ID="ID_1523088286" MODIFIED="1557498707225" TEXT="Element != Widget"/>
|
|
<node COLOR="#640c0c" CREATED="1479774764575" ID="ID_1338013643" MODIFIED="1557498707225" TEXT="DiffApplikator geht einfach von STL-Collection aus">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1479774747753" ID="ID_279553704" MODIFIED="1557498707225" TEXT="Umordnen der Elemente hat keinen Effekt auf die Anzeige">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480120294912" HGAP="31" ID="ID_1734639851" MODIFIED="1557498707225" VSHIFT="23">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
grundsätzliches
|
|
</p>
|
|
<p>
|
|
Problem
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1480120349873" ID="ID_795629510" MODIFIED="1557498707225" TEXT="Diff repräsentiert Änderungen indirekt"/>
|
|
<node CREATED="1480120487509" ID="ID_1693545323" MODIFIED="1557498707225">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
speziell die Umordnungen <i>ergeben sich</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480120359191" ID="ID_1039094699" MODIFIED="1557498707225" TEXT="Widget-Container hat keine Änderungs-Schnittstelle"/>
|
|
<node COLOR="#338800" CREATED="1480725417748" HGAP="28" ID="ID_1996114890" MODIFIED="1557498707225" TEXT="...war dann doch kein so schlimmes Problem" VSHIFT="7">
|
|
<arrowlink COLOR="#69ee12" DESTINATION="ID_1964453367" ENDARROW="Default" ENDINCLINATION="-55;-87;" ID="Arrow_ID_636465261" STARTARROW="None" STARTINCLINATION="-116;69;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480120516442" FOLDED="true" ID="ID_880374813" MODIFIED="1557498707225" TEXT="Ansätze">
|
|
<node CREATED="1480120531935" ID="ID_1894474191" MODIFIED="1561827465251" TEXT="Dekorator auf TreeMutator">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1480121069464" ID="ID_1707876611" MODIFIED="1557498707225" TEXT="Operationen mitlesen"/>
|
|
<node CREATED="1480121074703" ID="ID_1346494338" MODIFIED="1576282358087" TEXT="Notifikations-Schnittstelle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und der Dekorator würde die beobachteten Operationen
|
|
</p>
|
|
<p>
|
|
an diese Notifikations-Schnittstelle senden.
|
|
</p>
|
|
<p>
|
|
Implementiert würde sie vom jeweiligen Widget
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480123478013" ID="ID_1281325973" MODIFIED="1576282358086" TEXT="eine Ebene zu tief, aber geht noch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
korrekt wäre, die Diff-Verben mitzulesen.
|
|
</p>
|
|
<p>
|
|
<i>Das </i>geht aber nicht, weil wir intern (aktiv) iterieren.
|
|
</p>
|
|
<p>
|
|
Wollten wir das doch, müßten wir das gesamte Diff-Applikator-Design wegwerfen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Da aber eigentlich eine 1:1-Zuordnung zwischen Diff-Verben und Operations-Primitiven besteht,
|
|
</p>
|
|
<p>
|
|
könnte man trotzdem (mit etwas Hängen und Würgen) noch hinkommen.
|
|
</p>
|
|
<p>
|
|
Der Dekorator würde also auf dem TreeMutator sitzen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480121092492" ID="ID_1543810707" MODIFIED="1576282358085" TEXT="Löschungen nur heuristisch zu erkennen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Weil wir die "skip"-Operation für zwei Zwecke verwenden,
|
|
</p>
|
|
<p>
|
|
und man im Skip nicht weiß, ob man das Element überhaupt noch anfassen darf,
|
|
</p>
|
|
<p>
|
|
denn es könnte ja auch ein von "find" zurückgelassener Müll sein.
|
|
</p>
|
|
<p>
|
|
Daher gibt es die matchSrc-Operation. Effektiv wird die aber nur bei einem Delete aufgerufen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480123741362" ID="ID_586646895" MODIFIED="1576282358085" TEXT="unsauber, hässlich, unglücklich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
man sitzt mit dem Detektor unter dem API
|
|
</li>
|
|
<li>
|
|
dadurch entstehen "ungeschriebene Regeln", wie das API auzurufen ist
|
|
</li>
|
|
<li>
|
|
alternativ könnten wir die Operationen komplett 1:1 definieren, also eine explizite delete-Operation einführen
|
|
</li>
|
|
<li>
|
|
dafür würde dann die matchSrc wegfallen, was praktisch alle sinnvollen Unit-Tests stark beschränkt.
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480123380843" ID="ID_1717666432" MODIFIED="1557498707225" TEXT="wäre prinzipiell machbar">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480121177145" ID="ID_1964453367" MODIFIED="1557498707225" TEXT="Widget is delegate/slave">
|
|
<linktarget COLOR="#69ee12" DESTINATION="ID_1964453367" ENDARROW="Default" ENDINCLINATION="-55;-87;" ID="Arrow_ID_636465261" SOURCE="ID_1996114890" STARTARROW="None" STARTINCLINATION="-116;69;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1480121209277" ID="ID_834494092" MODIFIED="1557498707225" TEXT="Hinzufügungen erzeugen neue Widgets">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1480121219579" ID="ID_1906821886" MODIFIED="1557498707225" TEXT="Löschungen entfernen das zugehörige Widget">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1480121271493" ID="ID_1169797519" MODIFIED="1557498707225" TEXT="Reihenfolge ist nebensächlich">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1480123311260" ID="ID_1288896772" MODIFIED="1557498707225" TEXT="Reihenfolge der Widgets == Z-Ordnung"/>
|
|
<node CREATED="1480123321707" ID="ID_1842225087" MODIFIED="1557498707225" TEXT="das ist ein reiner UI-Belang"/>
|
|
<node CREATED="1480123330521" ID="ID_255024472" MODIFIED="1557498707225" TEXT="Reihenfolge der Tracks wird im UI realisiert"/>
|
|
<node CREATED="1480123353030" ID="ID_871730723" MODIFIED="1557498707225" TEXT="Reihenfolge der Clips wird redundant (durch Position) gegeben"/>
|
|
</node>
|
|
<node COLOR="#bd304f" CREATED="1573408400309" ID="ID_240517447" MODIFIED="1573411462228" TEXT="Vorsicht: parallel gebaute Strukturen sind gefährlich">
|
|
<arrowlink COLOR="#774779" DESTINATION="ID_1728979524" ENDARROW="Default" ENDINCLINATION="-1429;-736;" ID="Arrow_ID_1394313218" STARTARROW="None" STARTINCLINATION="-692;36;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1573408424206" ID="ID_210523305" MODIFIED="1573408436104" TEXT="diese sind oftmals notwendig, um den Code wartbar zu halten"/>
|
|
<node CREATED="1573408436949" ID="ID_429179986" MODIFIED="1573409776349" TEXT="Beispiel: TrackBody - Struktur">
|
|
<linktarget COLOR="#73618d" DESTINATION="ID_429179986" ENDARROW="Default" ENDINCLINATION="502;276;" ID="Arrow_ID_635099577" SOURCE="ID_101081525" STARTARROW="None" STARTINCLINATION="278;11;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1573408465433" ID="ID_1549970410" MODIFIED="1573408481827" TEXT="diese doppelt die Kontroll-Struktur der Track(Presenter) auf"/>
|
|
<node CREATED="1573408515992" ID="ID_1316818344" MODIFIED="1573408548407" TEXT="sie ist notwendig, um den TrackPresenter vom reinen Display-Code zu trennen"/>
|
|
<node CREATED="1573408487478" ID="ID_758564014" MODIFIED="1573408506255" TEXT="nach jeder Struktur-Änderung der Tracks ist diese Struktur invalide geworden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480123881912" HGAP="6" ID="ID_1550301342" MODIFIED="1557498707225" TEXT="Schlußfolgerung" VSHIFT="3">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1480123900845" ID="ID_1099759004" MODIFIED="1557498707225" TEXT="wir mutieren ein Modell-Objekt"/>
|
|
<node CREATED="1480123908524" ID="ID_599072568" MODIFIED="1557498707225" TEXT="das Widget hängt an diesem als kompletter Slave">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480123920371" ID="ID_413127533" MODIFIED="1557498707225" TEXT="Registrierung / Deregistrierung muß vollautomatisch sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1480124094867" ID="ID_1956638484" MODIFIED="1557498707225">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nach </i>der Mutation erfolgt <b>Display-Neubewertung</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1480124145476" ID="ID_1268974326" MODIFIED="1557498707225" TEXT="für einen ganzen Scope"/>
|
|
<node CREATED="1480124153979" ID="ID_887707794" MODIFIED="1557498707225" TEXT="stellt fest, was gezeigt werden muß"/>
|
|
<node CREATED="1480124174144" ID="ID_1145067443" MODIFIED="1557498707225" TEXT="synthetisiert Anzeige-Parameter (z.B: Koordinaten, Z-Ordnung)"/>
|
|
<node CREATED="1480124235128" ID="ID_162610711" MODIFIED="1575053313157" TEXT="muß inkrementell arbeiten und bestehende Widgets an neue Reihenfolge anpassen">
|
|
<arrowlink COLOR="#d6677c" DESTINATION="ID_1660005887" ENDARROW="Default" ENDINCLINATION="130;-668;" ID="Arrow_ID_1942101483" STARTARROW="None" STARTINCLINATION="730;24;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480300573857" FOLDED="true" HGAP="68" ID="ID_434577605" MODIFIED="1679360167655" TEXT="Anzeige-Steuerung" VSHIFT="39">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1480300627712" ID="ID_1748490788" MODIFIED="1557498707225" TEXT="Display-Manager">
|
|
<node CREATED="1480300640790" ID="ID_1461181527" MODIFIED="1557498707225" TEXT="Abstraktion">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1480300645837" ID="ID_337010957" MODIFIED="1557498707225" TEXT="Interface"/>
|
|
<node CREATED="1480300649437" ID="ID_704277125" MODIFIED="1557498707225">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
interagiert mit den <b>Presentern</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480300584454" ID="ID_202830560" MODIFIED="1557498707225" TEXT="globaler Layout-Manager">
|
|
<node CREATED="1480300595820" ID="ID_1004344887" MODIFIED="1557498707225" TEXT="fungiert als Service"/>
|
|
<node CREATED="1480300614873" ID="ID_895306481" MODIFIED="1557498707225" TEXT="Ermitteln konkreter Koordinaten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480300682256" ID="ID_1828380850" MODIFIED="1557498707225" TEXT="Presenter">
|
|
<node CREATED="1480300690191" ID="ID_1405428387" MODIFIED="1557498707225" TEXT="sind lokales Struktur-Modell">
|
|
<node CREATED="1480300733506" ID="ID_186466790" MODIFIED="1557498707225" TEXT="werden per Diff manipuliert"/>
|
|
<node CREATED="1480300740537" ID="ID_1322437138" MODIFIED="1576282358084" TEXT="enthalten die Modell-Binding-Daten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. eine LUID
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480300699694" ID="ID_1686150984" MODIFIED="1557498707225" TEXT="aktiver Part der View-Steuerung"/>
|
|
<node CREATED="1480300717747" ID="ID_1736166807" MODIFIED="1557498707225" TEXT="Master-Slave für die Widgets"/>
|
|
<node CREATED="1480300804840" ID="ID_1330942810" MODIFIED="1557498707225" TEXT="Verbindung zum Anzeigekontext">
|
|
<node CREATED="1480300822302" ID="ID_1819260908" MODIFIED="1557498707225" TEXT="zwei Kontexte für die Tracks"/>
|
|
<node CREATED="1480300836092" ID="ID_1069009472" MODIFIED="1557498707225" TEXT="Anzeigekontext = Konkretes Vater-Widget"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480606888860" FOLDED="true" HGAP="25" ID="ID_899101975" MODIFIED="1679361614097" TEXT="Implementierung" VGAP="11" VSHIFT="14">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1480606950372" ID="ID_1502878943" MODIFIED="1557498707225" TEXT="Grundstruktur">
|
|
<node CREATED="1563036503676" ID="ID_274320987" MODIFIED="1563036508677" TEXT="visuell/Layout">
|
|
<node CREATED="1480639404070" ID="ID_506539007" MODIFIED="1557498707225" TEXT="HeaderPane">
|
|
<node CREATED="1480639435010" ID="ID_892799964" MODIFIED="1557498707225" TEXT="Navigator"/>
|
|
<node CREATED="1480639438921" ID="ID_1668884794" MODIFIED="1557498707225" TEXT="Baum">
|
|
<node CREATED="1480639447736" ID="ID_1842963526" MODIFIED="1557498707225" TEXT="Expander"/>
|
|
<node CREATED="1480639450960" ID="ID_1468387103" MODIFIED="1557498707225" TEXT="Patchbay"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480639411109" ID="ID_520199505" MODIFIED="1557498707225" TEXT="ScrolledPane">
|
|
<node CREATED="1480639423116" ID="ID_1226894709" MODIFIED="1557498707225" TEXT="Ruler"/>
|
|
<node CREATED="1480639429307" ID="ID_1922498247" MODIFIED="1557498707225" TEXT="Canvas"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563036487350" ID="ID_1370107301" MODIFIED="1563036492008" TEXT="custom-Widgets">
|
|
<node COLOR="#338800" CREATED="1562972742894" ID="ID_50010456" MODIFIED="1563044193887" TEXT="Namen für die custom-widgets">
|
|
<linktarget COLOR="#3f4a94" DESTINATION="ID_50010456" ENDARROW="Default" ENDINCLINATION="-1046;66;" ID="Arrow_ID_1862548348" SOURCE="ID_340313615" STARTARROW="None" STARTINCLINATION="-1895;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1563035885483" FOLDED="true" ID="ID_180592409" MODIFIED="1679360139274" TEXT="Wunsch/Konzept">
|
|
<arrowlink DESTINATION="ID_105242868" ENDARROW="Default" ENDINCLINATION="1295;0;" ID="Arrow_ID_708537872" STARTARROW="None" STARTINCLINATION="825;-325;"/>
|
|
<node CREATED="1563036553387" ID="ID_1889445008" MODIFIED="1563036560952" TEXT="TimelineWidget selber?">
|
|
<node CREATED="1563036568256" ID="ID_1816733755" MODIFIED="1576282358084" TEXT="sollte besser ein "paned" bleiben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dies ggfs vom Theme her schon gestyled wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563036619140" ID="ID_1483549704" MODIFIED="1563037392573" TEXT="aber Klasse: .timeline-page">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563019287444" ID="ID_1624037692" MODIFIED="1563043796072" TEXT="body.timeline">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node COLOR="#338800" CREATED="1563019321399" ID="ID_1793367255" MODIFIED="1563043799284" TEXT="fork.timeline">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1563019330262" ID="ID_36986369" MODIFIED="1563043802584" TEXT="canvas.timeline">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563043807392" ID="ID_994687888" MODIFIED="1576282358083" TEXT="Wunsch nur teilweise realisierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn die CSS-Node-Namen von Custom-Widgets kann man via GTKmm nicht ändern.
|
|
</p>
|
|
<p>
|
|
Das geht nur, wenn man das Custom-Widget direkt per C erzeugt,
|
|
</p>
|
|
<p>
|
|
weil der betreffende Aufruf gtk_widget_class_set_css_name (GTK_WIDGET_GET_CLASS(gobj()), "my-node")
|
|
</p>
|
|
<p>
|
|
in der C "class init function" passieren muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#bc86a6" DESTINATION="ID_1245820640" ENDARROW="Default" ENDINCLINATION="-1901;31;" ID="Arrow_ID_1120129058" STARTARROW="None" STARTINCLINATION="-2128;-72;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480606954115" FOLDED="true" ID="ID_1178000371" MODIFIED="1557498707225" TEXT="Struktur-Modell">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1480725215087" ID="ID_212845679" MODIFIED="1557498707225" TEXT="erzeugen">
|
|
<node CREATED="1480725218783" ID="ID_192239117" MODIFIED="1557498707225" TEXT="Controller ist Tangible">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1480725247115" ID="ID_1533101483" MODIFIED="1557498707225" TEXT="Konstruktion erfordert...">
|
|
<node CREATED="1480796814716" ID="ID_1742743432" MODIFIED="1576282358083" TEXT="ID einer Timeline">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir lassen es offen, welche Art von ID das ist.
|
|
</p>
|
|
<p>
|
|
Irgend eine BareEntryID genügt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540639615789" ID="ID_1775707565" MODIFIED="1557498707225" TEXT="ID des root-Track"/>
|
|
<node CREATED="1480725273775" ID="ID_1495656573" MODIFIED="1557498707225" TEXT="Bus-Term-Referenz"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540639905935" ID="ID_1563220898" MODIFIED="1557498707225" TEXT="zerstören">
|
|
<node CREATED="1540639914260" ID="ID_1797549156" MODIFIED="1557498707225" TEXT="der Root-Track kann nicht gelöscht werden">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1540639925885" ID="ID_1352494029" MODIFIED="1557498707225" TEXT="das wird bereits auf Diff-Ebene abgewiesen"/>
|
|
<node CREATED="1540639934819" ID="ID_1733133201" MODIFIED="1557498707225" TEXT="...da es sich um ein Attribut-Binding handelt"/>
|
|
<node CREATED="1540639945978" ID="ID_1136500098" MODIFIED="1576282358082" TEXT="(sollte aber auch niemals auftreten)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da wir unterstellen, daß das Gegenstück im Session-Modell,
|
|
</p>
|
|
<p>
|
|
von dem der Diff ausgeht, ebenfalls den Root-Track als festes Attribut hält.
|
|
</p>
|
|
<p>
|
|
Daher sollte eine inkompatible Strukturänderung überhaupt nicht auftreten können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540640048428" ID="ID_838010387" MODIFIED="1557498707225" TEXT="nur das gesamte Widget insgesamt">
|
|
<node CREATED="1540640063547" ID="ID_975320950" MODIFIED="1557498707225" TEXT="kaskadiert in natürlicher Ordnung"/>
|
|
<node CREATED="1540640074705" ID="ID_181154970" MODIFIED="1557498707225" TEXT="Kinder zuerst...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573409624900" ID="ID_1959987638" MODIFIED="1573409630695" TEXT="verändern">
|
|
<node CREATED="1573409632189" ID="ID_1780072285" MODIFIED="1573409639158" TEXT="hier wird's gefährlich...."/>
|
|
<node CREATED="1573409642343" ID="ID_1221373403" MODIFIED="1573409653748" TEXT="das Diff-System handhabt die eigentliche Mutation"/>
|
|
<node CREATED="1573409655220" ID="ID_101081525" MODIFIED="1573409776349" TEXT="aber wenn wir Strukturen lokal aufdoppeln, bekommen wir ein Problem">
|
|
<arrowlink COLOR="#73618d" DESTINATION="ID_429179986" ENDARROW="Default" ENDINCLINATION="502;276;" ID="Arrow_ID_635099577" STARTARROW="None" STARTINCLINATION="278;11;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480725377994" ID="ID_172881069" MODIFIED="1557498707226" TEXT="verwalten">
|
|
<node COLOR="#338800" CREATED="1480741524775" ID="ID_661893589" MODIFIED="1557498707226" TEXT="Bindings einrichten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1480800574418" ID="ID_791426893" MODIFIED="1557498707226" TEXT="Marker">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1480800603331" ID="ID_1846937607" MODIFIED="1557498707226" TEXT="treten in diversen Scopes auf"/>
|
|
<node CREATED="1480800643953" ID="ID_409762087" MODIFIED="1557498707226" TEXT="sogar global, auf dem TimeRuler">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1480800605150" ID="ID_1156238228" MODIFIED="1557498707226" TEXT="sind stets optional"/>
|
|
<node CREATED="1480807594822" ID="ID_333819085" MODIFIED="1557498707226" TEXT="führe mal einen Marker-Typ ein"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538957611472" ID="ID_1996849782" MODIFIED="1557498707226" TEXT="erwartet gemäß UI Modell-Schema">
|
|
<arrowlink COLOR="#919fc6" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-902;329;" ID="Arrow_ID_651613049" STARTARROW="None" STARTINCLINATION="823;93;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#435e98" CREATED="1540639547294" ID="ID_133813709" MODIFIED="1557498707226" TEXT="TimelineID"/>
|
|
<node COLOR="#435e98" CREATED="1540639550757" ID="ID_521896867" MODIFIED="1557498707226" TEXT="Root-TrackID">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1541462330990" ID="ID_1246009618" MODIFIED="1557498707226" TEXT="TODO: eigentlich redundant">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1541462351699" ID="ID_1571413865" MODIFIED="1557498707226" TEXT="sie ist immer "fork", da es ein Attribut ist"/>
|
|
<node CREATED="1541462368025" ID="ID_66547064" MODIFIED="1557498707226" TEXT="der Entry-ID-Typ ist GenNode"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" ID="ID_391329400" MODIFIED="1561899149547" TEXT="TimelineController">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_391329400" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1839172502" SOURCE="ID_693425928" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1480694557112" ID="ID_786517324" MODIFIED="1557498707226" TEXT="Widget ist Startpunkt"/>
|
|
<node CREATED="1480694571310" ID="ID_1188786444" MODIFIED="1557498707226" TEXT="aber Controller wird Chef"/>
|
|
<node CREATED="1480725633399" FOLDED="true" ID="ID_1475661668" MODIFIED="1576282358082" TEXT="muß erst mal Controller implementieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...abstraktes Interface
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1480725680713" ID="ID_448125852" MODIFIED="1557498707226" TEXT="Delegate for Notification">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1480725704142" ID="ID_992732373" MODIFIED="1557498707226" TEXT="was bleibt abstrakt?">
|
|
<node CREATED="1480725715916" ID="ID_890987188" MODIFIED="1576282358081" TEXT="buildMutator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
latürnich
|
|
</p>
|
|
<p>
|
|
...den <i>muß</i> jeder individuell implementieren,
|
|
</p>
|
|
<p>
|
|
um die Bindung herzustellen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540639476279" ID="ID_298401557" MODIFIED="1557498707226" TEXT="vorerst Platzhalter">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480741498930" ID="ID_1605140473" MODIFIED="1557498707226" TEXT="hat nur einen einzigen RootTrack">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480742405505" FOLDED="true" ID="ID_1590367176" MODIFIED="1679360112757" TEXT="ACHTUNG: leere Sequenz?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>theoretisch</i> könnte man eine Timeline ohne Sequenz
|
|
</p>
|
|
<p>
|
|
oder eine Sequenz ohne root-Fork zulassen
|
|
</p>
|
|
<p>
|
|
<u>Fazit</u>: wir lassen das nicht zu, erzwingen das bereits per ctor
|
|
</p>
|
|
<p>
|
|
und erwarten abweichend vom Standard ein vollständiges Skelett im INS-Verb
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1480776052551" ID="ID_431920594" MODIFIED="1518487921081" TEXT="warum">
|
|
<node CREATED="1480742420383" ID="ID_19092812" MODIFIED="1518487921081" TEXT="kann ihn nicht gleich im ctor erzeugen"/>
|
|
<node CREATED="1480742432749" ID="ID_1840237751" MODIFIED="1518487921081" TEXT="denn wir brauchen die ID"/>
|
|
<node CREATED="1480742437892" ID="ID_1335490062" MODIFIED="1518487921081" TEXT="und die kann nur über den Bus kommen"/>
|
|
<node CREATED="1480742445563" ID="ID_1224591813" MODIFIED="1518487921081" TEXT="also müssen wir warten, bis das Attribut zugewiesen wird"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480776067549" FOLDED="true" HGAP="41" ID="ID_1500222365" MODIFIED="1679360103974" TEXT="Alternativen" VSHIFT="-1">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1480776081388" ID="ID_783764544" MODIFIED="1540506788245" TEXT="via ctor">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1480776096665" ID="ID_1492275941" MODIFIED="1576282358080" TEXT="das heißt....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Thema "Darstellung von Objekt-Feldern im Diff"
|
|
</p>
|
|
<p>
|
|
<i>da hab ich mir ausgiebig Gedanken darüber gemacht (in dieser Mindmap)</i>
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
entweder ein Feld ist wirklich optional belegbar, dann kann es mit dem Diff kommen
|
|
</li>
|
|
<li>
|
|
wenn dagegen ein Feld zwingend befüllt sein soll, muß man das über den Konstruktor erzwingen<br />in diesem Fall müssen alle Daten bereits mit dem vorangehenden INS kommen,<br />welches den Konstruktor-Aufruf auslöst<br /><br />
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1480776313813" ID="ID_1507386991" MODIFIED="1518487921082" TEXT="Vorteil: einfache Verhältnisse in der Widget-Impl"/>
|
|
<node CREATED="1480776341393" ID="ID_1985821448" MODIFIED="1540506389132" TEXT="Nachteil: muß Diff genau in spezieller Form schicken"/>
|
|
<node CREATED="1480777922397" ID="ID_514769772" MODIFIED="1518487921082" TEXT="...sonst">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1480777950449" ID="ID_487608965" MODIFIED="1540506527436" TEXT="Core schickt unvollständigen Populations-diff"/>
|
|
<node CREATED="1480777972862" ID="ID_1185499319" MODIFIED="1518487921082" TEXT="Exception beim Aufspielen"/>
|
|
<node CREATED="1480777979069" ID="ID_1379570617" MODIFIED="1518487921082" TEXT="kann nur geloggt werden"/>
|
|
<node CREATED="1480777983381" ID="ID_1125654729" MODIFIED="1518487921082" TEXT="Folglich fehlt im UI die betreffende Timeline"/>
|
|
<node CREATED="1480778002098" ID="ID_535894255" MODIFIED="1518487921082" TEXT="spätere Updates scheitern gleichermaßen"/>
|
|
<node CREATED="1480778011745" ID="ID_1623403394" MODIFIED="1518487921082" TEXT="dysfunktionales UI">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480776087027" ID="ID_132590373" MODIFIED="1518487921082" TEXT="leer zulassen">
|
|
<node CREATED="1480778115091" ID="ID_1948130012" MODIFIED="1576282358080" TEXT="das heißt...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die betreffenden Felder sind echt optional.
|
|
</p>
|
|
<p>
|
|
Der Ctor belegt sie mit einem sinnvollen Leerwert
|
|
</p>
|
|
<p>
|
|
Das Objekt muß so geschrieben werden, daß es mit den Leerwerten umgehen kann,
|
|
</p>
|
|
<p>
|
|
was typischerweise heitß, daß es verschiedene Betriebsmodi bekommt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das Diff kann dann später die konkreten Werte für die Attribute nachliefern;
|
|
</p>
|
|
<p>
|
|
typischerweise wird es das in einem Populationsdiff sofort als Nächstes machen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1480778348652" ID="ID_1249761108" MODIFIED="1518487921082" TEXT="Vorteil: Diff-Erzeugung und Aufspielen läuft nach Schema-F"/>
|
|
<node CREATED="1480778407052" ID="ID_181642617" MODIFIED="1518487921082">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwei mögliche
|
|
</p>
|
|
<p>
|
|
Konsequenzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1480778420418" ID="ID_1430286640" MODIFIED="1540506791804" TEXT="Problem ignorieren">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1480778499928" ID="ID_1466170472" MODIFIED="1518487921082" TEXT="Felder im Ctor einfach uninitialisiert lassen"/>
|
|
<node CREATED="1480778490545" ID="ID_1228109442" MODIFIED="1540506504371" TEXT="darauf hoffen, daß das Diff immer komplett alles populiert"/>
|
|
<node CREATED="1480778511086" ID="ID_1612105579" MODIFIED="1518487921082" TEXT="keine Checks im Code"/>
|
|
<node CREATED="1480778532907" ID="ID_1167492250" MODIFIED="1576282358079">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
funktioniert <i>fast immer</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>"was kann denn schon passieren??"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1540506535667" ID="ID_1048222076" MODIFIED="1540506545488">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und wenn nicht, dann <b>Crash</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480778451502" ID="ID_1135553012" MODIFIED="1540506795353" TEXT="echt optionale Felder">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1480778622039" ID="ID_1007915114" MODIFIED="1518487921082">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Betriebsart <i>"partiell initialisiert"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480778652819" ID="ID_1335924975" MODIFIED="1518487921082" TEXT="Checks und Verzweigungen im Code"/>
|
|
<node CREATED="1480778689191" ID="ID_45333997" MODIFIED="1576282358078" TEXT="Pflanzt sich auf die Nutzer fort">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
..hier das Widget, das ebenfalls
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
nur partiell aufgebaut existieren können muß
|
|
</li>
|
|
<li>
|
|
später sich dynamisch erweitern können muß
|
|
</li>
|
|
<li>
|
|
in der Behandlung der UI-Signale ebenfalls checks einbauen muß
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480778768988" ID="ID_1385067618" MODIFIED="1576282358078" TEXT="und das alles nur für....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
einen Fall, der <i>praktisch nie</i> auftritt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1480780047561" FOLDED="true" HGAP="88" ID="ID_1993420764" MODIFIED="1561899108929" TEXT="Entscheidung" VSHIFT="16">
|
|
<node CREATED="1480780057079" ID="ID_481017202" MODIFIED="1518487921082" TEXT="Analyse">
|
|
<node CREATED="1480780061327" ID="ID_628488180" MODIFIED="1539382659192" TEXT="zwei Fälle sind sehr ähnlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar interessanterweise über Kreuz gegliedert
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Ctor-Lösung (hat aber etwas mehr Umsetzungsaufwand)
|
|
</li>
|
|
<li>
|
|
die "wird schon klappen"-Lösung
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1480780163369" ID="ID_851065784" MODIFIED="1518487921082" TEXT="wenig Zusatzaufwand"/>
|
|
<node CREATED="1480780174552" ID="ID_640476327" MODIFIED="1518487921082" TEXT="funktioniert fast immer"/>
|
|
<node CREATED="1480780183319" ID="ID_431465582" MODIFIED="1518487921082" TEXT="üble Konsequenzen wenn nicht"/>
|
|
</node>
|
|
<node CREATED="1480780140741" ID="ID_1754958261" MODIFIED="1539382659205" TEXT="und ein dritter ist wirklich wasserdicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn alle Objekte <i>wirklich</i> auf partiell initialisierten Zustand vorbereitet sind,
|
|
</p>
|
|
<p>
|
|
und auch über ihre APIs dem Nutzer diese Unterscheidnung mit aufzwingen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1480780253397" ID="ID_1966427410" MODIFIED="1518487921082" TEXT="zum Preis von deutlich Mehraufwand"/>
|
|
<node CREATED="1480780260508" ID="ID_1565963038" MODIFIED="1539382659215" TEXT="plus einer korrodierenden Wirkung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welche darin besteht,
|
|
</p>
|
|
<p>
|
|
daß man überall, in der Fläche, sich um Zustandsabhöngigkeit kümmern muß,
|
|
</p>
|
|
<p>
|
|
und deshalb dazu neigt, das Problem jeweils wegzutricksen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Es besteht also die große Gefahr, zu "sündigen" und
|
|
</p>
|
|
<p>
|
|
heimlich in den "wird schon nix passieren" Fall zu geraten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480780269867" ID="ID_1571900658" MODIFIED="1518487921082" TEXT="dafür kann nie was passieren"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480780494717" ID="ID_432076484" MODIFIED="1518487921082" TEXT="Bewertung">
|
|
<node CREATED="1480780498437" ID="ID_1806301944" MODIFIED="1539382659226" TEXT="nur die Ctor-Lösung ist geradlinig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, nur diese Lösung gründet in der Natur der behandelten Sachverhalte.
|
|
</p>
|
|
<p>
|
|
Wenn etwas seinem Wesen nach nicht optional ist, dann wird es auch nicht optional behandelt.
|
|
</p>
|
|
<p>
|
|
Es ist keine weitere Argumentation notwendig.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480780538975" ID="ID_1139883143" MODIFIED="1539382659232" TEXT="nur die "paßt schon"-Lösung ist vernünftig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nach allen gängigen Prinzipien der instrumentellen Vernunft.
|
|
</p>
|
|
<p>
|
|
KISS
|
|
</p>
|
|
<p>
|
|
YAGNI
|
|
</p>
|
|
<p>
|
|
"fokussiere Dich"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480780704849" ID="ID_483861197" MODIFIED="1518487921082" TEXT="Abwägung">
|
|
<node CREATED="1480780835319" ID="ID_1263364267" MODIFIED="1540506617751">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hey, es ist <b>mein Leben</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...hab ich mich je anders entschieden?
|
|
</p>
|
|
<p>
|
|
<i>wenn</i> ich mich überhaupt entscheiden konnte...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1540506618429" ID="ID_654526245" MODIFIED="1540506765576" TEXT="wähle die geradlinige Lösung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die Lösung entspricht der inneren Natur der Dinge
|
|
</li>
|
|
<li>
|
|
sie bedeutet zwar (leider) eine zusätzliche Verpflichtung beim Erzeugen des Diff
|
|
</li>
|
|
<li>
|
|
aber im Fehlerfall scheitern wir halbwegs sauber (Exception, dysfunktionales UI)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink DESTINATION="ID_1156407347" ENDARROW="Default" ENDINCLINATION="57;0;" ID="Arrow_ID_665420852" STARTARROW="None" STARTINCLINATION="11;38;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1480780930115" HGAP="5" ID="ID_1156407347" MODIFIED="1576282358077" TEXT="Lösung: per Konstruktor festlegen" VSHIFT="6">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nochmal zusammengefaßt
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
immer wenn ein Feld <i>seinem Wesen nach</i> zwingend gesetzt sein muß (und aus keinem anderen Grund)
|
|
</li>
|
|
<li>
|
|
dann wird dies per Konstruktor so erzwungen
|
|
</li>
|
|
<li>
|
|
daher muß dann im Diff bereits im INS-Verb die notwendige Information transportiert werden
|
|
</li>
|
|
<li>
|
|
das heißt, bei der Diff-Erzeugung muß man aufpassen und an dieser Stelle bereits einen Record mit den Daten liefern
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1156407347" ENDARROW="Default" ENDINCLINATION="57;0;" ID="Arrow_ID_665420852" SOURCE="ID_654526245" STARTARROW="None" STARTINCLINATION="11;38;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" FOLDED="true" ID="ID_562532566" MODIFIED="1679361463987" TEXT="»Layout-Manager«">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_562532566" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_130009025" SOURCE="ID_758873433" STARTARROW="None" STARTINCLINATION="611;93;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1561898858814" HGAP="-12" ID="ID_1456175251" MODIFIED="1561899077764" TEXT="Bedeutung" VSHIFT="-21">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1561898668856" ID="ID_1536703120" MODIFIED="1561899085407" TEXT="soll einheitliches Styling unterstützen">
|
|
<linktarget COLOR="#6557a4" DESTINATION="ID_1536703120" ENDARROW="Default" ENDINCLINATION="-715;74;" ID="Arrow_ID_1260120879" SOURCE="ID_253449798" STARTARROW="None" STARTINCLINATION="-1565;0;"/>
|
|
<node CREATED="1561898695086" ID="ID_1426731428" MODIFIED="1561899095356" TEXT="Koordiniert durch globalen Layout-Manager">
|
|
<arrowlink COLOR="#7339d4" DESTINATION="ID_44229333" ENDARROW="Default" ENDINCLINATION="-1147;0;" ID="Arrow_ID_61031233" STARTARROW="None" STARTINCLINATION="797;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480639469981" ID="ID_983391388" MODIFIED="1557498707226" TEXT="Abstraktionen">
|
|
<node CREATED="1666902209942" ID="ID_727768012" MODIFIED="1666902216649" TEXT="DisplayManager"/>
|
|
<node CREATED="1666902217430" ID="ID_723844350" MODIFIED="1666902317723" TEXT="DisplayMetric">
|
|
<linktarget COLOR="#587489" DESTINATION="ID_723844350" ENDARROW="Default" ENDINCLINATION="201;41;" ID="Arrow_ID_886505757" SOURCE="ID_771044369" STARTARROW="None" STARTINCLINATION="-1041;45;"/>
|
|
</node>
|
|
<node CREATED="1666902240954" ID="ID_1027771886" MODIFIED="1666902248325" TEXT="DisplayViewHooks"/>
|
|
<node CREATED="1666902249080" ID="ID_1436546117" MODIFIED="1666902254061" TEXT="Display-Evaluation"/>
|
|
</node>
|
|
<node CREATED="1540647717236" ID="ID_1682094694" MODIFIED="1557498707226" TEXT="Konzept für Größen-Steuerung" VGAP="25">
|
|
<node COLOR="#435e98" CREATED="1540647728418" FOLDED="true" ID="ID_71764405" MODIFIED="1679360086917" TEXT="grundsätzlich">
|
|
<node CREATED="1540647743681" ID="ID_344681852" MODIFIED="1557498707226" TEXT="soweit möglich bei der Automatik bleiben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1541862056646" ID="ID_262489955" MODIFIED="1557498707226">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Widgets arbeiten <b>stets in Pixeln</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1540647761611" ID="ID_841316619" MODIFIED="1557498707226" TEXT="Erweiterungs-Punkte">
|
|
<arrowlink COLOR="#59699c" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="-876;0;" ID="Arrow_ID_72712594" STARTARROW="None" STARTINCLINATION="-1659;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1540647890477" ID="ID_347383643" MODIFIED="1557498707226" TEXT="direkt die Properties setzen"/>
|
|
<node CREATED="1540647897963" ID="ID_155000915" MODIFIED="1557498707226" TEXT="an signal_size_allocate() anhängen"/>
|
|
</node>
|
|
<node CREATED="1540647995231" ID="ID_37565869" MODIFIED="1557498707226" TEXT="wir kontrollieren nur die vertikale Ausdehnung"/>
|
|
<node CREATED="1540648007237" ID="ID_679717206" MODIFIED="1557498707226" TEXT="der Canvas folgt der Header-Struktur">
|
|
<node CREATED="1540648025554" ID="ID_1681608373" MODIFIED="1557498707226" TEXT="diese ist weitgehend automatisch"/>
|
|
<node CREATED="1540648036313" ID="ID_372148054" MODIFIED="1557498707226" TEXT="Quer-Verkoppelung schaffen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1541857185478" ID="ID_1038931568" MODIFIED="1678405188400" TEXT="Zeit-Darstellung">
|
|
<linktarget COLOR="#2a79c1" DESTINATION="ID_1038931568" ENDARROW="Default" ENDINCLINATION="-511;19;" ID="Arrow_ID_1052516165" SOURCE="ID_1316730142" STARTARROW="None" STARTINCLINATION="-253;-12;"/>
|
|
<linktarget COLOR="#2a79c1" DESTINATION="ID_1038931568" ENDARROW="Default" ENDINCLINATION="-511;19;" ID="Arrow_ID_405016415" SOURCE="ID_552550333" STARTARROW="None" STARTINCLINATION="-1360;-43;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1541857206083" ID="ID_1480494725" MODIFIED="1557498707226" TEXT="Problem-Komplex">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1541857225304" ID="ID_1753842977" MODIFIED="1557498707226" TEXT="Übersetzung Zeit -> Pixel"/>
|
|
<node CREATED="1541857235471" ID="ID_1096265760" MODIFIED="1557498707226" TEXT="integrieren von Zeitangaben"/>
|
|
<node CREATED="1541857252860" ID="ID_298952812" MODIFIED="1557498707226" TEXT="Zeit-Rasterung (Time-Grid)"/>
|
|
<node CREATED="1541857273978" ID="ID_10543409" MODIFIED="1557498707226" TEXT="managing the Zoom-Window"/>
|
|
</node>
|
|
<node CREATED="1541857340976" ID="ID_433103364" LINK="#ID_1054510557" MODIFIED="1667337152477" TEXT="Lumiera Time Framework">
|
|
<node CREATED="1541857349526" ID="ID_1259099260" MODIFIED="1557498707226" TEXT="bietet Konzept "Grid""/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666452057169" FOLDED="true" ID="ID_1202075896" MODIFIED="1678404826707" TEXT="Aufgabe: DisplayMetric bereitstellen">
|
|
<linktarget COLOR="#3c4864" DESTINATION="ID_1202075896" ENDARROW="Default" ENDINCLINATION="-1351;104;" ID="Arrow_ID_1210722108" SOURCE="ID_244578537" STARTARROW="None" STARTINCLINATION="-74;-277;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1666476557441" HGAP="46" ID="ID_1389871438" MODIFIED="1678404884839" TEXT="Design: Zugang und Interface" VSHIFT="-9">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1666476570783" ID="ID_1807785585" MODIFIED="1666479237736" TEXT="Ergebnis einer längeren Suche/Entwicklung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1666476598232" ID="ID_412611180" MODIFIED="1666476751149" TEXT="zunächst als Dependency-Injection in die Track-Struktur eingewoben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
per »einhäkel-λ«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666479109019" ID="ID_211374228" MODIFIED="1666479136955" TEXT="Implementierung der Übersetzung war im BodyCanvas"/>
|
|
<node CREATED="1666479148397" ID="ID_422444614" MODIFIED="1666479156928" TEXT="Zugriff über DisplayFrame"/>
|
|
<node CREATED="1666479157703" ID="ID_1040782071" MODIFIED="1666479208532" TEXT="aus diesem heraus abstrahiert als ViewHook"/>
|
|
<node CREATED="1666479188584" ID="ID_563183680" MODIFIED="1666479203198" TEXT="ViewHook / CanvasHook getrennt"/>
|
|
<node CREATED="1666479210828" ID="ID_1064091645" MODIFIED="1666479225855" TEXT="aus letzterem extrahiert als "mini-DisplayManager""/>
|
|
</node>
|
|
<node CREATED="1666476727258" ID="ID_735591701" MODIFIED="1666477819710" TEXT="Problem: verkettete virtuelle calls">
|
|
<linktarget COLOR="#9b3c5a" DESTINATION="ID_735591701" ENDARROW="Default" ENDINCLINATION="-828;79;" ID="Arrow_ID_619578495" SOURCE="ID_97557081" STARTARROW="None" STARTINCLINATION="-1537;0;"/>
|
|
<node CREATED="1666478244870" ID="ID_1175173929" MODIFIED="1666479017987" TEXT="CanvasHook::getMetric() �� DisplayMetric::translateTime... �� (ggfs ZoomWindow)"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666478265860" FOLDED="true" ID="ID_1432355805" MODIFIED="1666493227294" TEXT="könnte man Indirektionen einsparen?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1666478030507" ID="ID_263543815" MODIFIED="1666481494568" TEXT="in früherem Kontext schon mal untersucht...">
|
|
<arrowlink COLOR="#9f5337" DESTINATION="ID_1256984812" ENDARROW="Default" ENDINCLINATION="-812;-59;" ID="Arrow_ID_1128030260" STARTARROW="None" STARTINCLINATION="2097;137;"/>
|
|
</node>
|
|
<node CREATED="1666480618904" ID="ID_1117619215" MODIFIED="1666481163741" TEXT="Impl. als mix-in sichtbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Um eine tatsächliche Indirektion einzusparen, muß die Implementierung schon mit der jeweiligen Interface-Deklaration zusammen sichtbar sein. Flexibilität ist dann nur noch durch Parametrisierung der Implementierung möglich — was im konkreten Fall aber durchaus denkbar wäre, da es sich letztlich nur um eine affin-lineare Transformation handelt (und wir uns darauf dann limitieren würden)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1666481508537" ID="ID_767490652" MODIFIED="1666481512449" TEXT="Analyse..."/>
|
|
<node CREATED="1666481268601" ID="ID_224528667" MODIFIED="1666481473064" TEXT="CanvasHooked?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
↯ Nein!
|
|
</p>
|
|
<p>
|
|
Diese Trennung ist praktisch unverzichtbar, allein schon aufgrund der getrennten Allokation: das Widget wird irgendwann erzeugt und bekommt einen Pointer auf einen CanvasHook, welcher zu der Zeit schon besteht, und vermutlich auch länger leben wird. Eine andere Frage ist allerdings, ob dann auf dem CanvasHook ein virtueller Call gemacht wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1666481516664" ID="ID_452196146" MODIFIED="1666483676987" TEXT="CanvasHook mix-in?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
CanvasHook könnte ein konkretes mix-In sein; d.h. zumindest die DisplayMetric wäre zwar als weitere mix-in-Komponente in einem anderen Header definiert (um den Code klar zu halten), aber letztlich bereits auf Interface-Ebene komplett in der Implementierung sichtbar. Die zwei Faktoren der affin-linearen-Transformation wären mutable Variable, die per Setter geändert werden können...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
für den Client erfolgt die Abstraktion beim Zugriff per up-Cast (d.h. er bekommt einen CanvasHook-Pointer)
|
|
</li>
|
|
<li>
|
|
das konkrete TimelineLayout erbt von CanvasHook und inkorporiert damit genau diese Implementierung
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
⟹ der verbleibende Knackpunkt ist das Einbinden des (relativen) Canvas-Hook
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1666484788093" ID="ID_1631269506" MODIFIED="1666485263714" TEXT="DisplayFrame ist RelativeCanvasHook">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das nutzt explizit die bestehenden Indirektionen aus...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Client nimmt einen DisplayHook per up-Cast (und weiß nicht, daß es sich um einen DisplayFrame handelt)
|
|
</li>
|
|
<li>
|
|
getDisplayMetric() geht durch die VTable; das Interface legt sich überhaupt nicht fest, von woher die DisplayMetric stammt
|
|
</li>
|
|
<li>
|
|
die Impl in RelativeCanvasHook delegiert auf refHook_.getMetric
|
|
</li>
|
|
<li>
|
|
refHook_ ist selber wieder ein DisplayHook, und wir wissen nicht, wer ihn bereitstellt
|
|
</li>
|
|
<li>
|
|
tatsächlich bestimmt der top-Level DisplayFrame darüber, indem er ihn an das TimelineLayout anbindet
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1666485375028" ID="ID_282899643" MODIFIED="1666485530387" TEXT="DisplayFrame::getDisplayMetric()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist in der Tat eine überflüssige Indirektion, die jedoch einen Storage-Slot einspart (weil die VTable ohnehin schon da ist). Man könnte sehr wohl schon im Interface CanvasHook einen Pointer auf eine DisplayMetric vorsehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1666485621639" ID="ID_1015581509" MODIFIED="1666485779479" TEXT="nur die Impl von DisplayMetric">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist die minimale Einsparung...
|
|
</p>
|
|
<p>
|
|
DisplayMetric wäre demnach schon als Interface auf eine affin-lineare-Transformation festgelegt, und würde nur per Setter parametrisiert...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1666486003675" ID="ID_563456586" MODIFIED="1666486275676" TEXT="DisplayMetric* speichern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Da im Clip die Anfrage an die Metrik-Übersetzung x-fach (bei jedem Fokus-Wechsel) erfolgt, dagegen das generelle re-Positionieren auf dem Canvas nur nach einem Strukturwechsel oder Zoom-Wechsel, wäre eine sehr einfache und effektive Optimierung, sich den DisplayMetric-Pointer <i>im individuellen Clip</i> eigens zu speichern. Das wäre <i>allerings ein zusätzlicher »Slot« pro Clip! </i>... eine Variante mit einer zusätzlichen Pointer-Indirektion würde den DisplayMetric*-Pointer im CanvasHook speichern, und damit einmal pro Track (also wesentlich kleinerer Hebel)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1666485783482" ID="ID_1718274154" MODIFIED="1666486279237">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Diskussion ⟹ <i>später!</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die aktuelle Implementierung ist zwar x-fach indirekt, dafür aber sauber faktorisiert
|
|
</li>
|
|
<li>
|
|
sie ließe sich daher rein auf logischer Basis auch an weitere Use-cases anpassen
|
|
</li>
|
|
<li>
|
|
zumindest die Optimierungen auf einen DisplayMetric-Pointer klingen akzeptabel
|
|
</li>
|
|
<li>
|
|
allerdings sollten solche Optimierungen nicht <i>premature </i>erfolgen, sondern im Rahmen von konkreten Messungen in einer voll besetzten Timeline
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666493151300" ID="ID_1454936084" MODIFIED="1666493165261" TEXT="#1254 investigate impact of DisplayMetric indirection">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666902098061" ID="ID_1065760214" MODIFIED="1666902106000" TEXT="Implementierung als mix-In">
|
|
<node CREATED="1666902107252" ID="ID_70774013" MODIFIED="1666902131606" TEXT="drohender Diamond-of-Death">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1666902141488" ID="ID_771044369" MODIFIED="1666902327065" TEXT="Interface DisplayMetric gehört aber zum Interface DisplayManager">
|
|
<arrowlink COLOR="#587489" DESTINATION="ID_723844350" ENDARROW="Default" ENDINCLINATION="201;41;" ID="Arrow_ID_886505757" STARTARROW="None" STARTINCLINATION="-1041;45;"/>
|
|
</node>
|
|
<node CREATED="1666902351036" ID="ID_502371950" MODIFIED="1666902395778" TEXT="mix-In kann daher die zugehörige Basisklasse nicht explizit machen">
|
|
<node CREATED="1666902397286" ID="ID_574539438" MODIFIED="1666902412032" TEXT="weil sonst Diamond"/>
|
|
<node CREATED="1666902413588" ID="ID_1336614077" MODIFIED="1666902420823" TEXT="also stattdessen dokumentieren"/>
|
|
<node CREATED="1666902450815" ID="ID_1937191130" MODIFIED="1666902458897" TEXT="und als Include einbinden"/>
|
|
<node CREATED="1666902421555" ID="ID_1361555924" MODIFIED="1666902429264" TEXT="und per static assertion absichern"/>
|
|
</node>
|
|
<node CREATED="1666902485026" ID="ID_637601056" MODIFIED="1666902539317" TEXT="direkt verbinden mit ZoomWindow ⟹ ZoomMetric">
|
|
<arrowlink COLOR="#6d7f94" DESTINATION="ID_326538083" ENDARROW="Default" ENDINCLINATION="7;-65;" ID="Arrow_ID_1100141740" STARTARROW="None" STARTINCLINATION="124;7;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666476675737" ID="ID_489715422" MODIFIED="1678406261536">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Dienst</u>: aktueller Skalenfaktor + Offset
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#eb488f" DESTINATION="ID_326538083" ENDARROW="Default" ENDINCLINATION="-242;-28;" ID="Arrow_ID_1439269834" STARTARROW="None" STARTINCLINATION="74;-6;"/>
|
|
<linktarget COLOR="#6a9ab7" DESTINATION="ID_489715422" ENDARROW="Default" ENDINCLINATION="-479;1585;" ID="Arrow_ID_994014904" SOURCE="ID_626245969" STARTARROW="None" STARTINCLINATION="851;54;"/>
|
|
<linktarget COLOR="#9f3f5e" DESTINATION="ID_489715422" ENDARROW="Default" ENDINCLINATION="-2561;184;" ID="Arrow_ID_597075385" SOURCE="ID_400013153" STARTARROW="None" STARTINCLINATION="-1907;-124;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1666901228118" ID="ID_701422331" MODIFIED="1666901228118" TEXT="translateTimeToPixels">
|
|
<node CREATED="1666901808139" ID="ID_68915394" MODIFIED="1666901819846" TEXT="Zeit ⟼ Pixel">
|
|
<node CREATED="1666901778191" ID="ID_1270254992" MODIFIED="1666901795372" TEXT="(Übersetzungsfunktion vorwärts)">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1672694716089" ID="ID_1323685955" MODIFIED="1672695142709" TEXT="Problem: Canvas-Ursprung in Pixel">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1672695162345" ID="ID_624244605" MODIFIED="1672695183218" TEXT="sollte rein technisch „links oben“ im Fenster liegen"/>
|
|
<node CREATED="1672695187333" ID="ID_1273824912" MODIFIED="1672695197079" TEXT="muß für alle Zeichen-Routinen konsistent sein"/>
|
|
<node CREATED="1672695198068" ID="ID_1764927765" MODIFIED="1672695207622" TEXT="ist davon abgesehen aber opaque"/>
|
|
<node CREATED="1672695222232" ID="ID_785032228" MODIFIED="1672695546890" TEXT="binde ihn an den Anfrang vom ZoomWindow-Canvas">
|
|
<arrowlink COLOR="#868ca5" DESTINATION="ID_350857288" ENDARROW="Default" ENDINCLINATION="1491;0;" ID="Arrow_ID_265889059" STARTARROW="None" STARTINCLINATION="-1670;93;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672694636798" ID="ID_1539523482" MODIFIED="1672694672146" TEXT="translateScreenDelta">
|
|
<node CREATED="1672694688748" ID="ID_1632699702" MODIFIED="1672694704719" TEXT="Zeit-Offset ⟼ Pixel-Δ"/>
|
|
<node CREATED="1666901778191" ID="ID_10531267" MODIFIED="1672700828681" TEXT="(implementiert Metrik-Übersetzung)">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666901241839" ID="ID_1036232479" MODIFIED="1666901245317" TEXT="applyScreenDelta">
|
|
<node CREATED="1666901254363" ID="ID_280452814" MODIFIED="1666901607568" TEXT="Zeit + pixel ⟼ Zeit"/>
|
|
<node CREATED="1666901703977" ID="ID_944891696" MODIFIED="1666901738404" TEXT="(implizit die Umkehrfunktion)">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666901623044" ID="ID_1492305881" MODIFIED="1666901629255" TEXT="coveredTime()">
|
|
<node CREATED="1666901657919" ID="ID_783302636" MODIFIED="1666902040819" TEXT="Implementierung tendentiell problematisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
woher soll man das wissen?
|
|
</p>
|
|
<p>
|
|
muß eigentlich schon von der Session geliefert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666901646144" ID="ID_1978778077" MODIFIED="1666902048800" TEXT="benötigt zur Dimensionierung des Canvas..."/>
|
|
<node CREATED="1666902006957" ID="ID_601891500" MODIFIED="1666902033802" TEXT="und auch zur Konstituierung des ZoomWindow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541861495569" FOLDED="true" ID="ID_1949450244" MODIFIED="1672970963226">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
�� generische <b>ZoomWindow</b>-Komponente
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5b5ca1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="-519;-1168;" ID="Arrow_ID_1674512697" STARTARROW="None" STARTINCLINATION="518;31;"/>
|
|
<node CREATED="1666889163624" ID="ID_858177284" MODIFIED="1666889196771" TEXT="Einbindung und Verdrahtung">
|
|
<node CREATED="1666889225532" ID="ID_176130370" MODIFIED="1666889244156" TEXT="direkt eingelagert in die DisplayMetric-Implementierung (mix-in)">
|
|
<node CREATED="1666889610112" ID="ID_326538083" MODIFIED="1666902539317">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Name: <b>ZoomMetric</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#6d7f94" DESTINATION="ID_326538083" ENDARROW="Default" ENDINCLINATION="7;-65;" ID="Arrow_ID_1100141740" SOURCE="ID_637601056" STARTARROW="None" STARTINCLINATION="124;7;"/>
|
|
<linktarget COLOR="#eb488f" DESTINATION="ID_326538083" ENDARROW="Default" ENDINCLINATION="-242;-28;" ID="Arrow_ID_1439269834" SOURCE="ID_489715422" STARTARROW="None" STARTINCLINATION="74;-6;"/>
|
|
<node CREATED="1666889733127" ID="ID_41491875" MODIFIED="1666889741033" TEXT="header-only"/>
|
|
<node CREATED="1666889741894" ID="ID_176779607" MODIFIED="1666889777772" TEXT="generisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
direkten Bezug auf die Timeline vermeiden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666889639116" ID="ID_1904347591" MODIFIED="1666889659397" TEXT="zoomWindow_ als Member zugänglich"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666889276573" ID="ID_858654573" MODIFIED="1666889393957" TEXT="control connnections">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1666889293466" ID="ID_1286633993" MODIFIED="1666889303678" TEXT="Zoom-Widget in der Toolbar"/>
|
|
<node CREATED="1666889427144" ID="ID_1652095423" MODIFIED="1666889438850" TEXT="Navigator / Spot-Locator"/>
|
|
<node CREATED="1666889336685" ID="ID_1883804335" MODIFIED="1666889344602" TEXT="context-Menu?"/>
|
|
<node CREATED="1666889359890" ID="ID_437996591" MODIFIED="1666889366672" TEXT="globales View-Menü"/>
|
|
<node CREATED="1666889369994" ID="ID_1179325794" MODIFIED="1666889376418" TEXT="Keybindings"/>
|
|
<node CREATED="1666889377440" ID="ID_1707480753" MODIFIED="1666889383577" TEXT="Zoom-Gesten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672703576092" HGAP="227" ID="ID_253168595" MODIFIED="1672703593980" TEXT="Initialisierung" VSHIFT="25">
|
|
<node CREATED="1672703613783" ID="ID_1111316685" MODIFIED="1672703625305" TEXT="anfangs undefiniert / default"/>
|
|
<node COLOR="#338800" CREATED="1672706823302" ID="ID_445391760" MODIFIED="1672707119233" TEXT="changeNotification-Functor verdrahten">
|
|
<linktarget COLOR="#34a5a4" DESTINATION="ID_445391760" ENDARROW="Default" ENDINCLINATION="108;96;" ID="Arrow_ID_1879633887" SOURCE="ID_394283688" STARTARROW="None" STARTINCLINATION="515;22;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1672706833208" ID="ID_1727841525" MODIFIED="1675897056715" TEXT="kann man direkt mit dem Signal initialisieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1672706877415" ID="ID_1791069589" MODIFIED="1672706882814" TEXT="signalStructureChange_"/>
|
|
<node CREATED="1672706902644" ID="ID_429923017" MODIFIED="1672706904037" TEXT="using SignalStructureChange = sigc::signal<void>;"/>
|
|
<node CREATED="1672706906238" ID="ID_1588783616" MODIFIED="1672706918219">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sollte <i>callable</i> sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1672706942567" ID="ID_525512704" MODIFIED="1672707389514">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit würde eine std::function konstruiert,
|
|
</p>
|
|
<p>
|
|
welche das Target (per Referenz / smart-ptr) aufruft.<br />
|
|
</p>
|
|
<p>
|
|
Der Change-Listener wird im ZoomWindow zugewiesen,
|
|
</p>
|
|
<p>
|
|
was <a href="https://en.cppreference.com/w/cpp/utility/functional/function/operator%3D">lt. C++-Referenz</a> den gleichen Effekt hat wie
|
|
</p>
|
|
<p>
|
|
  <font face="Monospaced">function(<a href="http://en.cppreference.com/w/cpp/utility/forward">std::forward</a><F>(f)).swap(*this);</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8bbab7" DESTINATION="ID_281948392" ENDARROW="Default" ENDINCLINATION="824;0;" ID="Arrow_ID_1340083553" STARTARROW="None" STARTINCLINATION="-507;22;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1672706851970" ID="ID_1116087475" MODIFIED="1678405849988" TEXT="hab das jetzt einfach mal dreist so gemacht">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672703662072" ID="ID_1923088969" MODIFIED="1678405417720" TEXT="klären: wann wird die Pixel-Weite festgelegt?">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1672708648699" ID="ID_1466789019" MODIFIED="1672708769250" TEXT="#1264 fully integrate ZoomWindow mutators into Timeline display">
|
|
<arrowlink COLOR="#954368" DESTINATION="ID_1985216414" ENDARROW="Default" ENDINCLINATION="1507;68;" ID="Arrow_ID_1698932113" STARTARROW="None" STARTINCLINATION="-35;216;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672764114942" ID="ID_327539453" MODIFIED="1672765461663" TEXT="Ansatzpunkt: Erfahrungen beim ElementBoxWidget">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Fazit</u>: man sollte also die Layout-Berechnungen machen in dem
|
|
Zeitraum zwischen dem Aufruf der get_preferred_*-VFunks und dem
|
|
on_size_allocate()-callback. Denn in dieser Phase sind die Widgets
|
|
bereits gemapped (=einem GDK-Fenster mit Koordinaten zugeordnet) und der <i>visibility-</i>Status
|
|
steht bereits fest, aber es wurde noch nichts <i>realized </i>und damit
|
|
auch noch nichts (erneut) gezeichnet. Sofern kein »fill-Layout«
|
|
verwendet wird, liefern die get_preferred_width|height()-Funktionen als
|
|
Standard-Wert genau das, was GTK dann nachfolgend zuteilen wird (die
|
|
MIN-Werte werden praktisch nicht verwendet). Später könnten Widgets sich
|
|
noch verkleinern, und GTK könnte eine größere Allokation zuteilen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
�� Es gibt <b>keine praktikable Möglichkeit</b>, die
|
|
aktuelle <b>reale Größe </b>in Pixeln von Außen und generisch
|
|
für jedes Widget in Erfahrung zu bringen. Wenn man selber ein
|
|
custom-Widget schreibt, kann man die reale size-Allocation wegspeichern
|
|
und zugänglich machen; dann bleibt aber immer noch das Problem mit den
|
|
Dekorationen und dem Padding per CSS
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#738fa6" DESTINATION="ID_915287836" ENDARROW="Default" ENDINCLINATION="-35;506;" ID="Arrow_ID_1564122490" STARTARROW="None" STARTINCLINATION="1322;71;"/>
|
|
<linktarget COLOR="#6575b0" DESTINATION="ID_327539453" ENDARROW="Default" ENDINCLINATION="-654;33;" ID="Arrow_ID_47233640" SOURCE="ID_123234016" STARTARROW="None" STARTINCLINATION="-417;28;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672708980937" ID="ID_123640005" MODIFIED="1678405387303" TEXT="Change-Listener vom ZoomWindow ⟼ SignalStructureChange ⟹ trigger Display-Evaluation">
|
|
<linktarget COLOR="#71b1ad" DESTINATION="ID_123640005" ENDARROW="Default" ENDINCLINATION="889;28;" ID="Arrow_ID_835967440" SOURCE="ID_1838761224" STARTARROW="None" STARTINCLINATION="1146;63;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672787519757" ID="ID_650213030" MODIFIED="1678405252570" TEXT="Pixel-Weite kalibrieren: zu Beginn der Display-Evaluation einschleifen">
|
|
<arrowlink COLOR="#444b9e" DESTINATION="ID_1189311522" ENDARROW="Default" ENDINCLINATION="785;29;" ID="Arrow_ID_1573433988" STARTARROW="None" STARTINCLINATION="241;10;"/>
|
|
<linktarget COLOR="#517488" DESTINATION="ID_650213030" ENDARROW="Default" ENDINCLINATION="515;561;" ID="Arrow_ID_113145433" SOURCE="ID_1514900067" STARTARROW="None" STARTINCLINATION="754;37;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1678840536481" HGAP="35" ID="ID_1658816102" MODIFIED="1678840689222" TEXT="wird aber ausgelöst durch bodyCanvas_.signal_size_allocate()">
|
|
<arrowlink COLOR="#5978c6" DESTINATION="ID_1655268668" ENDARROW="Default" ENDINCLINATION="1204;-55;" ID="Arrow_ID_470073487" STARTARROW="None" STARTINCLINATION="506;642;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1678405393907" ID="ID_988091406" MODIFIED="1678405414087" TEXT="scheint zu funktionieren">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541857367446" ID="ID_34718193" MODIFIED="1557498707226" TEXT="Anfragen">
|
|
<node CREATED="1541857411462" ID="ID_1874282992" MODIFIED="1557498707226" TEXT="Pixel-Intervall -> TimeSpan">
|
|
<node CREATED="1541857482489" ID="ID_524756641" MODIFIED="1557498707226" TEXT="timeline custom drawing"/>
|
|
</node>
|
|
<node CREATED="1568578895020" ID="ID_561665068" MODIFIED="1568578911701" TEXT="Time point -> Pixel-Offset">
|
|
<node CREATED="1568578913193" ID="ID_1111880749" MODIFIED="1568578935234" TEXT="placing a Clip"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480639473324" ID="ID_191170582" MODIFIED="1575131626153" TEXT="eval pass">
|
|
<linktarget COLOR="#921d48" DESTINATION="ID_191170582" ENDARROW="Default" ENDINCLINATION="1620;0;" ID="Arrow_ID_982561049" SOURCE="ID_624999649" STARTARROW="None" STARTINCLINATION="299;22;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666378011037" ID="ID_1362490028" MODIFIED="1666739659882" TEXT="#1252 Timeline display-evaluation-pass">
|
|
<arrowlink COLOR="#735667" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="68;-547;" ID="Arrow_ID_1219011636" STARTARROW="None" STARTINCLINATION="1094;73;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560627720011" HGAP="35" ID="ID_322949413" MODIFIED="1666450726004" TEXT="wozu?" VSHIFT="23">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666450734975" ID="ID_1944641444" MODIFIED="1666450749556" TEXT="übergreifende Koordination des Layouts"/>
|
|
<node CREATED="1666450778635" ID="ID_743528549" MODIFIED="1666450809168" TEXT="stößt lokalen Neuaufbau der Strukturen an"/>
|
|
<node CREATED="1666450794506" ID="ID_373894220" MODIFIED="1666450805016" TEXT="verteilt zusätzliches (vertikales) padding"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555022703032" ID="ID_13722484" MODIFIED="1557498707226" TEXT="Verdrahtung">
|
|
<node CREATED="1555022710839" ID="ID_1166296639" MODIFIED="1557498707226" TEXT="muß in alle Nutzer injiziert werden"/>
|
|
<node CREATED="1555022761189" ID="ID_640769952" MODIFIED="1576282358077" TEXT="wie? geht wohl nur direkte Referenz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist hier kein by-Name-Zugriff,
|
|
</p>
|
|
<p>
|
|
weil ein Layout-Manager immer nur im Bereich eines TimelineWidget relevant ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555023446038" ID="ID_858959830" MODIFIED="1557498707226" TEXT="clients">
|
|
<node CREATED="1555023449597" ID="ID_1228634821" MODIFIED="1557498707226" TEXT="TimelineCanvas">
|
|
<node CREATED="1555023483241" ID="ID_753460169" MODIFIED="1557498707226" TEXT="zum Feststellen des zu zeichnenden Bereiches"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560698483596" ID="ID_368409585" MODIFIED="1561048727700" TEXT="Infrastruktur für Status-Änderungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560698506599" ID="ID_1679016153" MODIFIED="1561048713811" TEXT="notwendig">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1560698514618" ID="ID_424874311" MODIFIED="1560698517787" TEXT="Benachrichtigung">
|
|
<node CREATED="1560698522830" ID="ID_771595987" MODIFIED="1560698534464" TEXT="initial..."/>
|
|
<node CREATED="1560698535135" ID="ID_499624854" MODIFIED="1560698542403" TEXT="bei neuen Elementen"/>
|
|
<node CREATED="1560698543371" ID="ID_853239190" MODIFIED="1560698549559" TEXT="bei entfernten Elementen"/>
|
|
<node CREATED="1560698550171" ID="ID_1461540019" MODIFIED="1560698556309" TEXT="bei aus/eingeblendeten Elementen"/>
|
|
</node>
|
|
<node CREATED="1560698518159" ID="ID_625626693" MODIFIED="1560698521434" TEXT="Aktionen"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560698568536" ID="ID_1734037059" MODIFIED="1561048706720" TEXT="Mechanismen">
|
|
<node CREATED="1560698573838" FOLDED="true" ID="ID_546774892" MODIFIED="1561042610462" TEXT="Call-chain bauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1560698613458" ID="ID_1618171484" MODIFIED="1560698618101" TEXT="direkte Parent-Links">
|
|
<node CREATED="1560698643705" ID="ID_1904845397" MODIFIED="1560698651645" TEXT="eine Menge Aufwand"/>
|
|
<node CREATED="1560698652882" ID="ID_314410558" MODIFIED="1560698659496" TEXT="komplex instand zu halten"/>
|
|
<node CREATED="1560698660108" ID="ID_881178993" MODIFIED="1560698663479" TEXT="verteilte Struktur"/>
|
|
</node>
|
|
<node CREATED="1560698618689" ID="ID_231185798" MODIFIED="1560698625444" TEXT="notification-Callbacks">
|
|
<node CREATED="1560698764250" ID="ID_926915515" MODIFIED="1560698770146" TEXT="Publisher-Subscriber"/>
|
|
<node CREATED="1560698668089" ID="ID_1609727906" MODIFIED="1560698674278" TEXT="ebenso problematisch"/>
|
|
<node CREATED="1560698675226" ID="ID_1528720357" MODIFIED="1576282358076" TEXT="Signale sind aber Callbacks....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und für Signale sind diese Probleme bereits gelöst
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fcc76b" DESTINATION="ID_64926941" ENDARROW="Default" ENDINCLINATION="39;-39;" ID="Arrow_ID_1800480673" STARTARROW="None" STARTINCLINATION="-57;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560698625944" ID="ID_64926941" MODIFIED="1563021623445" TEXT="ein spezielles Signal hierfür">
|
|
<linktarget COLOR="#fcc76b" DESTINATION="ID_64926941" ENDARROW="Default" ENDINCLINATION="39;-39;" ID="Arrow_ID_1800480673" SOURCE="ID_1528720357" STARTARROW="None" STARTINCLINATION="-57;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1560698805704" ID="ID_1490359824" MODIFIED="1561042627539" TEXT="wer trägt es?">
|
|
<arrowlink DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="93;0;" ID="Arrow_ID_576839005" STARTARROW="None" STARTINCLINATION="169;0;"/>
|
|
</node>
|
|
<node CREATED="1560698814327" ID="ID_44788176" MODIFIED="1576282358076" TEXT="wie wird es zugänglich?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
per direktem Zugriff via Interface DisplayManager
|
|
</li>
|
|
<li>
|
|
per Zuweisung an die einzelnen TrackBody (signal == smart-ptr!)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561036803347" ID="ID_281948392" MODIFIED="1672707022158" TEXT="Sigc-Signal ist ein (ref-counting) smart-ptr">
|
|
<linktarget COLOR="#8bbab7" DESTINATION="ID_281948392" ENDARROW="Default" ENDINCLINATION="824;0;" ID="Arrow_ID_1340083553" SOURCE="ID_525512704" STARTARROW="None" STARTINCLINATION="-507;22;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561036911418" ID="ID_1948376179" MODIFIED="1561048719567" TEXT="Struktur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561036914961" ID="ID_318008470" MODIFIED="1561042586692" TEXT="der DisplayManager trägt das "Anker"-Signal">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1561036987264" ID="ID_1799554074" MODIFIED="1582931247838" TEXT="signalStructureChange">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="93;0;" ID="Arrow_ID_576839005" SOURCE="ID_1490359824" STARTARROW="None" STARTINCLINATION="169;0;"/>
|
|
<linktarget COLOR="#8db7cd" DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="598;258;" ID="Arrow_ID_1531606207" SOURCE="ID_833580972" STARTARROW="None" STARTINCLINATION="455;26;"/>
|
|
<linktarget COLOR="#89adc8" DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="340;0;" ID="Arrow_ID_19787354" SOURCE="ID_1865072728" STARTARROW="None" STARTINCLINATION="1589;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561036945238" ID="ID_932981139" MODIFIED="1561047017981" TEXT="Nutzer kopieren es sich hiervon">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561037513769" ID="ID_1240081490" MODIFIED="1561042582058" TEXT="das BodyCanvasWidget hängt daran seinen Slot">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1561037555636" ID="ID_830580579" MODIFIED="1565272188071" TEXT="slotStructureChange">
|
|
<linktarget COLOR="#3a5fc7" DESTINATION="ID_830580579" ENDARROW="Default" ENDINCLINATION="22;64;" ID="Arrow_ID_820625489" SOURCE="ID_1083460430" STARTARROW="None" STARTINCLINATION="69;7;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672707067098" ID="ID_394283688" MODIFIED="1672707125211" TEXT="Change-Listener vom ZoomWindow (TimelineLayout) angekoppelt">
|
|
<arrowlink COLOR="#34a5a4" DESTINATION="ID_445391760" ENDARROW="Default" ENDINCLINATION="108;96;" ID="Arrow_ID_1879633887" STARTARROW="None" STARTINCLINATION="515;22;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582987902149" ID="ID_1883527171" MODIFIED="1582988088360" TEXT="Details: Strukturänderung auf Timeline-Elemente übertragen">
|
|
<arrowlink COLOR="#7aacc3" DESTINATION="ID_1537299376" ENDARROW="Default" ENDINCLINATION="-632;83;" ID="Arrow_ID_1708561781" STARTARROW="None" STARTINCLINATION="806;36;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582987649916" ID="ID_1965735811" MODIFIED="1582987656795" TEXT="Auslöser">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1582987662546" ID="ID_1241259382" MODIFIED="1582988324071" TEXT="Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582988407348" ID="ID_1492167964" MODIFIED="1582988538202" TEXT="Trigger im Diff-System verankert">
|
|
<arrowlink COLOR="#4d8b82" DESTINATION="ID_727500820" ENDARROW="Default" ENDINCLINATION="-1160;0;" ID="Arrow_ID_680446238" STARTARROW="None" STARTINCLINATION="-1645;0;"/>
|
|
</node>
|
|
<node CREATED="1582988189302" ID="ID_1886398385" MODIFIED="1582988334866" TEXT="triggert re-Konstruieren">
|
|
<arrowlink COLOR="#6e8c9b" DESTINATION="ID_1911321905" ENDARROW="Default" ENDINCLINATION="-733;-208;" ID="Arrow_ID_528411186" STARTARROW="None" STARTINCLINATION="1622;164;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582988593441" ID="ID_1045867973" MODIFIED="1582988608129" TEXT="das löst seinerseits signalStructureChange aus"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582987668065" ID="ID_1132578172" MODIFIED="1582987683420" TEXT="gibt es noch sonstige?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565269870508" FOLDED="true" HGAP="79" ID="ID_1694997659" MODIFIED="1582994817448" TEXT="Thema: Platz belegen" VSHIFT="10">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1565269889973" ID="ID_505463246" MODIFIED="1565269897468" TEXT="wann passiert das?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1565270118707" ID="ID_271042562" MODIFIED="1565270125821" TEXT="zwei Modelle denkbar">
|
|
<node CREATED="1565270127210" FOLDED="true" ID="ID_1361476631" MODIFIED="1565273111637" TEXT="systematisch">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1565270170764" ID="ID_1485295868" MODIFIED="1565270177943" TEXT="on realize()"/>
|
|
<node CREATED="1565270179930" ID="ID_184642245" MODIFIED="1565270190161" TEXT="wenn die Größe geändert wurde">
|
|
<node CREATED="1565270944290" ID="ID_842897291" LINK="https://developer.gnome.org/gtk3/stable/GtkWidget.html#GtkWidget-configure-event" MODIFIED="1567869662204" TEXT="the "configure-event"">
|
|
<linktarget COLOR="#819eaf" DESTINATION="ID_842897291" ENDARROW="Default" ENDINCLINATION="1085;0;" ID="Arrow_ID_704507451" SOURCE="ID_244849159" STARTARROW="None" STARTINCLINATION="2673;-176;"/>
|
|
</node>
|
|
<node CREATED="1565272115020" ID="ID_1493844829" MODIFIED="1565272125236" TEXT="size_allocate?"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565272130826" ID="ID_1758102270" MODIFIED="1565276547287" TEXT="sonst? Expermient machen">
|
|
<linktarget COLOR="#d44574" DESTINATION="ID_1758102270" ENDARROW="Default" ENDINCLINATION="161;13;" ID="Arrow_ID_533711629" SOURCE="ID_841565553" STARTARROW="None" STARTINCLINATION="663;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565270191321" ID="ID_1083460430" MODIFIED="1565272188071" TEXT="nach Struktur-Änderungen">
|
|
<arrowlink COLOR="#3a5fc7" DESTINATION="ID_830580579" ENDARROW="Default" ENDINCLINATION="22;64;" ID="Arrow_ID_820625489" STARTARROW="None" STARTINCLINATION="69;7;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565270133489" FOLDED="true" ID="ID_246191901" MODIFIED="1565270273097" TEXT="nach Bedarf">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1565270236979" ID="ID_500089479" MODIFIED="1565270248056" TEXT="Problem ist hier, den Bedarf zu erkennen">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1565270276854" ID="ID_1536974886" MODIFIED="1565270289802" TEXT="ist also nur eine Schein-Lösung">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1565273005475" ID="ID_1081606131" MODIFIED="1576282358075" TEXT="aber sinnvoll zum Triggern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es ist sinnvoll, die Feststellung einer Änderung vom Berechnen der neuen Werte zu trennen.
|
|
</p>
|
|
<p>
|
|
Die <i>Notwendigkeit</i> einer Neuberechnung wird also systematisch festgestellt,
|
|
</p>
|
|
<p>
|
|
aber die tatsächliche Neuberechnung erfolgt erst spät, und bei Bedarf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8c9ca5" DESTINATION="ID_666349818" ENDARROW="Default" ENDINCLINATION="472;-18;" ID="Arrow_ID_1928094034" STARTARROW="Default" STARTINCLINATION="-298;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565272203271" ID="ID_882288996" MODIFIED="1565272228941">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß <i>nach</i> GTK's Behandlung gemacht werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1565272231130" ID="ID_1494587769" MODIFIED="1565272239670" TEXT="erst muß GTK nach seinem System den Platz belegen"/>
|
|
<node CREATED="1565272267647" ID="ID_435131169" MODIFIED="1565272278457" TEXT="dann können wir endgültig unseren Platz festlegen"/>
|
|
<node CREATED="1565272555130" ID="ID_1371436208" MODIFIED="1582989730794" TEXT="und müssen als Konsequenz auch dynamisch vergrößern">
|
|
<linktarget COLOR="#4c8bd7" DESTINATION="ID_1371436208" ENDARROW="Default" ENDINCLINATION="115;0;" ID="Arrow_ID_1110457125" SOURCE="ID_851047389" STARTARROW="None" STARTINCLINATION="134;7;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565272282454" ID="ID_1908255689" MODIFIED="1565272311351">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Grundlagen müssen <i>vor</i> GTK's Behandlung erfolgen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1565272503600" ID="ID_1427250696" MODIFIED="1565272509745" TEXT="aber nur mit Einschränkung"/>
|
|
<node CREATED="1565272510615" ID="ID_329997818" MODIFIED="1565272532607" TEXT="es genügt, sinnvolle Minimalwerte zu setzen"/>
|
|
<node CREATED="1565272533522" ID="ID_851047389" MODIFIED="1582989730794" TEXT="denn wir werden später immer noch vergrößern müssen">
|
|
<arrowlink COLOR="#4c8bd7" DESTINATION="ID_1371436208" ENDARROW="Default" ENDINCLINATION="115;0;" ID="Arrow_ID_1110457125" STARTARROW="None" STARTINCLINATION="134;7;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565269898720" ID="ID_709484512" MODIFIED="1565269907147" TEXT="was muß passieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1565272714735" ID="ID_758511873" MODIFIED="1565272729843" TEXT="Track-Heads müssen ihre Controls unterbringen können"/>
|
|
<node CREATED="1565272733041" ID="ID_1333387410" MODIFIED="1565272749626" TEXT="Track-Bodies müssen ihren Content darstellen können"/>
|
|
<node CREATED="1565272863440" ID="ID_1088687911" MODIFIED="1565272882384" TEXT="der Zeichen-Code braucht ggfs. zusätzlichen Raum"/>
|
|
<node CREATED="1565272886564" ID="ID_726198762" MODIFIED="1565272911133" TEXT="Jedes Teilelement setzt seine Ausdehnung fest"/>
|
|
<node CREATED="1565272911999" ID="ID_505692945" MODIFIED="1565272930138" TEXT="danach folgt eine vergrößernde Abstimmung"/>
|
|
<node CREATED="1565272944612" ID="ID_559376631" MODIFIED="1582989776685">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Teilelemente <i>speichern</i> ihren Wert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1565272972192" ID="ID_1941959455" MODIFIED="1565272983357">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zeichencode <i>verwendet</i> diesen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1565269919314" ID="ID_128780255" MODIFIED="1565269921729" TEXT="Struktur">
|
|
<node CREATED="1565269950161" ID="ID_1371304351" MODIFIED="1565269963907" TEXT="jeder Clip muß feststellen was er braucht"/>
|
|
<node CREATED="1565269965040" ID="ID_1456350700" MODIFIED="1565272666343" TEXT="jeder Track muß das intern für sich aushandeln">
|
|
<arrowlink COLOR="#464cb7" DESTINATION="ID_1989047133" ENDARROW="Default" ENDINCLINATION="-742;0;" ID="Arrow_ID_1408255827" STARTARROW="None" STARTINCLINATION="440;27;"/>
|
|
</node>
|
|
<node CREATED="1565269994131" ID="ID_723034201" MODIFIED="1565270006259" TEXT="die Teil-Ausdehnungen sind zu aggregieren"/>
|
|
<node CREATED="1565270007474" ID="ID_878794125" MODIFIED="1565270021812" TEXT="Zusatzbedarf für Layout/Dekoration"/>
|
|
</node>
|
|
<node CREATED="1565269922650" ID="ID_1107611568" MODIFIED="1565269925662" TEXT="Koordination">
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1565273130691" ID="ID_539630517" MODIFIED="1565273161569" TEXT="systematisch triggern und Flags setzen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1565273141662" ID="ID_666349818" MODIFIED="1565273205895" TEXT="spät und bei Bedarf die tatsächlichen Berechnungen ausführen">
|
|
<linktarget COLOR="#8c9ca5" DESTINATION="ID_666349818" ENDARROW="Default" ENDINCLINATION="472;-18;" ID="Arrow_ID_1928094034" SOURCE="ID_1081606131" STARTARROW="Default" STARTINCLINATION="-298;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276441575" FOLDED="true" HGAP="128" ID="ID_1008547187" MODIFIED="1679086272990" TEXT="Umsetzung" VSHIFT="-26">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276460661" ID="ID_5450975" MODIFIED="1679086203225" TEXT="Trigger-Punkte">
|
|
<icon BUILTIN="info"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276497480" ID="ID_626936962" MODIFIED="1611920407215" TEXT="initial">
|
|
<arrowlink COLOR="#89b9c4" DESTINATION="ID_1666462781" ENDARROW="Default" ENDINCLINATION="611;0;" ID="Arrow_ID_457212401" STARTARROW="None" STARTINCLINATION="611;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276507055" ID="ID_1099814081" MODIFIED="1565276516574" TEXT="Größen-Änderung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276523637" ID="ID_841565553" MODIFIED="1565276547287" TEXT="wie erkennen?">
|
|
<arrowlink COLOR="#d44574" DESTINATION="ID_1758102270" ENDARROW="Default" ENDINCLINATION="161;13;" ID="Arrow_ID_533711629" STARTARROW="None" STARTINCLINATION="663;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1582988935367" ID="ID_829958563" MODIFIED="1672875280897" TEXT="Problem mit automatischer Scrollbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...deutet darauf hin, daß in diesem Zusammenhang etwas schiefläuft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8c6572" DESTINATION="ID_483543888" ENDARROW="Default" ENDINCLINATION="544;-34;" ID="Arrow_ID_759404699" STARTARROW="None" STARTINCLINATION="395;28;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276882329" ID="ID_545533298" MODIFIED="1565276923406" TEXT="Zustands-Änderung (expanded/collapsed)">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1565276481723" ID="ID_486818015" MODIFIED="1565276514847" TEXT="signalStructureChange">
|
|
<arrowlink COLOR="#73c2be" DESTINATION="ID_1563488644" ENDARROW="Default" ENDINCLINATION="576;0;" ID="Arrow_ID_1851095183" STARTARROW="None" STARTINCLINATION="597;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582930819530" ID="ID_1636643575" MODIFIED="1582930825502" TEXT="#1209 ensure display evaluation is performed reliably">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1582930831025" ID="ID_1768705376" MODIFIED="1582930913112" TEXT="hatte einzelne Vorfälle im Testcode zum relativen Clip-Placement">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man die mark "test"-Nachricht an eine Timeline schickt, die vorher per Population "reingeschossen" wurde, ohne sie jemals im UI anzuzeigen. Das heißt, im Moment haben wir da <b>definitiv</b> eine offene Flanke -- allerdings ist das ganze Thema auch bisher ehr ein draft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611918440785" HGAP="-8" ID="ID_1799063910" MODIFIED="1611920975289" TEXT="Stand" VSHIFT="10">
|
|
<edge COLOR="#58689e" STYLE="linear"/>
|
|
<linktarget COLOR="#2252b8" DESTINATION="ID_1799063910" ENDARROW="Default" ENDINCLINATION="48;334;" ID="Arrow_ID_276756493" SOURCE="ID_1009590247" STARTARROW="None" STARTINCLINATION="-334;85;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#435e98" CREATED="1611918484023" ID="ID_1998807581" MODIFIED="1611918546027" TEXT="4/2020">
|
|
<node CREATED="1611918493341" ID="ID_1458082993" MODIFIED="1611918502533" TEXT="Timeline-Konstrollstruktur ist da"/>
|
|
<node CREATED="1611918503905" ID="ID_1426688996" MODIFIED="1611918511294" TEXT="erster Draft für Clip-Anzeige"/>
|
|
<node CREATED="1611918513014" ID="ID_826865191" MODIFIED="1611918530129" TEXT="Trigger">
|
|
<node CREATED="1611918534396" ID="ID_1507749604" MODIFIED="1611918649982" TEXT="einzig BodyCanvasWidget::maybeRebuildLayout()">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1611918651549" ID="ID_1270377106" MODIFIED="1611918666929" TEXT="aus BodyCanvasWidget::getProfile_">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611918667922" ID="ID_1487411072" MODIFIED="1611918681877" TEXT="damit rein nach Bedarf"/>
|
|
</node>
|
|
<node CREATED="1611918741213" ID="ID_396002411" MODIFIED="1611918753315" TEXT="indirekte Triggerbedingung">
|
|
<node CREATED="1611918756795" ID="ID_1406903463" MODIFIED="1611919419969">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
isnil (<font color="#293bcd">profile_</font>)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1611920351800" ID="ID_1666462781" MODIFIED="1611920377932" TEXT="ist bei Konstruktion == null">
|
|
<linktarget COLOR="#89b9c4" DESTINATION="ID_1666462781" ENDARROW="Default" ENDINCLINATION="611;0;" ID="Arrow_ID_457212401" SOURCE="ID_626936962" STARTARROW="None" STARTINCLINATION="611;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611919430964" ID="ID_1154063221" MODIFIED="1611919443478" TEXT="BodyCanvasWidget::disable()">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611920064342" ID="ID_504940493" MODIFIED="1611920072904" TEXT="etwas fragwürdig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1611920262075" ID="ID_1537785236" MODIFIED="1611920280909" TEXT="sollte das niche ehr ein signalStructureChange() sein?"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611920282881" ID="ID_676112629" MODIFIED="1611920309972" TEXT="und warum wird der rootBody_ ≔ null gesetzt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1611920311381" ID="ID_1468092111" MODIFIED="1611920317824" TEXT="wer baut den (wieder) auf?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611920075406" ID="ID_924343393" MODIFIED="1611920087014" TEXT="beim Löschen eines Track aufgerufen">
|
|
<node CREATED="1611920186183" ID="ID_1923992459" MODIFIED="1611920200504" TEXT="aber als ViewHook::remove()-Implementierung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611919912363" ID="ID_1563488644" MODIFIED="1611920392591" TEXT="BodyCanvasWidget::slotStructureChange()">
|
|
<linktarget COLOR="#73c2be" DESTINATION="ID_1563488644" ENDARROW="Default" ENDINCLINATION="576;0;" ID="Arrow_ID_1851095183" SOURCE="ID_486818015" STARTARROW="None" STARTINCLINATION="597;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611920935537" ID="ID_635197187" MODIFIED="1611920954225" TEXT="es fehlt die Reaktion auf Größenänderung und re-Allokation">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611920958639" ID="ID_672952621" MODIFIED="1672787275660" TEXT="2/2021">
|
|
<node COLOR="#338800" CREATED="1611920993410" ID="ID_73368483" MODIFIED="1612641365225" TEXT="Ziel: vorläufige Clip-Anzeige an der richtigen Stelle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672787245084" ID="ID_981886029" MODIFIED="1672787302614" TEXT="(ist inzwischen der Fall)">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672787253663" ID="ID_1729285584" MODIFIED="1678405903445" TEXT="Winter 2022/23">
|
|
<node COLOR="#338800" CREATED="1672787313919" ID="ID_1746559922" MODIFIED="1672797007708" TEXT="integriere ZoomWindow">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1672787325263" ID="ID_1202050801" MODIFIED="1672787341544" TEXT="Change-Listener dort kann ebenfalls Display-Evaluation auslösen"/>
|
|
<node CREATED="1672787342676" ID="ID_1189311522" MODIFIED="1672787960019" TEXT="aber auch: ZoomWindow selber muß von Geometrie-Änderungen erfahren">
|
|
<arrowlink COLOR="#4c7ef4" DESTINATION="ID_973993644" ENDARROW="Default" ENDINCLINATION="-1199;-155;" ID="Arrow_ID_1196387900" STARTARROW="None" STARTINCLINATION="2666;104;"/>
|
|
<linktarget COLOR="#444b9e" DESTINATION="ID_1189311522" ENDARROW="Default" ENDINCLINATION="785;29;" ID="Arrow_ID_1573433988" SOURCE="ID_650213030" STARTARROW="None" STARTINCLINATION="241;10;"/>
|
|
<linktarget COLOR="#4a759a" DESTINATION="ID_1189311522" ENDARROW="Default" ENDINCLINATION="1548;60;" ID="Arrow_ID_751989601" SOURCE="ID_37048779" STARTARROW="None" STARTINCLINATION="1439;57;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672787636743" ID="ID_1344084462" MODIFIED="1672797005517" TEXT="Flexibilisierung Display-Evaluation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1672787680391" ID="ID_1852720730" MODIFIED="1672787701739" TEXT="ist bisher zu „fest gedrahtet“">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1672787656282" ID="ID_1938149016" MODIFIED="1672787679639" TEXT="muß weitere Komponenten integrieren können">
|
|
<node CREATED="1672787706195" ID="ID_1709964238" MODIFIED="1672787709536" TEXT="ZoomWindow"/>
|
|
<node CREATED="1672787710007" ID="ID_894239833" MODIFIED="1672787717634" TEXT="Koordination im LayoutManager"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1565276663937" ID="ID_712308681" MODIFIED="1679085393495" TEXT="Marker für geplante Neuberechnung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1565276684054" ID="ID_1620487558" MODIFIED="1565276701349" TEXT="isnil (TrackProfile)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1565276732282" ID="ID_958770975" MODIFIED="1679085388914" TEXT="dirty-Flag an geeignerter Stelle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bis jetzt genügt es, das TrackProfile selbst als "dirty-flag" zu misbrauchen. Aber ich vermute, längerfristig bekommen wir irgendwo im GUI noch weiteren "dirty-state" ⟹ und dann bleibt die Frage, wo siedeln wir den an...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276582060" HGAP="244" ID="ID_1896159832" MODIFIED="1672673134068" TEXT="Display-Evaluation-Pass">
|
|
<linktarget COLOR="#735667" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="68;-547;" ID="Arrow_ID_672337506" SOURCE="ID_134472006" STARTARROW="None" STARTINCLINATION="1091;68;"/>
|
|
<linktarget COLOR="#735667" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="68;-547;" ID="Arrow_ID_1219011636" SOURCE="ID_1362490028" STARTARROW="None" STARTINCLINATION="1094;73;"/>
|
|
<linktarget COLOR="#7b45d8" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="-839;66;" ID="Arrow_ID_786196853" SOURCE="ID_1758019036" STARTARROW="None" STARTINCLINATION="667;67;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666378011037" ID="ID_595193151" MODIFIED="1666378030994" TEXT="#1252 Timeline display-evaluation-pass">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582990060411" HGAP="75" ID="ID_499410745" MODIFIED="1679085114524" TEXT="Ausführungs-Struktur" VSHIFT="-14">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1582990066937" ID="ID_1271958729" MODIFIED="1582990072357" TEXT="Grundsätzlich">
|
|
<node CREATED="1582990081504" ID="ID_1009590247" MODIFIED="1582990084347" TEXT="ausgelöst">
|
|
<arrowlink COLOR="#2252b8" DESTINATION="ID_1799063910" ENDARROW="Default" ENDINCLINATION="48;334;" ID="Arrow_ID_276756493" STARTARROW="None" STARTINCLINATION="-334;85;"/>
|
|
<node CREATED="1582990085729" ID="ID_600460054" MODIFIED="1582990119965" TEXT="bei Bedarf">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1582990097374" ID="ID_424445384" MODIFIED="1582990113629" TEXT="nachdem alle Betroffenen bereits da sind">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582990127105" ID="ID_467377598" MODIFIED="1582990133110" TEXT="Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582990139760" FOLDED="true" ID="ID_1798095645" MODIFIED="1582990145211" TEXT="mehrere Bezugssysteme">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1582990146847" ID="ID_1892380041" MODIFIED="1582990159097" TEXT="strukturelle Hierarchie"/>
|
|
<node CREATED="1582990166774" ID="ID_160585935" MODIFIED="1582990173325" TEXT="funktionelle Hierarchie">
|
|
<node CREATED="1582990174283" ID="ID_1358397767" MODIFIED="1582990181528" TEXT="vor allem im Canvas"/>
|
|
<node CREATED="1582990182170" ID="ID_286499384" MODIFIED="1582990206578" TEXT="aufgedoppelte Struktur in den TrackBody-Elementen"/>
|
|
</node>
|
|
<node CREATED="1582990210670" ID="ID_605968231" MODIFIED="1582990229767" TEXT="geometrische Hierarchie">
|
|
<node CREATED="1582990248505" ID="ID_602361892" MODIFIED="1582990251332" TEXT="Schachtelung">
|
|
<node CREATED="1582990265182" ID="ID_1785851420" MODIFIED="1582990270642" TEXT="Docking-pane"/>
|
|
<node CREATED="1582990272030" ID="ID_581839904" MODIFIED="1582990281728" TEXT="Timeline Panel-Tab"/>
|
|
<node CREATED="1582990285372" ID="ID_463161150" MODIFIED="1582990292247" TEXT="left Pane">
|
|
<node CREATED="1582990417338" ID="ID_1278424192" MODIFIED="1582990426037" TEXT="Teilung Navigator / Patchbay"/>
|
|
<node CREATED="1582990426913" ID="ID_107683155" MODIFIED="1582990436927" TEXT="Tracks in der Patchbay">
|
|
<node CREATED="1582990438749" ID="ID_803277221" MODIFIED="1582990443002" TEXT="von oben nach unten"/>
|
|
<node CREATED="1582990443776" ID="ID_1332669205" MODIFIED="1582990449873" TEXT="von innen nach außen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582990292907" ID="ID_1319070559" MODIFIED="1582990295966" TEXT="right Pane">
|
|
<node CREATED="1582990301313" ID="ID_203503889" MODIFIED="1582990307980" TEXT="Teilung wegen Scrolling"/>
|
|
<node CREATED="1582990308664" ID="ID_231067935" MODIFIED="1582990319732" TEXT="wird jedoch bereits intern gehandhabt"/>
|
|
<node CREATED="1582990321359" ID="ID_247850066" MODIFIED="1582990328698" TEXT="erscheint als uniforme Zeichenfläche"/>
|
|
<node CREATED="1582990355570" ID="ID_524994712" MODIFIED="1582990371428" TEXT="realisiert aber de-facto auch eine Hierarchie">
|
|
<node CREATED="1582990372680" ID="ID_122407571" MODIFIED="1582990377043" TEXT="geschachtelte Tracks"/>
|
|
<node CREATED="1582990377751" ID="ID_754352" MODIFIED="1582990383322" TEXT="von oben nach unten"/>
|
|
<node CREATED="1582990390238" ID="ID_664493300" MODIFIED="1582990408551" TEXT="von innen nach außen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582990252083" ID="ID_344719650" MODIFIED="1582990256355" TEXT="von oben nach unten"/>
|
|
<node CREATED="1582990257583" ID="ID_551100173" MODIFIED="1582990261149" TEXT="von links nach rechts">
|
|
<node CREATED="1582990493888" ID="ID_1406728700" MODIFIED="1582990515278" TEXT="fast immer ausgeschlossen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da links->rechts auf die Zeitachse abgebildet ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582990516445" ID="ID_1869844868" MODIFIED="1582990539925" TEXT="Ausnahme: Patchbay">
|
|
<node CREATED="1582990541033" ID="ID_1986940143" MODIFIED="1582990552936" TEXT="Verschachtelungstiefe im Baum-Graphen"/>
|
|
<node CREATED="1582990553928" ID="ID_164949916" MODIFIED="1582990575913" TEXT="Minimal-Ausdehnung der Controls im Track-Head"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582991242096" FOLDED="true" HGAP="111" ID="ID_743061991" MODIFIED="1679085241620" TEXT="Wirk-Pfade" VSHIFT="-16">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1582991739392" ID="ID_964423802" MODIFIED="1582991744027" TEXT="in GTK">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1582991754360" ID="ID_427688996" MODIFIED="1582991772673" TEXT="jedes Widget definiert seine minimale Platz-Anforderung"/>
|
|
<node CREATED="1582991777437" ID="ID_480450913" MODIFIED="1582991797636" TEXT="Platzmangel wird per Overflow gelöst">
|
|
<node CREATED="1582991802555" ID="ID_1172300308" MODIFIED="1582991808476" TEXT="width for height"/>
|
|
<node CREATED="1582991809272" ID="ID_1291349715" MODIFIED="1582991812763" TEXT="height for width"/>
|
|
</node>
|
|
<node CREATED="1582991832808" ID="ID_1564814529" MODIFIED="1582991851613" TEXT="zusätzlicher Platz wird per Füllmechanismus verteilt"/>
|
|
<node CREATED="1582991852866" ID="ID_39596491" MODIFIED="1582991860876" TEXT="jedes Widget bekommt eine Allokation"/>
|
|
<node CREATED="1582991861608" ID="ID_119326076" MODIFIED="1582991868867" TEXT="...und wird zum Zeichnen aufgefordert">
|
|
<node COLOR="#641a3d" CREATED="1582991870072" ID="ID_286684900" MODIFIED="1582991896331" TEXT="hier erst kann unser Code aktiv werden">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582991961258" ID="ID_545649889" MODIFIED="1582991965501" TEXT="pro Track">
|
|
<node CREATED="1582992016890" ID="ID_1705972913" MODIFIED="1582992030828" TEXT="Aufsammeln der vertikalen Ausdehnung"/>
|
|
<node CREATED="1582992031648" ID="ID_752229981" MODIFIED="1582992037387" TEXT="Maximum + Padding"/>
|
|
<node CREATED="1582992060135" ID="ID_446948891" MODIFIED="1582992233901">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieses speichern als <font color="#5d1843">TrackBody::<b>contentHeight_</b></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582992575660" ID="ID_1847082474" MODIFIED="1582992587869" TEXT="Head <-> Body">
|
|
<node CREATED="1582992599058" ID="ID_1308776454" MODIFIED="1582992606624" TEXT="Head -> Body">
|
|
<node CREATED="1582992608761" ID="ID_1391476282" MODIFIED="1582992619859" TEXT="muß in die vertikale Ausdehnung mit eingehen"/>
|
|
</node>
|
|
<node CREATED="1582992663089" ID="ID_1122116110" MODIFIED="1582992671524" TEXT="Body -> Head">
|
|
<node CREATED="1582992688462" ID="ID_1694951369" MODIFIED="1582992707232" TEXT="Head muß exakt auf die Ausdehnung des Body gespreizt werden"/>
|
|
<node CREATED="1582992708484" ID="ID_1956350254" MODIFIED="1582992756018" TEXT="Vorsicht: das muß früh erfolgen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582992724026" ID="ID_772600480" MODIFIED="1582992752646" TEXT="bevor GTK aktiv wird">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1582992742037" ID="ID_1532947172" MODIFIED="1582992750234" TEXT="Änderung löst kompletten Zeichenzyklus aus"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582992261608" ID="ID_647002044" MODIFIED="1582992271986" TEXT="Track->Fork->TimelineCanvas">
|
|
<node CREATED="1582992289786" ID="ID_478649023" MODIFIED="1582996676592">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wird komplett erledigt durch <font color="#5c2549">TrackBody::<b>establishTrackSpace</b></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582992315675" ID="ID_1937379462" MODIFIED="1582992414632">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Auslösen durch <b><font color="#7a264c">signalStructureChange</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1582993077095" FOLDED="true" ID="ID_1248829869" MODIFIED="1582993085449" TEXT="Vorsicht: Rekursion">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582993092825" ID="ID_1779309098" MODIFIED="1582993104811" TEXT="Clip und Effekt">
|
|
<node CREATED="1582993119758" ID="ID_1843431209" MODIFIED="1582993172267" TEXT="enthält (voraussichtlich) komplette verschachtelte Timeline-Struktur"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582993256244" ID="ID_1054753498" MODIFIED="1582993279274" TEXT="Problem: wie gehen wir mit dem Head-Bereich um?">
|
|
<linktarget COLOR="#9a5670" DESTINATION="ID_1054753498" ENDARROW="Default" ENDINCLINATION="-3448;194;" ID="Arrow_ID_948617682" SOURCE="ID_1626144230" STARTARROW="None" STARTINCLINATION="1004;81;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1582993283464" ID="ID_187092898" MODIFIED="1582993298033" TEXT="horizontale Ausdehnung ist limitiert"/>
|
|
<node CREATED="1582993311469" ID="ID_1905724855" MODIFIED="1582993324697" TEXT="Lösungsansätze">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582993326008" ID="ID_1118811002" MODIFIED="1582993554765" TEXT="auf den Header-Berech verzichten">
|
|
<linktarget COLOR="#734474" DESTINATION="ID_1118811002" ENDARROW="Default" ENDINCLINATION="-50;4;" ID="Arrow_ID_1937551526" SOURCE="ID_17198777" STARTARROW="None" STARTINCLINATION="-324;-102;"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1582993340944" ID="ID_583086871" MODIFIED="1582993355096" TEXT="können wir das wirklich bis zum Ende durchhalten??">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1582993384124" ID="ID_1159677197" MODIFIED="1582993404276" TEXT="man könnte den Clip in einem neuen Timeline-Tab aufmachen"/>
|
|
<node CREATED="1582993407759" ID="ID_976591024" MODIFIED="1582993426099" TEXT="dann wäre die Clip-Anzeige stets »abgekürzt«"/>
|
|
</node>
|
|
<node CREATED="1582993456608" ID="ID_614577452" MODIFIED="1582993550949" TEXT="Header-Bereich als Brücke rendern">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1582993522569" ID="ID_1946280413" MODIFIED="1582993528110" TEXT="vielleicht immer sichtbar"/>
|
|
<node CREATED="1582993471862" ID="ID_1469148025" MODIFIED="1582993477200" TEXT="horizontal verschiebbar"/>
|
|
<node CREATED="1582993480844" ID="ID_397325641" MODIFIED="1582993487137" TEXT="einklappbar"/>
|
|
<node CREATED="1582993508727" ID="ID_270624980" MODIFIED="1582993516003" TEXT="geht nicht bei zu kleinen Clips"/>
|
|
</node>
|
|
<node CREATED="1582993533204" ID="ID_1997246843" MODIFIED="1582993569673" TEXT="Header-Bereich als Überhang links">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1582993597075" ID="ID_1870967483" MODIFIED="1582993618478" TEXT="Überhang muß visuell verdeutlicht werden"/>
|
|
<node CREATED="1582993583853" ID="ID_1350317066" MODIFIED="1582993644123" TEXT="ebenfalls mitlaufend und wegklappbar"/>
|
|
<node CREATED="1582993827289" ID="ID_835847813" MODIFIED="1582993850770" TEXT="Timeline muß ggfs nach links jenseits von Null erweitert werden"/>
|
|
</node>
|
|
<node CREATED="1611119459685" ID="ID_948080801" MODIFIED="1611119890746" TEXT="Track-Header-Bereich nutzen">
|
|
<icon BUILTIN="full-4"/>
|
|
<node CREATED="1611119472116" ID="ID_586467198" MODIFIED="1611119496620" TEXT="die Scope-Hierarchie überspannt ohnehin Tracks, Clips und Effekte"/>
|
|
<node CREATED="1611119498086" ID="ID_997383591" MODIFIED="1611119528080" TEXT="im Detail-Modus würde damit der Clip-Inhalt zu eingeschachtelten Pseudo-Tracks"/>
|
|
<node CREATED="1611119529869" ID="ID_436071858" MODIFIED="1611119595838" TEXT="und ensprechende Lables/Controls könnten in der Patchbay leben"/>
|
|
<node CREATED="1611119603818" ID="ID_1129752792" MODIFIED="1611119630501" TEXT="Aber: mehrere Clips auf der Timeline müßten sich diese Pseudo-Tracks teilen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1611119659018" ID="ID_1000548254" MODIFIED="1611119678899" TEXT="folglich wären Inhalt und Bedeutung dynamisch vom Fokus abhängig"/>
|
|
<node CREATED="1611119741841" ID="ID_383304836" MODIFIED="1611119880288" TEXT="hätte seinen Charme, wäre aber sehr anspruchsvoll umzusetzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das Schöne an diesem Ansatz wäre, daß er für den User komplett natürlich wirkt; solange man gleichartige Clips in einer Timeline liegen hat, würde sich dieses Konzept überaupt nicht auffällig bemerkbar machen; und ein weiterer Vorteil wäre, daß man es als Weiterentwicklung des 1. Lösungsansatzes betrachten kann...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1611119913136" ID="ID_17198777" MODIFIED="1611119984890" TEXT="Beschluß: vorerst verfolgen wir den Lösungsansatz-1 und sehen dann weiter....">
|
|
<arrowlink COLOR="#734474" DESTINATION="ID_1118811002" ENDARROW="Default" ENDINCLINATION="-50;4;" ID="Arrow_ID_1937551526" STARTARROW="None" STARTINCLINATION="-324;-102;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582993882182" ID="ID_1282407348" MODIFIED="1582993890945" TEXT="wenn es einen Header-Bereich gibt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1582993892114" ID="ID_1867662190" MODIFIED="1582993903794" TEXT="dann wiederholt sich 1:1 die Problematik von der Timeline"/>
|
|
<node CREATED="1582993904567" ID="ID_10857837" MODIFIED="1582993920776" TEXT="und die Lösung mit dem DisplayFrame muß verallgemeinert werden"/>
|
|
</node>
|
|
<node CREATED="1582993974317" ID="ID_1334346577" MODIFIED="1582993982823" TEXT="Außerdem...">
|
|
<node CREATED="1582993993650" ID="ID_1979728574" MODIFIED="1582994019387" TEXT="muß der gesamte DisplayEvaluationPass in jedem Clip komplett laufen"/>
|
|
<node CREATED="1582994040043" ID="ID_1049094462" MODIFIED="1582994055581" TEXT="das Resultat setzt eine Gesamt-Ausdehnung"/>
|
|
<node CREATED="1582994056505" ID="ID_1127135248" MODIFIED="1582994070796" TEXT="und triggert damit einen neuen Pass">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582994079654" ID="ID_180241522" MODIFIED="1582994103110" TEXT="Body -> Head -Rückmeldung">
|
|
<node CREATED="1582994112114" ID="ID_1104128825" MODIFIED="1582994131515" TEXT="kann zur Vergrößerung des Header-Widgets führen"/>
|
|
<node CREATED="1582994321717" ID="ID_778571331" MODIFIED="1582994333548" TEXT="und diese triggert einen neuen Pass">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1582994173545" ID="ID_215195075" MODIFIED="1582994187763" TEXT="es muß einen globalen Ausgleich geben">
|
|
<node CREATED="1582994188919" ID="ID_1821239484" MODIFIED="1582994212400" TEXT="denn wir haben zwar die Overview-Ruler zusätzlich über"/>
|
|
<node CREATED="1582994213112" ID="ID_1002913154" MODIFIED="1582994227798" TEXT="andererseits geht von der Header-Pane der Navigator weg"/>
|
|
<node CREATED="1582994285082" ID="ID_1430842857" MODIFIED="1582994300940" TEXT="man könnte einen gewissen Betrag davon nach unten verteilen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582994343496" ID="ID_1281717867" MODIFIED="1582994354246" TEXT="Rekursion einhegen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1582994362415" ID="ID_534180238" MODIFIED="1582994380448" TEXT="eine wilde Rekursion kann zu Oszillationen führen"/>
|
|
<node CREATED="1582994386724" ID="ID_640491515" MODIFIED="1582994396631" TEXT="wir müssen für monotone Änderungen sorgen"/>
|
|
<node CREATED="1582994409209" ID="ID_1593855255" MODIFIED="1582994419307" TEXT="diese müssen so groß wie möglich, aber niemals zu groß sein"/>
|
|
<node CREATED="1582994430718" ID="ID_1659605004" MODIFIED="1583525063060" TEXT="wir müssen alle korrelierten Änderungen auf einmal einbringen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1582994490311" ID="ID_1537290692" MODIFIED="1582994497769" TEXT="das bedeutet...."/>
|
|
<node CREATED="1582994498669" ID="ID_889822565" MODIFIED="1583525068436" TEXT="Größenänderungen müssen als Nachrichten abgesetzt werden">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1582994514659" ID="ID_620800362" MODIFIED="1583525074189" TEXT="diese müssen in einem späteren UI-Event aggregiert behandelt werden">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1583525076319" ID="ID_815242494" MODIFIED="1583525638834" TEXT="geht so nicht -- Widgets nicht sicher addressierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt keinen <i>einfachen und performanten</i> Mechanismus, über den ich mir irgend ein Widget merken und später noch sicher addressieren kann, selbst wenn eine Diff-Nachricht inzwischen die Anzeige umbaut und das bezeichnete Element inzwischen gelöscht ist. Und zwar deshalb, weil wir hier von echten einfachen GTK-Widgets reden, und nicht von unseren "Tangibles", die am UI-Bus hängen. Selbst wenn wir noch gesicherte »Mediatoren« dazwischenschalten, also z.B. diese Nachrichten über jeweils ein zuständiges model::Tangible zustellen, dann haben wiederum diese das identische Problem: sie bekommen nicht garantiert mit, wenn eines der von ihnen verwalteten Widgets inzwischen nicht mehr existiert. Wir bräuchten
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
entweder ein universelles Addressierungs-Schema, das aber dann auch bis auf das einzelne Widget herunter wirksam sein müßte
|
|
</li>
|
|
<li>
|
|
oder jeder Mediator (oder zumindest der DisplayManager selber) müßte Diff-Listener installieren, die auch sicher für Diffs auf ihre Kinder ansprechen (!)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#db337d" DESTINATION="ID_815242494" ENDARROW="Default" ENDINCLINATION="-814;0;" ID="Arrow_ID_1920099327" SOURCE="ID_1528548638" STARTARROW="None" STARTINCLINATION="812;88;"/>
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1583525520828" ID="ID_785480961" MODIFIED="1583525553466" TEXT="wohl auch nicht notwendig -- da das UI single-threaded läuft">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582994588889" ID="ID_1127174838" MODIFIED="1582994596164" TEXT="(idealer)Endpunkt">
|
|
<node CREATED="1582994614549" ID="ID_436198586" MODIFIED="1582994630335" TEXT="die sub-Clip und Header-Allokationen passen bereits"/>
|
|
<node CREATED="1582994631395" ID="ID_132052842" MODIFIED="1582994648575" TEXT="es muß alles nur noch einmal gezeichnet werden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582995207306" FOLDED="true" HGAP="103" ID="ID_548079760" MODIFIED="1582995223113" TEXT="Abhängigkeits-Steuerung" VSHIFT="11">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1582995233632" ID="ID_1067561210" MODIFIED="1582995245966" TEXT="die Konvergenz selber wird nicht explizit realisiert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1582995299738" ID="ID_1571358808" MODIFIED="1582995304581" TEXT="es gibt Phasen">
|
|
<linktarget COLOR="#96b3e9" DESTINATION="ID_1571358808" ENDARROW="Default" ENDINCLINATION="259;158;" ID="Arrow_ID_1529296223" SOURCE="ID_531908394" STARTARROW="None" STARTINCLINATION="-382;24;"/>
|
|
<linktarget COLOR="#6e829b" DESTINATION="ID_1571358808" ENDARROW="Default" ENDINCLINATION="476;590;" ID="Arrow_ID_1458719997" SOURCE="ID_868399927" STARTARROW="None" STARTINCLINATION="292;29;"/>
|
|
<node CREATED="1582995321487" ID="ID_772868413" MODIFIED="1582995337967" TEXT="weiterer Pass notwendig"/>
|
|
<node CREATED="1582995339452" ID="ID_1832467200" MODIFIED="1582995346706" TEXT="Pass findet statt"/>
|
|
<node CREATED="1582995372168" ID="ID_219954513" MODIFIED="1582995381674" TEXT="Größenänderungen abgesetzt"/>
|
|
</node>
|
|
<node CREATED="1582995460940" ID="ID_34447460" MODIFIED="1582995467695" TEXT="Abhängigkeits-Ordnung">
|
|
<node CREATED="1582995480735" ID="ID_1960342717" MODIFIED="1582995484829" TEXT="innen vor außen"/>
|
|
<node CREATED="1582995508832" ID="ID_706569968" MODIFIED="1582995517616" TEXT="Clip vor Track"/>
|
|
<node CREATED="1582995541969" ID="ID_1695345076" MODIFIED="1582995550355" TEXT="Header-Beitrag vor Body-Festsetzung"/>
|
|
<node CREATED="1582995611311" ID="ID_1286546344" MODIFIED="1582995621833" TEXT="aber: Hierarchie nicht relevant">
|
|
<node CREATED="1582995624230" ID="ID_527427935" MODIFIED="1582995631288" TEXT="das lösen die internen Mechanismen bereits"/>
|
|
<node CREATED="1582995631900" ID="ID_1750090379" MODIFIED="1582995643846" TEXT="in GTK sind das nested child widgets"/>
|
|
<node CREATED="1582995644603" ID="ID_1368190539" MODIFIED="1582995658084" TEXT="im BodyCanvas ist das der Platz für Sub-Tracks"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583103616819" ID="ID_635184052" MODIFIED="1583103674376">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Nein</b>: keine Abhängigkeiten,
|
|
</p>
|
|
<p>
|
|
sondern Iterationen!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1583103686706" ID="ID_1021464384" MODIFIED="1583103698796" TEXT="wir nähern uns dem korrekten Layout inkrementell an"/>
|
|
<node CREATED="1583103711798" ID="ID_1460889946" MODIFIED="1583104046449" TEXT="daher ist die Reihenfolge des Besuchs fast egal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Warum</u>? Weil wir immer die Hilfe von GTK brauchen, um aus unseren veränderten Vorgaben eine Platz-Allokation zu machen. Und diese Hilfe können wir nicht synchron anfordern, sondern triggern sie indirekt durch setzen neuer Mindestgrößen...
|
|
</p>
|
|
<p>
|
|
<u>Warum "fast"</u>? weil dann der Header-Pass eben doch eine globale Information transportiert, und zwar den Übertrag. Da die Auswertung aber auch hier ausfächert (über die Header in den Clips), sollte man tatsächlich versuchen, globale Datenhaltung (jenseits der Auswertungs-Phase) zu vermeiden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1583104061758" ID="ID_970866414" MODIFIED="1583104078795" TEXT=""fast" vermeiden, indem man rekursiv auswertet!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583104117487" ID="ID_1016623445" MODIFIED="1583104131498" TEXT="Konsequenz: rekursive Auswertungs-Scopes">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1583434078579" ID="ID_718475738" MODIFIED="1583434227770" TEXT="behandelt implizite Abhängigkeiten">
|
|
<linktarget COLOR="#f0e0c0" DESTINATION="ID_718475738" ENDARROW="Default" ENDINCLINATION="-190;15;" ID="Arrow_ID_1507039489" SOURCE="ID_1287988941" STARTARROW="None" STARTINCLINATION="201;15;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1583434172775" ID="ID_1444249960" MODIFIED="1583434412688" TEXT="Aufgabe ist, dieses orthogonal darzustellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Rekursion ist immer doppelbödig:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
angeblich haben wir selbstähnliche Strukturen
|
|
</li>
|
|
<li>
|
|
aber tatsächlich steckt eine Absicht dahinter
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1583434976100" ID="ID_1359440" MODIFIED="1583435092878" TEXT="hierfür wird die Abfolge verpflichtend geordnet">
|
|
<arrowlink COLOR="#6f56e5" DESTINATION="ID_1485425520" ENDARROW="Default" ENDINCLINATION="250;14;" ID="Arrow_ID_832303335" STARTARROW="None" STARTINCLINATION="298;17;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582995993706" FOLDED="true" HGAP="62" ID="ID_333264806" MODIFIED="1679085227862" TEXT="Aktivitäten" VSHIFT="8">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1583427610013" ID="ID_1910384749" MODIFIED="1583427716087" TEXT="Teilschritte">
|
|
<node CREATED="1582996051549" ID="ID_29139061" MODIFIED="1583427655853" TEXT="Track bestimmt Maximum über seinen Inhalt">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1582996202265" ID="ID_218499874" MODIFIED="1582996202265" TEXT="(Clips, Effekte)"/>
|
|
<node CREATED="1582996203830" ID="ID_149464381" MODIFIED="1582996209358" TEXT="input vom zugehörigen Head"/>
|
|
<node CREATED="1582996562758" ID="ID_1180945302" MODIFIED="1582996602940" TEXT="Ergebnis wird in contentHeight_ abgelegt"/>
|
|
</node>
|
|
<node CREATED="1582996608127" ID="ID_92521449" MODIFIED="1583427660810" TEXT="Canvas evaluation: TrackBody::establishTrackSpace">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1582996722829" ID="ID_842289587" MODIFIED="1583427701893" TEXT="Head-Ausgleichs-Pass">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583427622167" ID="ID_1142872612" MODIFIED="1583427625373" TEXT="Zusammenhang">
|
|
<node CREATED="1583427626479" ID="ID_954689662" MODIFIED="1583427635727" TEXT="jeder Teil ist in-sich geschlossen"/>
|
|
<node CREATED="1583427636950" ID="ID_1936738462" MODIFIED="1583427650200" TEXT="muß aber in sinnvoller Reihenfolge laufen">
|
|
<node CREATED="1583433528741" ID="ID_1966240809" MODIFIED="1583433550809" TEXT="Problem dabei: Aysmmetrie">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1583433557458" ID="ID_260365198" MODIFIED="1583433567364" TEXT="es sind nur zwei Teilsysteme, aber drei Passes">
|
|
<linktarget COLOR="#f04b31" DESTINATION="ID_260365198" ENDARROW="Default" ENDINCLINATION="396;0;" ID="Arrow_ID_1446215014" SOURCE="ID_783533006" STARTARROW="None" STARTINCLINATION="398;26;"/>
|
|
</node>
|
|
<node CREATED="1583433572927" ID="ID_242969113" MODIFIED="1583433619074" TEXT="der erste und der dritte Pass braucht die DisplayFrames">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil wir eine Verknüpfung der Body und Header-Informationen herstellen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1583433986108" ID="ID_542008018" MODIFIED="1583434006913" TEXT="der dritte Pass muß obendrein ein Integral transportieren"/>
|
|
<node CREATED="1611922802313" ID="ID_531908394" MODIFIED="1611922854579" TEXT="das läßt sich über ein Phasen-Modell integrieren">
|
|
<arrowlink COLOR="#96b3e9" DESTINATION="ID_1571358808" ENDARROW="Default" ENDINCLINATION="259;158;" ID="Arrow_ID_1529296223" STARTARROW="None" STARTINCLINATION="-382;24;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583434059006" ID="ID_1287988941" MODIFIED="1583434227770" TEXT="Idee: in der Rekursion verstecken">
|
|
<arrowlink COLOR="#f0e0c0" DESTINATION="ID_718475738" ENDARROW="Default" ENDINCLINATION="-190;15;" ID="Arrow_ID_1507039489" STARTARROW="None" STARTINCLINATION="201;15;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#8d0099" CREATED="1583435024997" ID="ID_1485425520" MODIFIED="1583435263295" TEXT="Verpflichtend in Layout-Ordnung auszuwerten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ausnahmslos von oben nach unten und von links nach rechts!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7a4ec3" DESTINATION="ID_1346473468" ENDARROW="Default" ENDINCLINATION="-294;-13;" ID="Arrow_ID_1976656108" STARTARROW="None" STARTINCLINATION="-358;20;"/>
|
|
<linktarget COLOR="#6f56e5" DESTINATION="ID_1485425520" ENDARROW="Default" ENDINCLINATION="250;14;" ID="Arrow_ID_832303335" SOURCE="ID_1359440" STARTARROW="None" STARTINCLINATION="298;17;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1582995698667" HGAP="165" ID="ID_1849412034" MODIFIED="1679085179278" TEXT="zu Bauen" VSHIFT="27">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1582996759972" FOLDED="true" ID="ID_1795046219" MODIFIED="1583537382866" TEXT="Rahmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582996764330" ID="ID_920127062" MODIFIED="1582996766870" TEXT="Umbau">
|
|
<node CREATED="1582996768074" ID="ID_1685131335" MODIFIED="1582996782861" TEXT="bisheriger Profil-Trigger muß herausgelöst werden"/>
|
|
<node CREATED="1582996783904" ID="ID_1435982546" MODIFIED="1583008976682" TEXT="ermittelte Größe muß vom Evaluation-Pass weiterverarbeitet werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nicht mehr direkt auf den BodyCanvas als Größe anwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583009002945" ID="ID_1360288962" MODIFIED="1583009011003" TEXT="Auslöse-Mechanismus klären">
|
|
<node CREATED="1583434315708" ID="ID_1757558045" MODIFIED="1583434327974" TEXT="auslösbar über das DisplayManager-API"/>
|
|
<node CREATED="1583435433150" ID="ID_641720015" MODIFIED="1583435453391" TEXT="der evaluation-Pass ist synchron und stateful"/>
|
|
<node CREATED="1583435417845" ID="ID_1265153119" MODIFIED="1583435463063" TEXT="und die Komponenten können Annahmen über das Resultat machen"/>
|
|
<node CREATED="1583435479472" ID="ID_1015699978" MODIFIED="1583435597100">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b><u>Invariante</u></b>: <i><font size="2">(nach dem Pass)</font></i> liegen vorläufig/hinreichend brauchbare Layout-Maße vor
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582995724279" FOLDED="true" ID="ID_742111018" MODIFIED="1675384156539" TEXT="Steuer-Komponente">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582995734606" ID="ID_1813411794" MODIFIED="1582995739220" TEXT="lebt im Layout-Manager"/>
|
|
<node CREATED="1582995740053" ID="ID_521808189" MODIFIED="1582995755383" TEXT="stateful (evaluationPhase)"/>
|
|
<node CREATED="1583435618709" ID="ID_1501002443" MODIFIED="1583435629364" TEXT="es ist die DisplayEvaluation selber">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1672787134816" ID="ID_973993644" MODIFIED="1672787960019" TEXT="Evaluation-Protocol">
|
|
<linktarget COLOR="#4c7ef4" DESTINATION="ID_973993644" ENDARROW="Default" ENDINCLINATION="-1199;-155;" ID="Arrow_ID_1196387900" SOURCE="ID_1189311522" STARTARROW="None" STARTINCLINATION="2666;104;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1672787147372" ID="ID_434415256" MODIFIED="1672787159297" TEXT="es wird in zwei Phasen alles besucht"/>
|
|
<node CREATED="1672787160077" ID="ID_1477021297" MODIFIED="1672787169815" TEXT="Besuch erfolgt jeweils in »Layout-Ordnung«"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582995826081" FOLDED="true" ID="ID_1814756232" MODIFIED="1583537369744" TEXT="Evaluation-Ctx?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582995915117" ID="ID_1313886171" MODIFIED="1582995918612" TEXT="notwendig?">
|
|
<node CREATED="1582995919703" ID="ID_1252142092" MODIFIED="1582995927631" TEXT="könnte Daten transportieren"/>
|
|
<node CREATED="1582995928331" ID="ID_1250781606" MODIFIED="1582995932606" TEXT="wäre dann ein Visitor"/>
|
|
</node>
|
|
<node CREATED="1582995935542" ID="ID_755542037" MODIFIED="1611922601116" TEXT="könnte verzichtbar sein...">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1582995943761" ID="ID_1763997736" MODIFIED="1582995951988" TEXT="wenn es nur um eine Trigger-Reihenfolge geht"/>
|
|
<node CREATED="1582995952856" ID="ID_1376470251" MODIFIED="1582995967965" TEXT="wenn stattdessen der Layout-Manager als Inteface durchgereicht wird"/>
|
|
<node CREATED="1611922646015" ID="ID_868399927" MODIFIED="1611922773610" TEXT="(wir haben aber Phasen)">
|
|
<arrowlink COLOR="#6e829b" DESTINATION="ID_1571358808" ENDARROW="Default" ENDINCLINATION="476;590;" ID="Arrow_ID_1458719997" STARTARROW="None" STARTINCLINATION="292;29;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583103170639" ID="ID_1199980563" MODIFIED="1583103203649" TEXT="könnte die DisplayEvaluation selber sein">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1583103181267" ID="ID_1854299076" MODIFIED="1583103191631" TEXT="diese wäre dann auch ein Interface"/>
|
|
<node CREATED="1583103192422" ID="ID_1947518764" MODIFIED="1583103201511" TEXT="und würde per Referenz durchgegeben"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1583435165604" ID="ID_1346473468" MODIFIED="1583435263295" TEXT="überneme die Zusammenhangs-Struktur vom Visitor">
|
|
<linktarget COLOR="#7a4ec3" DESTINATION="ID_1346473468" ENDARROW="Default" ENDINCLINATION="-294;-13;" ID="Arrow_ID_1976656108" SOURCE="ID_1485425520" STARTARROW="None" STARTINCLINATION="-358;20;"/>
|
|
<node CREATED="1583435179556" ID="ID_857623389" MODIFIED="1583435203049" TEXT="alle Komponenten bieten eine Challenge-Funktion"/>
|
|
<node CREATED="1583435204373" ID="ID_741511380" MODIFIED="1583435220824" TEXT="sie rekurieren mit Insider-Wissen auf den Visitor zurück"/>
|
|
<node CREATED="1583435311207" ID="ID_146344730" MODIFIED="1583435342779" TEXT="aber die DisplayEvaluation ist selbst der Visitor">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insofern fällt die doppelte Abstraktion und indirektion hier weg
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010104257" ID="ID_82409060" MODIFIED="1583537388690" TEXT="Evaluation-Pass">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_82409060" ENDARROW="Default" ENDINCLINATION="-1352;202;" ID="Arrow_ID_1110289108" SOURCE="ID_430878592" STARTARROW="None" STARTINCLINATION="-2400;-277;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1672796917244" FOLDED="true" ID="ID_1182384811" MODIFIED="1672796930646" TEXT="DisplayManager selber....">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1672796932502" ID="ID_503407567" MODIFIED="1672796982107" TEXT="Einrichtung des ZoomWindow prüfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1672796940850" ID="ID_1966474939" MODIFIED="1672796954415" TEXT="hierfür vom BodyCanvas eine effektive Weite in Pixel beziehen"/>
|
|
<node CREATED="1672796964890" ID="ID_1604594120" MODIFIED="1672796979603" TEXT="ggfs. die ZoomWindow::pxWidth() neu kalibrieren"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678381426918" ID="ID_382705289" MODIFIED="1672799760652" TEXT="Verbindung auf Implementierungs-Level: Layout ↔ Metrik">
|
|
<linktarget COLOR="#6bb1c5" DESTINATION="ID_382705289" ENDARROW="Default" ENDINCLINATION="782;41;" ID="Arrow_ID_1372440678" SOURCE="ID_1514900067" STARTARROW="None" STARTINCLINATION="441;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583010115679" FOLDED="true" ID="ID_181195318" MODIFIED="1583677222280" TEXT="alle Tracks">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1583010186970" ID="ID_1754142891" MODIFIED="1675384010783" TEXT="Ping-Pong auf DisplayFrame auslösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1583010212766" ID="ID_1377321766" MODIFIED="1675384095983" TEXT="Größe vom Header auslesen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583010223312" ID="ID_929067099" MODIFIED="1583677196768" STYLE="fork" TEXT="damit die Maximums-Berechnung auf dem Track-Inhalt auslösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1583606375028" FOLDED="true" ID="ID_1922972295" MODIFIED="1583677196768" TEXT="funktionales Max">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1583606385337" ID="ID_1117598680" MODIFIED="1583626259305" TEXT="Type-deduction-Probleme">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hängen garnicht direkt damit zusammen, sondern wurden getriggert durch den "unorthodoxen" Gebrauch des PtrDerefIter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583677168146" ID="ID_1666646505" MODIFIED="1583677177990" TEXT="in util-coll.hpp ausgelagert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583677604571" ID="ID_214009767" MODIFIED="1675384124121" TEXT="brauche (vorläufige) Rückmeldung vom Clip">
|
|
<arrowlink COLOR="#ab415e" DESTINATION="ID_811510338" ENDARROW="Default" ENDINCLINATION="-975;-81;" ID="Arrow_ID_610185006" STARTARROW="None" STARTINCLINATION="744;47;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1611486765168" ID="ID_62818590" MODIFIED="1675384130360" TEXT="Clip-Positionen und Ausdehnungen integrieren">
|
|
<linktarget COLOR="#786096" DESTINATION="ID_62818590" ENDARROW="Default" ENDINCLINATION="-1193;64;" ID="Arrow_ID_1779091384" SOURCE="ID_392294660" STARTARROW="None" STARTINCLINATION="817;64;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#435e98" CREATED="1617470705305" HGAP="40" ID="ID_644438911" MODIFIED="1674161854370" TEXT="Stand: vorläufige Implementierung" VSHIFT="6">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erst mal nur mit einem Button, und die Layout-Logik ehr "geschätzt" den präzise verstanden und umgesetzt. Immerhinn läuft der DisplayEvaluationPass nun, und auch die Buttons erscheinen an der Stelle, an der ich das erwarten würde...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1674161820779" ID="ID_1877059709" MODIFIED="1674161920084" TEXT="Stand: ElementBoxWidget als Clip, aber leer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ende 2022 habe ich dann doch noch das ElementBoxWidget gebaut. Nun verwenden Clips schon mal dieses, aber die ganze Logik der Clip-Anzeige <i>ist auf später verschoben...</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583010246034" ID="ID_113344286" MODIFIED="1675384031717" TEXT="Resultat mit Wert vom Header abgleichen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611527674130" ID="ID_1530876056" MODIFIED="1612030681158" TEXT="Ergebnis ≙ lokales Maximum → TrackBody::contentHeight_">
|
|
<linktarget COLOR="#3b4b73" DESTINATION="ID_1530876056" ENDARROW="Default" ENDINCLINATION="802;689;" ID="Arrow_ID_471691943" SOURCE="ID_1232626344" STARTARROW="None" STARTINCLINATION="700;24;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611533783838" ID="ID_504265049" MODIFIED="1611533798915" TEXT="Vorsicht: es sind zwei Belange">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611533829992" ID="ID_1527761356" MODIFIED="1611533848566" TEXT="der Content muß in den Content-Bereich im Track passen"/>
|
|
<node CREATED="1611533811939" ID="ID_254664541" MODIFIED="1611533828996" TEXT="Synchronisation zwischen Header und Body"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611533873746" ID="ID_1129757567" MODIFIED="1675384005462" TEXT="wo/wie werden die Sub-Tracks berücksichtigt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1612645297486" ID="ID_847170359" MODIFIED="1612646097627" TEXT="ergibt sich aus der Struktur des Display-Frame">
|
|
<arrowlink COLOR="#696fb6" DESTINATION="ID_535248075" ENDARROW="Default" ENDINCLINATION="696;-47;" ID="Arrow_ID_88289028" STARTARROW="None" STARTINCLINATION="-1205;73;"/>
|
|
</node>
|
|
<node CREATED="1612646163776" ID="ID_146112525" MODIFIED="1612646172800" TEXT="es muß auf zwei Ebenen passen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612646174439" ID="ID_275074702" MODIFIED="1612646188585" TEXT="Beginn und Ende eines Track (incl Kinder)"/>
|
|
<node CREATED="1612646196212" ID="ID_965864393" MODIFIED="1612646208439" TEXT="Beginn und Ende jedes einzelnen Sub-Tracks"/>
|
|
</node>
|
|
<node CREATED="1612646254925" ID="ID_910305950" MODIFIED="1612646291779">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Invariante gilt <i>auf einem</i> Fork
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1612646316870" ID="ID_91413726" MODIFIED="1612646544159" TEXT="Heads und Bodies are reasonably synced">
|
|
<arrowlink COLOR="#af5182" DESTINATION="ID_253184113" ENDARROW="Default" ENDINCLINATION="47;-31;" ID="Arrow_ID_116043165" STARTARROW="None" STARTINCLINATION="-838;0;"/>
|
|
</node>
|
|
<node CREATED="1612646343880" ID="ID_811479327" MODIFIED="1612646385206" TEXT="⟿ add same height to Head and Body compound"/>
|
|
<node CREATED="1612646393898" ID="ID_162830410" MODIFIED="1612646408248" TEXT="⟹ Invariant holds at begin of next compound"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583010270152" ID="ID_689332581" MODIFIED="1583606371280" TEXT="depth-first-Suche und Aktion auf dem Rückweg">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1583010287758" ID="ID_101138504" MODIFIED="1583010298353" TEXT="relative Reihenfolge der Sibling-Tracks ist egal">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583010359364" ID="ID_1532117771" MODIFIED="1583010378225" TEXT=""danach" auf jedem Canvas die Platz-Ermittlung auslösen"/>
|
|
<node CREATED="1583010386420" ID="ID_719664576" MODIFIED="1583010408429" TEXT="Gesamtresultat mit Ist-Zustand vergleichen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010590180" ID="ID_253184113" MODIFIED="1612742654585" TEXT="Header-Ausgleich">
|
|
<arrowlink COLOR="#8b71ae" DESTINATION="ID_1925515175" ENDARROW="Default" ENDINCLINATION="259;-76;" ID="Arrow_ID_44202222" STARTARROW="None" STARTINCLINATION="-426;50;"/>
|
|
<linktarget COLOR="#af5182" DESTINATION="ID_253184113" ENDARROW="Default" ENDINCLINATION="47;-31;" ID="Arrow_ID_116043165" SOURCE="ID_91413726" STARTARROW="None" STARTINCLINATION="-838;0;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1611534925644" ID="ID_1754764132" MODIFIED="1675384149246" TEXT="#1211 coordinate track extension">
|
|
<linktarget COLOR="#4b98e2" DESTINATION="ID_1754764132" ENDARROW="Default" ENDINCLINATION="-2912;207;" ID="Arrow_ID_468901844" SOURCE="ID_1506262956" STARTARROW="None" STARTINCLINATION="698;66;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1583677270535" FOLDED="true" ID="ID_1729172771" MODIFIED="1612714274794" TEXT="wann genau muß der Header-Ausgleich laufen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1583677300836" ID="ID_893081931" MODIFIED="1612712793203" TEXT="Plan-A">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1583677323867" ID="ID_1147387689" MODIFIED="1583677337542" TEXT="gekoppelt mit der lokalen Platz-Ermittlung"/>
|
|
<node CREATED="1583677426338" ID="ID_6669047" MODIFIED="1583677442862" TEXT="Problem: Rückwirkung der Canvas-Platz-Ermittlung"/>
|
|
<node CREATED="1583677385064" ID="ID_822192050" MODIFIED="1583677399994" TEXT="indirekte Hoffnung: die Rekursion wird das lösen">
|
|
<node CREATED="1583677461566" ID="ID_786603239" MODIFIED="1583677485360" TEXT="insofern diese auch die Größe des Canvas ändert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und damit eine Rekursion triggert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1583677498641" ID="ID_406797992" MODIFIED="1583677518462" TEXT="lokale Anpassungen könnten sich gegenseitig neutralisieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583677357807" ID="ID_685227170" MODIFIED="1583677579039" TEXT="Plan-B">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1583677365234" ID="ID_1695342185" MODIFIED="1612712806916" TEXT="separater zweiter Pass"/>
|
|
<node CREATED="1612712807625" ID="ID_1219345647" MODIFIED="1612712819659" TEXT="nachdem das Track-Profil konstruiert wurde"/>
|
|
<node CREATED="1612712830629" ID="ID_713212199" MODIFIED="1612712864077" TEXT="dieser 2.Pass ist ohnehin notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um die Widgets an die nun korrekte Position gemäß Track-Profil zu schieben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1612712922845" ID="ID_1653554586" MODIFIED="1612726635680" TEXT="Problem: wenn Body zu klein ist">
|
|
<arrowlink COLOR="#c6696c" DESTINATION="ID_1102509163" ENDARROW="Default" ENDINCLINATION="68;-71;" ID="Arrow_ID_215519404" STARTARROW="None" STARTINCLINATION="-26;78;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612712941815" ID="ID_1546276985" MODIFIED="1612712963120" TEXT="...wir merken das erst, nachddem das Profil konstruiert wurde"/>
|
|
<node CREATED="1612712987992" ID="ID_1461659027" MODIFIED="1612713002175" TEXT="...aber dann ist es nicht mehr möglich den Body zu vergrößern"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583010602619" ID="ID_245791707" MODIFIED="1583010640224" TEXT="Eingabe: neuer Soll-Zustand laut Body">
|
|
<node CREATED="1612714376084" ID="ID_1212522067" MODIFIED="1612714380543" TEXT="für die Content-Area"/>
|
|
<node CREATED="1612714380972" ID="ID_1481576243" MODIFIED="1612714393222" TEXT="für den gesamten sub-Fork"/>
|
|
</node>
|
|
<node CREATED="1612726548017" ID="ID_1808095522" MODIFIED="1612726561622" TEXT="jeden einzelnen Header besuchen und ggfs vergrößern"/>
|
|
<node COLOR="#7a3459" CREATED="1612726562591" ID="ID_37470143" MODIFIED="1612726582625" TEXT="kann Body nicht vergrößern">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612726584909" ID="ID_1102509163" MODIFIED="1612726635680" TEXT="weil zu dem Zeitpunkt das TrackProfile schon berechnet ist">
|
|
<linktarget COLOR="#c6696c" DESTINATION="ID_1102509163" ENDARROW="Default" ENDINCLINATION="68;-71;" ID="Arrow_ID_215519404" SOURCE="ID_1653554586" STARTARROW="None" STARTINCLINATION="-26;78;"/>
|
|
</node>
|
|
<node CREATED="1612726638878" ID="ID_350050993" MODIFIED="1612726655223" TEXT="vermute / hoffe, daß das die Ausnahme bleibt">
|
|
<node CREATED="1612726657796" ID="ID_474492345" MODIFIED="1612726672996" TEXT="und zwar, weil wir durchaus auf der Ebene einzelner Tracks einen Ausgleich machen"/>
|
|
<node CREATED="1612726674105" ID="ID_228252726" MODIFIED="1612726705766" TEXT="⟹ bei der Diskrepanz kann es sich nur um Dekorationen handeln"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1583009909800" FOLDED="true" ID="ID_968621649" MODIFIED="1583525572283" TEXT="ReSizeMediator">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1583009921904" ID="ID_562662536" MODIFIED="1583009932169" TEXT="Key-Schema entwerfen"/>
|
|
<node CREATED="1583009934307" ID="ID_1843559579" MODIFIED="1583009940268" TEXT="Registry"/>
|
|
<node CREATED="1583009941021" ID="ID_1229178947" MODIFIED="1583009948045" TEXT="Verteile / Callback-Mechanismus">
|
|
<node CREATED="1583009949267" ID="ID_44481088" MODIFIED="1583009956166" TEXT="wenige Verteiler-Hubs"/>
|
|
<node CREATED="1583009956826" ID="ID_619375937" MODIFIED="1583009961965" TEXT="auf WLink aufbauen"/>
|
|
</node>
|
|
<node CREATED="1583525577464" ID="ID_1528548638" MODIFIED="1583525638834" TEXT="so nicht sicher umsetzbar">
|
|
<arrowlink COLOR="#db337d" DESTINATION="ID_815242494" ENDARROW="Default" ENDINCLINATION="-814;0;" ID="Arrow_ID_1920099327" STARTARROW="None" STARTINCLINATION="812;88;"/>
|
|
</node>
|
|
<node CREATED="1583525607796" ID="ID_1583316557" MODIFIED="1583525625915" TEXT="stattdessen einfach direkt die Widgets manipulieren und gut is">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1583525671643" ID="ID_1346439197" MODIFIED="1583525685861" TEXT="geht anscheinend problemlos"/>
|
|
<node CREATED="1583525686596" ID="ID_99335407" MODIFIED="1583525695780" TEXT="weil das UI single-threaded ist"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010785331" HGAP="-170" ID="ID_156323884" MODIFIED="1583010913817" TEXT="Test" VSHIFT="2">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010796753" ID="ID_1055941815" MODIFIED="1583010929143" TEXT="Unit-Tests">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583010801657" ID="ID_794457070" MODIFIED="1675382549124" TEXT="empirischer Test (via TestControl)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010827293" ID="ID_879314444" MODIFIED="1583010925312" TEXT="formalen Integrations-Test etablieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010948547" ID="ID_111432509" MODIFIED="1583010952923" TEXT="Dokumentation">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010956272" ID="ID_54750547" MODIFIED="1583010970041" TEXT="TiddlyWiki">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583010961106" ID="ID_1086636096" MODIFIED="1583010975732" TEXT="Lumiera-Doku">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1583010976623" ID="ID_919049718" MODIFIED="1583010981866" TEXT="zumindest den Ort etablieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1565276594566" HGAP="-92" ID="ID_1897432572" MODIFIED="1679085444854" STYLE="fork" TEXT="Ergebnisse anwenden..." VSHIFT="-2">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1611787571317" ID="ID_1425309225" MODIFIED="1679085514014" TEXT="ablegen...">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276601866" ID="ID_1770751657" MODIFIED="1679085432286" TEXT="in den Clips">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1565276606260" ID="ID_123769598" MODIFIED="1675383961301" TEXT="in den Tracks">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1565276616439" ID="ID_1925515175" MODIFIED="1675383777147" TEXT="Head">
|
|
<linktarget COLOR="#8b71ae" DESTINATION="ID_1925515175" ENDARROW="Default" ENDINCLINATION="259;-76;" ID="Arrow_ID_44202222" SOURCE="ID_253184113" STARTARROW="None" STARTINCLINATION="-426;50;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1675383567911" ID="ID_1478249525" MODIFIED="1675383577920" TEXT="implementiert als vertikaler GTK-size-request"/>
|
|
<node COLOR="#435e98" CREATED="1675383579950" HGAP="26" ID="ID_1353501579" MODIFIED="1675383672047" TEXT="in drei Ausprägungen" VSHIFT="2">
|
|
<edge COLOR="#7779b5" STYLE="linear"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1675383598939" ID="ID_191492412" MODIFIED="1675383618101" TEXT="contentHeight: cell (1,1)"/>
|
|
<node CREATED="1675383598939" ID="ID_769571784" MODIFIED="1675383698919" TEXT="syncPadHeight: cell (1,2)"/>
|
|
<node CREATED="1675383598939" ID="ID_1533042981" MODIFIED="1675383739149" TEXT="enforceExtent: cell (0,1)"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1565276619446" ID="ID_67786660" MODIFIED="1679085432286" TEXT="Body">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1675383833237" ID="ID_63682372" MODIFIED="1675383839039" TEXT="TrackBody::contentHeight_"/>
|
|
<node CREATED="1675383853090" ID="ID_1092222582" MODIFIED="1675383860604" TEXT="wird direkt zum Zeichnen verwendet"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1675383862097" ID="ID_93556948" MODIFIED="1679085432286" TEXT="TODO: wächst derzeit monoton">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es sollte an geeigneter Stelle einen Reset geben, da jeder DisplayEvalutaionPass grundsätzlich das ganze Layout sauber ausrechnen kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565276627006" ID="ID_1705597393" MODIFIED="1565276630975" TEXT="im TrackProfile">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611787674741" ID="ID_1709866969" MODIFIED="1612742632732" TEXT="Canvas-Koordinaten nachführen">
|
|
<linktarget COLOR="#675b85" DESTINATION="ID_1709866969" ENDARROW="Default" ENDINCLINATION="684;566;" ID="Arrow_ID_541728210" SOURCE="ID_791476178" STARTARROW="None" STARTINCLINATION="-1876;104;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1611915466838" FOLDED="true" ID="ID_355225110" MODIFIED="1611915483757" TEXT="Problem: Storage der Koordinaten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611915485454" ID="ID_1653031142" MODIFIED="1611915494045" TEXT="welche Form?">
|
|
<node CREATED="1611915495602" ID="ID_269674665" MODIFIED="1611915511620" TEXT="logische Koordinaten">
|
|
<node CREATED="1611915529262" ID="ID_1718125401" MODIFIED="1611915542597" TEXT="entsprechen der »Position« im Modell"/>
|
|
<node CREATED="1611915545852" ID="ID_580313241" MODIFIED="1611915553582" TEXT="eine Zeit-Position"/>
|
|
<node CREATED="1611915554690" ID="ID_200419284" MODIFIED="1611915668706" TEXT="expliziter vertikaler Shift">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
noch nicht klar, welche Rolle der spielt; ich sehe ihn erst mal vor, weil er möglich ist. Denkbar wäre, daß er durch User-Interaktion entsteht, oder aber auch systematisch generiert wird, um bestimmte Arten von Clips optisch abzusetzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611915512327" ID="ID_1119494975" MODIFIED="1611915516836" TEXT="roh-Koordinaten">
|
|
<node CREATED="1611915682249" ID="ID_1895722911" MODIFIED="1611915699720" TEXT="Übersetzung der logischen Koordinaten in Anzeige-Metrik"/>
|
|
<node CREATED="1611915704190" ID="ID_428966516" MODIFIED="1611915721000" TEXT="Zoom und Aspekte des Anzeigestils sind schon eingearbeitet"/>
|
|
<node CREATED="1611915721903" ID="ID_96302431" MODIFIED="1611915734913" TEXT="aber die Koordinaten sind strikt lokal zum Track"/>
|
|
</node>
|
|
<node CREATED="1611915517783" ID="ID_1437430462" MODIFIED="1611915526002" TEXT="layout-Koordinaten">
|
|
<node CREATED="1611915737121" ID="ID_1515058204" MODIFIED="1611915746180" TEXT="Übersetzung in Canvas-Koordinaten"/>
|
|
<node CREATED="1611915747105" ID="ID_1840524131" MODIFIED="1611915754462" TEXT="muß stets erneut aufgebaut werden"/>
|
|
<node CREATED="1611915755463" ID="ID_167995629" MODIFIED="1611915766418" TEXT="berücksichtigt Umgebung und benachbarte Tracks"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611915782683" ID="ID_1829463115" MODIFIED="1611916029023" TEXT="Zielkonflikt">
|
|
<arrowlink COLOR="#e33b64" DESTINATION="ID_1488484275" ENDARROW="Default" ENDINCLINATION="-14;-84;" ID="Arrow_ID_1820616086" STARTARROW="None" STARTINCLINATION="-70;14;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611915794009" ID="ID_1622487643" MODIFIED="1611915845837" TEXT="duplizierte Daten sind zu vermeiden, da hier ein starker Hebel gegeben ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Clips dürften die häufigsten Entitäten in der Timeline-Anzeige werden. Es müssen tausende bis zehntausende Clips performant gehandhabt werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611915849754" ID="ID_409163867" MODIFIED="1611915977254" TEXT="Daten müssen auf dem Pfad der Kontrollstruktur greifbar sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Kontrollstruktur ist bereits gefährlich komplex; spezielle "Schleifen" durch die Innereien eigentlich nicht involvierter Entitäten allein aus Performance-Gründen sollten vermieden werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611915390832" FOLDED="true" ID="ID_1488484275" MODIFIED="1612742624778" TEXT="Clips müssen partizipieren">
|
|
<linktarget COLOR="#e33b64" DESTINATION="ID_1488484275" ENDARROW="Default" ENDINCLINATION="-14;-84;" ID="Arrow_ID_1820616086" SOURCE="ID_1829463115" STARTARROW="None" STARTINCLINATION="-70;14;"/>
|
|
<linktarget COLOR="#5c849c" DESTINATION="ID_1488484275" ENDARROW="Default" ENDINCLINATION="-838;79;" ID="Arrow_ID_1236233773" SOURCE="ID_1248959265" STARTARROW="None" STARTINCLINATION="612;56;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611916037617" ID="ID_1961599171" MODIFIED="1611916053240" TEXT="weil die Layout-Koordinaten erneut aufgebaut werden müssen"/>
|
|
<node CREATED="1611916054695" ID="ID_178492743" MODIFIED="1611916077488" TEXT="und nur die logischen Koordinaten gespeichert sein sollten, und zwar im Clip"/>
|
|
<node CREATED="1611921176093" ID="ID_1185756571" MODIFIED="1611921186371" TEXT="Entscheidung: Art der Einbindung">
|
|
<node CREATED="1611921187479" ID="ID_60740036" MODIFIED="1611921190890" TEXT="Alternativen">
|
|
<node CREATED="1611921192310" FOLDED="true" ID="ID_1840435951" MODIFIED="1611921604756" TEXT="Callback-Mechanismus vom CanvasHook">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1611921251215" ID="ID_897674349" MODIFIED="1611921285018" TEXT="das wäre dann ein generischer Mechanismus">
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1611921261541" ID="ID_1979211118" MODIFIED="1611921280278" TEXT="und ein weiterer generischer Mechanismus">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
<node CREATED="1611921337706" ID="ID_797338208" MODIFIED="1611921423971" TEXT="schlimmer noch: auf der falschen Ebene angesiedelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
denn eigentlich wäre das eine "interne Angelegenheit" von CanvasHook ↔ CanvasHooked
|
|
</li>
|
|
<li>
|
|
da aber die Koordinaten-Daten im Clip liegen, muß der Clip involviert werden
|
|
</li>
|
|
<li>
|
|
obwohl dies überhaupt nicht zu den Belangen des Clip gehört
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611921214699" ID="ID_1406560322" MODIFIED="1611921610785" TEXT="aktives re-Attachment der Clips durch ihren Manager">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1611921293072" ID="ID_1224338135" MODIFIED="1611921306495" TEXT="könnte per DisplayEvaluationPass erfolgen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611921493716" ID="ID_783533006" MODIFIED="1611921597467" TEXT="das läuft dann aber auf den 3.Pass hinaus">
|
|
<arrowlink COLOR="#f04b31" DESTINATION="ID_260365198" ENDARROW="Default" ENDINCLINATION="396;0;" ID="Arrow_ID_1446215014" STARTARROW="None" STARTINCLINATION="398;26;"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1611922870848" HGAP="39" ID="ID_755879883" MODIFIED="1611922978680" TEXT="naja...." VSHIFT="12">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ich hab ja nicht umsonst in der theoretischen Analyse herausgefunden, daß dieses Schema auf ein Phasen-Modell hinausläuft; die Hoffnung wäre höchstens gewesen, daß in der Praxis der 3.Pass derart <i>degeneriert,</i>  daß man ihn in den 1.Pass einfalten kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611921629593" ID="ID_596099565" MODIFIED="1611921648499" TEXT="es erfolgt also im 3.Pass">
|
|
<node CREATED="1611921650318" ID="ID_1512516246" MODIFIED="1611921658210" TEXT="und dieser ist damit doch unvermeidlich"/>
|
|
<node CREATED="1611921687575" ID="ID_1008400960" MODIFIED="1611921701733" TEXT="(kann dann aber auch den Header-Ausgleich mit erledigen)"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611925014039" FOLDED="true" ID="ID_1261732954" MODIFIED="1611959573577" TEXT="relink() der Clips implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611925026550" ID="ID_1629005155" MODIFIED="1611925046136" TEXT="Lösung: einfach mit den aktuellen logischen Koordinaten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611925047162" ID="ID_949058382" MODIFIED="1611959549842" TEXT="feststellen ob überhaupt ein angebundenes ClipDelegate gegeben ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611959550608" ID="ID_706043253" MODIFIED="1611959559211" TEXT="erledigt durch virtuelle Methode">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611925067536" ID="ID_1433993572" MODIFIED="1611959566203" TEXT="letztlich die CanvasHook::move()-Funktion nutzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611953633107" ID="ID_866053960" MODIFIED="1611959528314" TEXT="⟹ Thema speichern der Clip-Daten">
|
|
<arrowlink COLOR="#70365f" DESTINATION="ID_814561596" ENDARROW="Default" ENDINCLINATION="-427;-565;" ID="Arrow_ID_1226103397" STARTARROW="None" STARTINCLINATION="805;58;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611959606145" ID="ID_877670109" MODIFIED="1612030761702" TEXT="Problem: Clip (noch) nicht am rechten Fleck">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1611959630868" ID="ID_268739743" MODIFIED="1611959702682" TEXT="Clip erscheint am oberen Rand des Track">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
berücksichtigt also nicht die Dekoration und das Padding... obwohl doch eigentlich der 2.Pass das Track-Profil aufgebaut haben sollte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611959645562" ID="ID_4339474" MODIFIED="1611959664916" TEXT="aber explizit injizierte Buttons erscheinen an der richtigen Stelle"/>
|
|
<node COLOR="#338800" CREATED="1611959706282" FOLDED="true" ID="ID_568799045" MODIFIED="1612031128784" TEXT="Debugging...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612000363951" ID="ID_1611539170" MODIFIED="1612031120974" TEXT="Beobachtungen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1612000371364" ID="ID_36603158" MODIFIED="1612000392460">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Test-Diff ist <i>ungeschickt geschrieben</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1612000397098" ID="ID_1350143023" MODIFIED="1612000406123" TEXT="er sendet erst ein ins(Clip)"/>
|
|
<node CREATED="1612000406975" ID="ID_1469300848" MODIFIED="1612000417872" TEXT="und mutiert dannach die Timings von diesem Clip"/>
|
|
<node COLOR="#338800" CREATED="1612000432043" ID="ID_174378469" MODIFIED="1612000442318" TEXT="aber das wird alles korrekt gehandhabt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612026280255" ID="ID_1932586467" MODIFIED="1612026308920" TEXT="Trotzdem: senden wie vorgesehen, sofort mit Timings">
|
|
<linktarget COLOR="#5cb39f" DESTINATION="ID_1932586467" ENDARROW="Default" ENDINCLINATION="-194;262;" ID="Arrow_ID_1566553463" SOURCE="ID_99599203" STARTARROW="None" STARTINCLINATION="435;33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612000444241" ID="ID_1290239156" MODIFIED="1612000568427" TEXT="TimeSpan und optional<TimeSpan> werden x-fach kopiert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612000475795" ID="ID_1550787880" MODIFIED="1612000489077" TEXT="da per Value-Argument">
|
|
<node CREATED="1612000496775" ID="ID_177231276" MODIFIED="1612000505843" TEXT="im ClipPresenter-ctor"/>
|
|
<node CREATED="1612000490724" ID="ID_1501412770" MODIFIED="1612000496039" TEXT="in der Getter-Funktion"/>
|
|
<node CREATED="1612000510489" ID="ID_1095678322" MODIFIED="1612000520712" TEXT="in allen Settern / Mutatoren"/>
|
|
</node>
|
|
<node CREATED="1612000529308" ID="ID_874373043" MODIFIED="1612000550279" TEXT="zumindest am Übergang zum ClipDelegate kann das der Optimizer nicht knacken">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612000552676" ID="ID_103077891" MODIFIED="1612024898535" TEXT="TODO: in Referenzen umschreiben">
|
|
<linktarget COLOR="#20a47e" DESTINATION="ID_103077891" ENDARROW="Default" ENDINCLINATION="-16;56;" ID="Arrow_ID_55769950" SOURCE="ID_1194581288" STARTARROW="None" STARTINCLINATION="304;18;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612000682337" ID="ID_1950742827" MODIFIED="1612022042102" TEXT="Widget wird vom Ctor zweimal hintereinander an den Canvas geheftet">
|
|
<arrowlink COLOR="#c16b96" DESTINATION="ID_1693567978" ENDARROW="Default" ENDINCLINATION="223;491;" ID="Arrow_ID_624678696" STARTARROW="None" STARTINCLINATION="1328;54;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1612000718837" ID="ID_1844571428" MODIFIED="1612000743430" TEXT="Design von CanvasHook fragwürdig">
|
|
<node CREATED="1612000744873" ID="ID_1198437143" MODIFIED="1612000756012" TEXT="modelliert als "spezieller ViewHook""/>
|
|
<node CREATED="1612000757240" ID="ID_828923416" MODIFIED="1612000775058" TEXT="das führt zu einem stellenweise umgebogenen API"/>
|
|
<node CREATED="1612000776126" ID="ID_64509148" MODIFIED="1612000794345" TEXT="und zu verketteten "magischen" ctors">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612000906004" ID="ID_89016969" MODIFIED="1612008915157" TEXT="wird jemals ein CanvasHook als ViewHook gebraucht?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1612008916353" ID="ID_1376139143" MODIFIED="1612008920019" TEXT="Nein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1612008922562" ID="ID_458884534" MODIFIED="1612009068409" TEXT="nur ein historisches Überbleibsel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich wollte mal ein viel generischeres Design schaffen, das sogar eine Art Grundgerüst für das Zusammenbauen des GUI sein könnte. In der vertieften Analyse wurde dann aber klar, daß dieses Design nicht so ohne Weiteres realisierbar ist. Daraufhin habe ich beschlossen, die Idee aufzugeben und stattdessen auf Einzelfälle zu spezialisieren. Und in einem weiteren Schritt habe ich dann die Themen "Grid" und "Canvas" voneinander getrennt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612000823535" ID="ID_602205033" MODIFIED="1612000891040" TEXT="Frage: bloß ungeschickt, oder sogar falsch?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1612000862978" ID="ID_292607955" MODIFIED="1612000878500" TEXT="klären: wie geht Gtk::Layout damit um?"/>
|
|
<node CREATED="1612001686428" ID="ID_1708452319" MODIFIED="1612001730290" TEXT="→ gtk_layout_put() in gtklayout.c, line 462"/>
|
|
<node CREATED="1612001824933" ID="ID_1012337567" MODIFIED="1612001854632" TEXT="konstruiert neuen Entry und fügt ihn an interne Liste an">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...and "realizes" the widget
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#bf335c" CREATED="1612001856494" ID="ID_896331202" MODIFIED="1612001914846" TEXT="Ergebnis: es ist ein Defekt">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612019580954" ID="ID_940366698" MODIFIED="1612022026663" TEXT="mit den Korrekturen wird die Position nun korrekt gesetzt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612023445690" ID="ID_404822600" MODIFIED="1612024837285" TEXT="Regression: die komplexe Timeline zeichnet nicht mehr richtig">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612023464364" ID="ID_1135923056" MODIFIED="1612023511217" TEXT="Eingeführt durch Changeset 5b336054">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
commit 5b33605469352f3403d44cb0d77ef3c224895f5b (HEAD, ichthyo/gui)
|
|
</p>
|
|
<p>
|
|
Author: Ichthyostega <prg@ichthyostega.de>
|
|
</p>
|
|
<p>
|
|
Date:   Mon Jan 25 03:06:27 2021 +0100
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
    Clip: fill in minimal implementation to make the clip appear
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1612024513406" ID="ID_1145874251" MODIFIED="1612024615254" TEXT="Aua!">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1612024549519" ID="ID_445021769" MODIFIED="1612024626079" TEXT="meine subergeni(t)ale max()-Funktion!!!!">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1612024571430" ID="ID_755468027" MODIFIED="1612024603966" TEXT="liefert -∞ wenn die Quellsequenz leer ist"/>
|
|
<node CREATED="1612024557000" ID="ID_1759594738" MODIFIED="1612024569834" TEXT="in DisplayFrame::establishExtension()"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612024633318" ID="ID_1173144029" MODIFIED="1612024661776" TEXT="Lösung: unit statt int zurückgeben">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1612024666745" ID="ID_1549387212" MODIFIED="1612024677267" TEXT="ist das jetzt "unter den Teppich"....?"/>
|
|
<node CREATED="1612024678071" ID="ID_714221228" MODIFIED="1612024832503" TEXT="ja und nein. Es ist sogar korrekt so">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aber der Punkt ist, nach der reinen Lehre sollte eine solche Funktion eine Options-Monade zurückgeben. Aber ich wollte stattdessen den guten alten Fallback-Wert. Wenn man <i>das </i>erst mal akzeptiert, dann muß "man" verdammt noch einmal auch die Wertebereiche ernst nehmen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612001961759" ID="ID_279893834" MODIFIED="1612025196962" TEXT="Probleme und Defekte beheben">
|
|
<arrowlink COLOR="#767b93" DESTINATION="ID_1752337691" ENDARROW="Default" ENDINCLINATION="-53;-147;" ID="Arrow_ID_569461745" STARTARROW="None" STARTINCLINATION="-103;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1612009188967" ID="ID_734571483" MODIFIED="1612009201239" TEXT="ViewHook und CanvasHook komplett getrennt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612024842825" ID="ID_920380509" MODIFIED="1612024857000" TEXT="Regrsssion in der DisplayEvaluation behoben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612024858159" ID="ID_1194581288" MODIFIED="1612024903951" TEXT="Timings und optional<Timings> als Referenz">
|
|
<arrowlink COLOR="#20a47e" DESTINATION="ID_103077891" ENDARROW="Default" ENDINCLINATION="-16;56;" ID="Arrow_ID_55769950" STARTARROW="None" STARTINCLINATION="304;18;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612026260569" ID="ID_99599203" MODIFIED="1612026319040" TEXT="Diff im kanonischen Format senden">
|
|
<arrowlink COLOR="#5cb39f" DESTINATION="ID_1932586467" ENDARROW="Default" ENDINCLINATION="-194;262;" ID="Arrow_ID_1566553463" STARTARROW="None" STARTINCLINATION="435;33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612019599970" ID="ID_1752337691" MODIFIED="1612019623795" TEXT="Clip bewegt sich aber erst beim nächsten Redraw">
|
|
<arrowlink COLOR="#62466a" DESTINATION="ID_1512224220" ENDARROW="Default" ENDINCLINATION="-74;-72;" ID="Arrow_ID_716623900" STARTARROW="None" STARTINCLINATION="48;96;"/>
|
|
<linktarget COLOR="#767b93" DESTINATION="ID_1752337691" ENDARROW="Default" ENDINCLINATION="-53;-147;" ID="Arrow_ID_569461745" SOURCE="ID_279893834" STARTARROW="None" STARTINCLINATION="-103;9;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1612019625163" ID="ID_191145933" MODIFIED="1612019777333" TEXT="liegt vmtl. darin, daß wir uns grade in einem Draw()-Callback befinden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beim ersten Mal wird "nebenbei" festgestellt, daß das Track-Profil (noch)nicht existiert.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1612019648505" ID="ID_1699675594" MODIFIED="1612019656044" TEXT="ist erst mal nur ein Schönheitsfehler">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1612019794709" ID="ID_921471388" MODIFIED="1612019884371" TEXT="könnte sich aber zu einem wirklichen Problem auswachsen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn selbst wenn wir das für das erste Mal irgendwie hinbiegen, so kann das doch in jedem späteren draw() wieder passieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1612019894343" ID="ID_1448053043" MODIFIED="1612019901396" TEXT="mögliche Workarounds...">
|
|
<node CREATED="1612019903134" ID="ID_1689432083" MODIFIED="1612020045315" TEXT="die DisplayEvaluation schon per Diff-Listener auslösen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dafür bräuchte ich aber einen Diff-Listener für alle strukturellen Änderungen incl sub-Scope. Das ist nicht trivial zu implementieren, weil die sub-Scopes ja beliebig tief verschachtelt sein können, und alle rekursiv delegiert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612020078974" ID="ID_25005774" MODIFIED="1612020100183" TEXT="den Canvas grundsätzlich nach der DisplayEvaluation nochmal invalidieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1612025039375" ID="ID_826424244" MODIFIED="1612025048929" TEXT="versucht">
|
|
<node CREATED="1612025050103" ID="ID_1320349894" MODIFIED="1612025062527" TEXT="sowohl mit dem ganzen TimelineBodyWidget"/>
|
|
<node CREATED="1612025062956" ID="ID_1000543035" MODIFIED="1612025073590" TEXT="alsauch nur mit den beiden Canvas-Widgets"/>
|
|
</node>
|
|
<node CREATED="1612025074794" ID="ID_800250683" MODIFIED="1612025088412" TEXT="zeigt keinerlei Reaktion">
|
|
<linktarget COLOR="#843f65" DESTINATION="ID_800250683" ENDARROW="Default" ENDINCLINATION="-296;33;" ID="Arrow_ID_1331047801" SOURCE="ID_445256100" STARTARROW="None" STARTINCLINATION="797;63;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1612025095479" ID="ID_1775295616" MODIFIED="1612025105906" TEXT="der Clip bleibt wo er ist (am falschen Ort)"/>
|
|
<node CREATED="1612025106830" ID="ID_1695696156" MODIFIED="1612025160707" TEXT="auch die anderen Layout-Anpassungen erfolgen erst beim nächsten Trigger">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also z.B: wenn man das TestControl schließt, oder auch nur den Fokus an das Lumiera-Hauptfenster gibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612030849154" ID="ID_242090895" MODIFIED="1612030858673" TEXT="verbleibende Probleme">
|
|
<icon BUILTIN="bell"/>
|
|
<node COLOR="#338800" CREATED="1612726745183" FOLDED="true" ID="ID_1213054592" MODIFIED="1679086226807" TEXT="Header-Ausglieich funktioniert (noch) nicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612742259238" ID="ID_607718286" MODIFIED="1612742418037" TEXT="wichtig: die desired_height verwenden (→size-request)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nachdem erstmals ein size-request gesetzt wurde, hat sich die tatsächliche Höhe des Widget noch nicht verändert (das wird erst mit dem nachfolgenden resize-event vollzogen). Aber der size-request spiegelt sich sofort in der desired_height wieder. Wir müssen also die Ermittlung der "aktuellen" Höhe <i>darauf</i> aufbauen, damit die schon vorgenommenen Anpassungen nicht nochmal im Delta landen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1612742186077" ID="ID_1081995188" MODIFIED="1612742421843" TEXT="Weiterer Fehler war die Auswertungs-Reihenfolge">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1612742199694" ID="ID_354715180" MODIFIED="1612742247324" TEXT="der 2.Pass muß rückwärts aufsteigen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damit die Höhen für die Kind-Tracks bereits gesetzt sind, wenn die Gesamthöhe des Parent-Track betrachtet wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612742429043" FOLDED="true" ID="ID_1739285791" MODIFIED="1674603322918" TEXT="die scroll-Höhe / Canvas-Höhe stimmt nicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612742467558" ID="ID_929888474" MODIFIED="1612742484264" TEXT="und zwar fehlt genau die zusätzliche Höhe der schließenden Slope"/>
|
|
<node CREATED="1612742484972" ID="ID_1291566735" MODIFIED="1612742498974" TEXT="nachdem man aber das Fenster einmal resized hat, stimmt es wieder"/>
|
|
<node CREATED="1674603256346" ID="ID_1331516814" MODIFIED="1674603318681" TEXT="Problem behoben: für das ZoomWindow eine exakte Layout-Berechnung implementiert">
|
|
<arrowlink DESTINATION="ID_328296925" ENDARROW="Default" ENDINCLINATION="116;0;" ID="Arrow_ID_819469158" STARTARROW="None" STARTINCLINATION="116;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1612742527238" FOLDED="true" ID="ID_1543056669" MODIFIED="1674603224715" TEXT="die Header-Starts rutschen minimal nach oben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1612742538724" ID="ID_1839437599" MODIFIED="1612742544871" TEXT="ein off-by-one?"/>
|
|
<node CREATED="1612742545690" ID="ID_1735908408" MODIFIED="1612742563442" TEXT="sieht so aus, als würden uns pro Zeile nur wenige Pixel fehlen"/>
|
|
<node CREATED="1612742574675" ID="ID_20715943" MODIFIED="1612742616893" TEXT="d.h. der TrackBody ist minimal Größer, als die Höhe, die wir als Delta anwenden"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1674603031791" ID="ID_328296925" LINK="#ID_1742313131" MODIFIED="1674603318681" TEXT="Nein: da war die Layout-Implementierung noch ziemlich „daneben“">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was bisher nur nicht aufgefallen war, weil die Display-Evaluation nur einmal lief;<br />Nachdem ich das ZoomWindow integriert hatte, zeigten sich diverse Defekte / run-away-Effekte, die erst beoben waren, nachdem ich die Layout-Berechnung im TrackHeadWidget komplett überarbeitet und systematisch ausgestaltet hatte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_328296925" ENDARROW="Default" ENDINCLINATION="116;0;" ID="Arrow_ID_819469158" SOURCE="ID_1331516814" STARTARROW="None" STARTINCLINATION="116;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612030881439" ID="ID_306268306" MODIFIED="1612030903673" TEXT="nach dem DisplayEvaluationPass: Zustand nicht vollständig realisiert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612030907643" ID="ID_607409982" MODIFIED="1612030927924" TEXT="obwohl aller Anzeigezustand korrekt gesetzt wurde"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612030928723" ID="ID_352360314" MODIFIED="1612031057189" TEXT="erst der nächste draw()-Zyklus">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1612030941302" ID="ID_1512224220" MODIFIED="1612031041398" TEXT="reralisieriert die zuletzt gesetzte Canvas-Postion der Clip-Widgets">
|
|
<linktarget COLOR="#62466a" DESTINATION="ID_1512224220" ENDARROW="Default" ENDINCLINATION="-74;-72;" ID="Arrow_ID_716623900" SOURCE="ID_1752337691" STARTARROW="None" STARTINCLINATION="48;96;"/>
|
|
</node>
|
|
<node CREATED="1612030955781" ID="ID_1382137559" MODIFIED="1612030970994" TEXT="realisiert die angepaßte Canvas-Größe"/>
|
|
<node CREATED="1612030974354" ID="ID_602452868" MODIFIED="1612030981278" TEXT="realisiert den Scroll-Overflow"/>
|
|
</node>
|
|
<node CREATED="1612031066295" ID="ID_445256100" MODIFIED="1612031108057" TEXT="Invalidieren des Widget hilft nicht">
|
|
<arrowlink COLOR="#843f65" DESTINATION="ID_800250683" ENDARROW="Default" ENDINCLINATION="-296;33;" ID="Arrow_ID_1331047801" STARTARROW="None" STARTINCLINATION="797;63;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1674603379625" ID="ID_22375243" MODIFIED="1674603406628">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Clip-Drag reagiert manchmal nicht <i>»live«</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1674606870062" ID="ID_1744725566" MODIFIED="1674606880174" TEXT="#1267 sometimes failure to re-draw">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1674603515247" ID="ID_145015079" MODIFIED="1674603519913" TEXT="Beobachtung...">
|
|
<node CREATED="1674603521102" ID="ID_1576327891" MODIFIED="1674603531711" TEXT="Track-Pane-Splitter nach rechts bewegen"/>
|
|
<node CREATED="1674603535772" ID="ID_1899820582" MODIFIED="1674603556532" TEXT="manchmal erfolgt dann kein Update / re-Draw beim Dragging"/>
|
|
<node CREATED="1674603557497" ID="ID_1941260000" MODIFIED="1674603679778" TEXT="die Position wird aber korrekt berechnet und gesetzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nachweislich...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die (x,y)-Koordinaten des Clip werden sinnvoll und korrekt aktualisiert
|
|
</li>
|
|
<li>
|
|
der Aufruf geht durch bis auf das Gtk::Layout
|
|
</li>
|
|
<li>
|
|
nach einer Invalidierung des ganzen Fensters springt der Clip plötzlich an die neue Position
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1674603568776" ID="ID_1618676622" MODIFIED="1674603583681" TEXT="nach einem focus-loss / focus-gain funktioniert's wieder"/>
|
|
<node CREATED="1674603584654" ID="ID_585485863" MODIFIED="1674603597876" TEXT="auch nach einem Verschieben des Pane-Splitters nach links"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#c7346a" CREATED="1674603681741" ID="ID_900437621" MODIFIED="1674603716830" TEXT="konnte kein Merkmal identifizieren, an dem sich das Fehlverhalten festmachen läßt">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561047296781" ID="ID_1660005887" MODIFIED="1575053313157" TEXT="Neuberechnung / Reihenfolge">
|
|
<linktarget COLOR="#d6677c" DESTINATION="ID_1660005887" ENDARROW="Default" ENDINCLINATION="130;-668;" ID="Arrow_ID_1942101483" SOURCE="ID_162610711" STARTARROW="None" STARTINCLINATION="730;24;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1561047320822" ID="ID_652813348" MODIFIED="1561047325927" TEXT="Grundsätzliches">
|
|
<node CREATED="1561047326773" ID="ID_455856045" MODIFIED="1561047353557" TEXT="wie wird die Reihenfolge der Tracks festgelegt?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561047338983" ID="ID_608382986" MODIFIED="1563466559242" TEXT="wie werden Änderungen dieser realisiert?">
|
|
<linktarget COLOR="#b05d76" DESTINATION="ID_608382986" ENDARROW="Default" ENDINCLINATION="-409;0;" ID="Arrow_ID_114040217" SOURCE="ID_1798080753" STARTARROW="None" STARTINCLINATION="215;14;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1561048744043" ID="ID_1401239177" MODIFIED="1561140347286" TEXT="Konzept klären">
|
|
<linktarget COLOR="#b13064" DESTINATION="ID_1401239177" ENDARROW="Default" ENDINCLINATION="363;61;" ID="Arrow_ID_807164253" SOURCE="ID_1143074852" STARTARROW="None" STARTINCLINATION="1263;0;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561048792468" ID="ID_638394722" MODIFIED="1561048797689" TEXT="#1199 handle Timeline layout changes">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1573411517071" ID="ID_1735372634" MODIFIED="1573411532925" TEXT="Lösungsidee: neu bauen statt umbauen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563466591056" FOLDED="true" ID="ID_1728979524" MODIFIED="1573411731540" TEXT="re-Konstruktion der Struktur">
|
|
<linktarget COLOR="#774779" DESTINATION="ID_1728979524" ENDARROW="Default" ENDINCLINATION="-1429;-736;" ID="Arrow_ID_1394313218" SOURCE="ID_240517447" STARTARROW="None" STARTINCLINATION="-692;36;"/>
|
|
<linktarget COLOR="#927aa8" DESTINATION="ID_1728979524" ENDARROW="Default" ENDINCLINATION="-421;17;" ID="Arrow_ID_445844094" SOURCE="ID_737072989" STARTARROW="None" STARTINCLINATION="398;25;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1563466616693" ID="ID_316217409" MODIFIED="1563466626054" TEXT="vom root-DisplayFrame ausgehend..."/>
|
|
<node CREATED="1563466626931" ID="ID_1475248081" MODIFIED="1563466639074" TEXT="top-down neu aufbauen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1563467297369" ID="ID_283854399" MODIFIED="1573411760423" TEXT="spezielles Problem: verschachtelte DisplayFrame-Struktur">
|
|
<arrowlink COLOR="#d73f41" DESTINATION="ID_1414960950" ENDARROW="Default" ENDINCLINATION="699;-94;" ID="Arrow_ID_1514395934" STARTARROW="None" STARTINCLINATION="236;12;"/>
|
|
</node>
|
|
<node CREATED="1575052534983" ID="ID_642649820" MODIFIED="1575052546569" TEXT="Verallgemeinerung: verschachtelte sub-Collections"/>
|
|
<node CREATED="1575052815130" ID="ID_216264810" MODIFIED="1575053021221" TEXT="Prinzip">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1575052820289" ID="ID_1240730647" MODIFIED="1575052843042" TEXT="Trigger »Struktur-Änderung«"/>
|
|
<node CREATED="1575052859764" ID="ID_1345880697" MODIFIED="1575052895211" TEXT="Löschungen/Hinzufügungen sind schon durchgeführt -- aber noch nicht "realisiert""/>
|
|
<node CREATED="1575052900360" ID="ID_447463518" MODIFIED="1575052923936" TEXT="Sortier-Ordnung für die Sub-Struktur bereitstellen"/>
|
|
<node CREATED="1575052925155" ID="ID_1405182366" MODIFIED="1575052948612" TEXT="Sub-Struktur atomar auseinandernehmen und neu aufbauen"/>
|
|
<node CREATED="1575052952855" ID="ID_1489113924" MODIFIED="1575053002685" TEXT="Umordnen der Teilbäume als Ganzes ist erforderlich"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561047369284" ID="ID_488158262" MODIFIED="1561047377394" TEXT="Implementierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563019548130" ID="ID_1803180287" MODIFIED="1679086313073" TEXT="Aufgabe: systematischen CSS-Pfad erzeugen">
|
|
<arrowlink COLOR="#419bcf" DESTINATION="ID_83481977" ENDARROW="Default" ENDINCLINATION="666;0;" ID="Arrow_ID_1386111155" STARTARROW="None" STARTINCLINATION="-787;0;"/>
|
|
<arrowlink COLOR="#8b7ea0" DESTINATION="ID_561705172" ENDARROW="Default" ENDINCLINATION="-2256;70;" ID="Arrow_ID_57895594" STARTARROW="None" STARTINCLINATION="465;29;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563021472845" ID="ID_63684521" MODIFIED="1563021488846" TEXT="braucht konkreten Gtk::WidgetPath als Anker">
|
|
<node CREATED="1563021490328" ID="ID_1982999427" MODIFIED="1563021498980" TEXT="vom BodyCanvasWidget"/>
|
|
<node CREATED="1563021499977" ID="ID_125420561" MODIFIED="1563021519170" TEXT="...im TimelineWidget > TimelineLayout"/>
|
|
</node>
|
|
<node CREATED="1563021522198" HGAP="84" ID="ID_349220035" MODIFIED="1563021584919" TEXT="ergänzt um virtuelle Knoten" VSHIFT="-9">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1563020900138" ID="ID_1653425334" MODIFIED="1575052603899" TEXT="implementiert im UiManger / UiStyle">
|
|
<arrowlink COLOR="#3976e4" DESTINATION="ID_517868337" ENDARROW="Default" ENDINCLINATION="-1204;103;" ID="Arrow_ID_1481718697" STARTARROW="None" STARTINCLINATION="928;72;"/>
|
|
</node>
|
|
<node CREATED="1563021556105" ID="ID_629948451" MODIFIED="1563021569720" TEXT="publiziert via Avice "style(trackBody)""/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" FOLDED="true" ID="ID_1306244096" MODIFIED="1679361598685" TEXT="Track-Presenter">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_1306244096" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_951723874" SOURCE="ID_1570849604" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1480741594101" ID="ID_1017414696" MODIFIED="1557498707226" TEXT="mit doppeltem Display-Kontext verbinden"/>
|
|
<node CREATED="1480741545196" ID="ID_1657879480" MODIFIED="1557498707226" TEXT="TrackWidget">
|
|
<node CREATED="1480741552611" ID="ID_1987203186" MODIFIED="1557498707226" TEXT="erzeugen"/>
|
|
<node COLOR="#435e98" CREATED="1480741555930" ID="ID_1869427213" MODIFIED="1678406865763">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie in Kopf <i>und</i> Rumpf injizieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#436cbd" DESTINATION="ID_600150628" ENDARROW="Default" ENDINCLINATION="-340;35;" ID="Arrow_ID_1431681301" STARTARROW="None" STARTINCLINATION="2;30;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1540259854597" ID="ID_330440597" MODIFIED="1557498707226" TEXT="Invariante gesucht">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1540259882177" ID="ID_269340322" MODIFIED="1557498707226" TEXT="TrackPresenter braucht....">
|
|
<node CREATED="1540259899289" ID="ID_1550133488" MODIFIED="1557498707226" TEXT="einen Head-Slave"/>
|
|
<node CREATED="1540259905062" ID="ID_1804783123" MODIFIED="1557498707226" TEXT="einen Body-Slave"/>
|
|
</node>
|
|
<node CREATED="1540260041187" ID="ID_686871621" MODIFIED="1557498707226" TEXT="Grundstruktur?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1540260073971" ID="ID_564056863" MODIFIED="1557498707226" TEXT="TrackPresenter hat DisplayFrame"/>
|
|
<node CREATED="1540260094236" ID="ID_439265924" MODIFIED="1557498707226" TEXT="DisplayFrame kann Sub-DisplayFrame erzeugen"/>
|
|
<node CREATED="1540260106675" ID="ID_432321502" MODIFIED="1557498707226" TEXT="aus sub-Frame kann man sub-TrackPresenter bauen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563466520522" ID="ID_1798080753" MODIFIED="1563466559242" TEXT="Struktur-Änderungen sind problematisch">
|
|
<arrowlink COLOR="#b05d76" DESTINATION="ID_608382986" ENDARROW="Default" ENDINCLINATION="-409;0;" ID="Arrow_ID_114040217" STARTARROW="None" STARTINCLINATION="215;14;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540346398887" ID="ID_1953592630" MODIFIED="1573929021565" TEXT="DisplayFrame">
|
|
<linktarget COLOR="#2769d6" DESTINATION="ID_1953592630" ENDARROW="Default" ENDINCLINATION="-300;1096;" ID="Arrow_ID_928857904" SOURCE="ID_1389602122" STARTARROW="None" STARTINCLINATION="-1987;53;"/>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1540346412629" ID="ID_1434445651" MODIFIED="1557498707226">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
abstrahiert den Zugang zum <i>zugehörigen Widget</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540346455423" ID="ID_535248075" MODIFIED="1557498707226" TEXT="schafft die invariante Struktur im Verhältnis zu den Kindern">
|
|
<linktarget COLOR="#696fb6" DESTINATION="ID_535248075" ENDARROW="Default" ENDINCLINATION="696;-47;" ID="Arrow_ID_88289028" SOURCE="ID_847170359" STARTARROW="None" STARTINCLINATION="-1205;73;"/>
|
|
<node CREATED="1612645714351" ID="ID_504975313" MODIFIED="1612645720472" TEXT="Display-Frame verklammert">
|
|
<node CREATED="1612645738946" ID="ID_1516329442" MODIFIED="1612645749156" TEXT="einen Track-Head incl nested sub-Heads"/>
|
|
<node CREATED="1612645752193" ID="ID_863983538" MODIFIED="1612645762738" TEXT="einen Track-Body incl nested sub-Tracks"/>
|
|
</node>
|
|
<node CREATED="1612645786635" ID="ID_600150628" MODIFIED="1612645961414" TEXT="Kind-Display-Frame injiziert">
|
|
<linktarget COLOR="#436cbd" DESTINATION="ID_600150628" ENDARROW="Default" ENDINCLINATION="-340;35;" ID="Arrow_ID_1431681301" SOURCE="ID_1869427213" STARTARROW="None" STARTINCLINATION="2;30;"/>
|
|
<node CREATED="1612645828669" ID="ID_117377953" MODIFIED="1612645878450" TEXT="neuen sub-Track-Head am Ende der verschachtelten Liste"/>
|
|
<node CREATED="1612645847854" ID="ID_661575710" MODIFIED="1612645874284" TEXT="neuen sub-Track-Body an die Kinder des Track-Body eingehängt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540505441706" HGAP="28" ID="ID_1492670388" MODIFIED="1563466899646" TEXT="Lebenszyklus" VSHIFT="20">
|
|
<linktarget COLOR="#ac8396" DESTINATION="ID_1492670388" ENDARROW="Default" ENDINCLINATION="-473;37;" ID="Arrow_ID_1838431568" SOURCE="ID_1349567495" STARTARROW="None" STARTINCLINATION="-428;36;"/>
|
|
<node CREATED="1540505464975" ID="ID_195276443" MODIFIED="1557498707226" TEXT="DisplayFrame (als Member) an TrackPresenter gebunden"/>
|
|
<node CREATED="1540505481022" ID="ID_1566437478" MODIFIED="1557498707226" TEXT="konkrete Widgets leben im DisplayFrame"/>
|
|
<node CREATED="1540506987900" ID="ID_1173067540" MODIFIED="1557498707226">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sub-Frame wird für <i>unsere</i> Kinder erzeugt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540507009225" ID="ID_104172694" MODIFIED="1557498707227" TEXT="Kinder werden vor Members zerstört"/>
|
|
<node CREATED="1540507040165" ID="ID_1123333647" MODIFIED="1557498707227">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Fazit</u>: DisplayFrame kann sich auf Parent verlassen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1540511179218" ID="ID_1592328868" MODIFIED="1678406429761" TEXT="Problem: Ankerpunkt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1540511250489" ID="ID_49278916" MODIFIED="1540511273407" TEXT="wie hängt man die ganze Struktur auf?"/>
|
|
<node CREATED="1584888287304" FOLDED="true" ID="ID_81420296" MODIFIED="1584888307013" TEXT="in Konstruktions-Reihenfolge verwoben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1540511274366" ID="ID_1134388060" MODIFIED="1540511281241" TEXT="Lösungsansätze">
|
|
<node CREATED="1540511304602" ID="ID_814037364" MODIFIED="1576282358074" TEXT="halb konstruierter Frame ohne Widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die Parent/Anker-Widgets werden auf ein Interface reduziert, z.B. Gtk::Container
|
|
</li>
|
|
<li>
|
|
man reicht einen halbfertigen Frame rein, in dem bereits die Anker-Widgets gesetzt sind
|
|
</li>
|
|
<li>
|
|
dann ruft man eine Konstruktor-Funktion auf, die die eigentlichen Widgets erstellt und verdrahtet
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1540511389686" ID="ID_1017315025" MODIFIED="1576282358074" TEXT="Anker-Widgets explizit übergeben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die Anker-Widgets kommen per Ref auf Interface
|
|
</li>
|
|
<li>
|
|
sie werden explizit an den ctor des Controllers übergeben
|
|
</li>
|
|
<li>
|
|
dieser verwendet die Referenzen, um in einem Streich den DisplayFrame incl. eigentlicher Widgets zu erzeugen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1540511282493" ID="ID_1902168929" MODIFIED="1576282358073" TEXT="Parent-Frame hat virtuelle Methoden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
der ctor des Controllers bekommt eine Ref. auf den Parent-Frame
|
|
</li>
|
|
<li>
|
|
dieser bietet eine virtuelle Methode, mit der sich die Widgets installieren lassen
|
|
</li>
|
|
<li>
|
|
wenn der Controller den DisplayFrame erzeugt, werden dort unmittelbar die Widgets konstruiert
|
|
</li>
|
|
<li>
|
|
sodann rufen wir die builder-Funktion auf, um sie im Parent-Kontext zu verankern
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1540511879965" ID="ID_1507237353" MODIFIED="1540511884826" TEXT="Varianten denkbar">
|
|
<node CREATED="1540511887116" ID="ID_467242392" MODIFIED="1576282358073" TEXT="nicht-virtuelle Methode">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber die gesamte Verankerungs-Aktion läßt sich rein auf Widget-Interface-Ebene machen.
|
|
</p>
|
|
<p>
|
|
D.h. wir rufen den parent-Frame, aber die Implementierung der Methode greift nicht direkt
|
|
</p>
|
|
<p>
|
|
auf die Widgets im Frame zu, sondern delegiert an eine Hilfsfunktion....
|
|
</p>
|
|
<p>
|
|
STOP. Damit ist die virtuelle Methode nur verschoben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1540512410629" ID="ID_1212514016" MODIFIED="1576282358072" TEXT="generisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der ctor des DisplayFrame nimmt einen generischen Typ (Template),
|
|
</p>
|
|
<p>
|
|
von dem nur erwartet wird, daß er eine "Verankerungs"-Funktion bietet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540512486974" ID="ID_709169542" MODIFIED="1576282358072" TEXT="Funktor">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der ctor des DisplayFrame bekommt einen Funktor oder Lambda,
|
|
</p>
|
|
<p>
|
|
welchen er aufruft, um seine neu erstellten Widgets zu verankern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#63bcba" DESTINATION="ID_709169542" ENDARROW="Default" ENDINCLINATION="648;-124;" ID="Arrow_ID_1775236750" SOURCE="ID_1596055753" STARTARROW="None" STARTINCLINATION="661;33;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540588158613" ID="ID_725383313" MODIFIED="1540588172897" TEXT="Funktor ist...">
|
|
<node CREATED="1540588173682" ID="ID_1607525948" MODIFIED="1540588180650" TEXT="entweder ein virtueller dispatch"/>
|
|
<node CREATED="1540588181550" ID="ID_1634888629" MODIFIED="1540951684741" TEXT="oder de-facto generisch">
|
|
<linktarget COLOR="#14409c" DESTINATION="ID_1634888629" ENDARROW="Default" ENDINCLINATION="-255;27;" ID="Arrow_ID_797597310" SOURCE="ID_417702154" STARTARROW="None" STARTINCLINATION="224;-18;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540512596221" ID="ID_417702154" MODIFIED="1540588240683" TEXT="neige der 3. Lösung zu">
|
|
<arrowlink COLOR="#14409c" DESTINATION="ID_1634888629" ENDARROW="Default" ENDINCLINATION="-255;27;" ID="Arrow_ID_797597310" STARTARROW="None" STARTINCLINATION="224;-18;"/>
|
|
</node>
|
|
<node COLOR="#731e43" CREATED="1584888334461" HGAP="6" ID="ID_1191403237" MODIFIED="1584888393658" TEXT="trotzdem komplex und unvollständig" VSHIFT="28">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1584888403457" ID="ID_1500365619" MODIFIED="1584888425339" TEXT="Aufruf-Verfugung schwer verständlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da weit über den Code verstreut
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1584888427300" ID="ID_1626398524" MODIFIED="1584888438510" TEXT="löst nicht das Problem mit dem re-Konstruieren"/>
|
|
<node CREATED="1584888442705" ID="ID_1729804708" MODIFIED="1584888451663" TEXT="unterstützt keine nachträglichen Anpassungen"/>
|
|
<node CREATED="1584888452778" ID="ID_384525360" MODIFIED="1584888561167" TEXT="kann sich nicht aus der Anzeige ausklinken">
|
|
<arrowlink COLOR="#775ae8" DESTINATION="ID_1663593154" ENDARROW="Default" ENDINCLINATION="84;-81;" ID="Arrow_ID_348205317" STARTARROW="None" STARTINCLINATION="-297;47;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1584888309716" ID="ID_236695014" MODIFIED="1678406412732" TEXT="explizit modelliert (CanvasHook)">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1584888472583" ID="ID_1663593154" MODIFIED="1584888561167" TEXT="Idee: smart-Handle">
|
|
<linktarget COLOR="#775ae8" DESTINATION="ID_1663593154" ENDARROW="Default" ENDINCLINATION="84;-81;" ID="Arrow_ID_348205317" SOURCE="ID_384525360" STARTARROW="None" STARTINCLINATION="-297;47;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584888672307" ID="ID_213768440" MODIFIED="1584888703767" TEXT="brauche zusätzlich lokalen Offset">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584888686257" ID="ID_380050520" MODIFIED="1666919335032" TEXT="brauche zusätzlich Übersetzung Time -> pixel">
|
|
<linktarget COLOR="#354ce1" DESTINATION="ID_380050520" ENDARROW="Default" ENDINCLINATION="-2737;0;" ID="Arrow_ID_459309015" SOURCE="ID_1764561185" STARTARROW="None" STARTINCLINATION="-907;39;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1584889060615" ID="ID_730955223" MODIFIED="1584932567086" TEXT="muß Design des ViewHook ausdifferenzieren">
|
|
<arrowlink COLOR="#47cdcd" DESTINATION="ID_1949130658" ENDARROW="Default" ENDINCLINATION="-1150;77;" ID="Arrow_ID_662295339" STARTARROW="None" STARTINCLINATION="877;53;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584932570334" ID="ID_626245969" MODIFIED="1584888307348" TEXT="Aufruf an den DisplayManager weiterleiten">
|
|
<arrowlink COLOR="#6a9ab7" DESTINATION="ID_489715422" ENDARROW="Default" ENDINCLINATION="-479;1585;" ID="Arrow_ID_994014904" STARTARROW="None" STARTINCLINATION="851;54;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584888588670" ID="ID_578774732" MODIFIED="1584888657654" TEXT="Ausgebaut in ein Framework (ViewHook / ViewHooked)">
|
|
<arrowlink COLOR="#3998d4" DESTINATION="ID_27191288" ENDARROW="Default" ENDINCLINATION="160;-7;" ID="Arrow_ID_998626173" STARTARROW="None" STARTINCLINATION="5;17;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569711798770" ID="ID_27191288" MODIFIED="1584888645436">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ermöglicht (abstrahierten) Zugang zum Canvas über einen <b>ViewHook</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_465735263" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<linktarget COLOR="#3998d4" DESTINATION="ID_27191288" ENDARROW="Default" ENDINCLINATION="160;-7;" ID="Arrow_ID_998626173" SOURCE="ID_578774732" STARTARROW="None" STARTINCLINATION="5;17;"/>
|
|
<node COLOR="#435e98" CREATED="1573315138011" FOLDED="true" ID="ID_1957325688" MODIFIED="1576876407022" TEXT="brauchen wir hier eine Erweiterung auf mehrere Typen...?">
|
|
<arrowlink COLOR="#684be4" DESTINATION="ID_1458279581" ENDARROW="Default" ENDINCLINATION="-1681;0;" ID="Arrow_ID_1672277618" STARTARROW="None" STARTINCLINATION="788;-76;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1575652924086" ID="ID_996829512" MODIFIED="1575653116780" TEXT="Antwort: im Prinzip ja">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1575652931295" ID="ID_1649360599" MODIFIED="1576282358071" TEXT="aber ein voller double-dispatch-Mechanismus ist nicht durchführbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn er erzwingt entweder....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die relevante Implementierung in einm einzigen Objekt zu konzentrieren -- was dann den double-dispatch überflüssig macht, denn dann kann man direkt die bekannte andere Methode aufrufen
|
|
</li>
|
|
<li>
|
|
oder, wenn man die verschiedenen Belange auf getrennte Objekte verteilt, müssen sich diese gegenseitig erreichen können, und die hierfür notwendigen Rückreferenzen untergraben die Trennung
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1575653121588" ID="ID_46973905" MODIFIED="1575653151603" TEXT="also bleibt nur, die Typisierung in den Funktions-Signaturen explizit auszudrücken"/>
|
|
<node CREATED="1576876291037" ID="ID_114617089" MODIFIED="1576876404029" TEXT="dieses Problem versuchen wir, "pragmatisch auszusitzen"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Streng genommen würden wir in der Tat einen generischen Quer-Zugriffsmechanismus brauchen.
|
|
</p>
|
|
<p>
|
|
Allerdings ist dieser entweder nicht implementierbar, oder, wenn implementierbar, dann auch redundant.
|
|
</p>
|
|
<p>
|
|
Und zudem kristallisiert sich bereits heraus, daß wir es nicht mit einem "Universum" generischer Typen zu tun bekommen, sondern mit einer kleinen Auswahl, für die wir halt dann die Quer-Verbindungen direkt auscoden und gut is...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575065263201" FOLDED="true" ID="ID_1640997956" MODIFIED="1576876415142" TEXT="zu klären: Zugang zu diesem ViewHook">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575653188938" ID="ID_619809248" MODIFIED="1575653206332" TEXT="es läuft darauf hinaus, den Zugang in den DisplayFrames zusammenzufassen"/>
|
|
<node CREATED="1575653207328" ID="ID_1942901156" MODIFIED="1576876278735" TEXT="diese brauchen daher eine Referenz auf einen "irgendwo vorhandenen" Timeline-ViewHook"/>
|
|
<node COLOR="#338800" CREATED="1576876251659" ID="ID_1249561924" MODIFIED="1576876267532" TEXT="und tatsächlich bekommen sie diesen per verketteter Initialisierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563467223350" ID="ID_16819001" MODIFIED="1612645643066" TEXT="Problem: neu-Anordnung">
|
|
<node CREATED="1563467236241" ID="ID_711529393" MODIFIED="1563467248187" TEXT="wenn sich die Reihenfolge der Spuren ändert"/>
|
|
<node CREATED="1563467263669" ID="ID_1535368629" MODIFIED="1563467269910" TEXT="wenn eine Spur wegfällt"/>
|
|
<node CREATED="1563467279931" ID="ID_563915021" MODIFIED="1563467289047" TEXT="...dann müssen">
|
|
<node CREATED="1563467290138" ID="ID_568668070" MODIFIED="1563467296500" TEXT="bestehende Verankerungen beseitigt werden"/>
|
|
<node CREATED="1563467297369" ID="ID_737072989" MODIFIED="1575053380683" TEXT="alle Verankerungen neu re-Konstruiert werden">
|
|
<arrowlink COLOR="#927aa8" DESTINATION="ID_1728979524" ENDARROW="Default" ENDINCLINATION="-421;17;" ID="Arrow_ID_445844094" STARTARROW="None" STARTINCLINATION="398;25;"/>
|
|
<arrowlink COLOR="#d73f41" DESTINATION="ID_1414960950" ENDARROW="Default" ENDINCLINATION="203;-36;" ID="Arrow_ID_1023645457" STARTARROW="None" STARTINCLINATION="2;57;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1563467398036" FOLDED="true" ID="ID_828698459" MODIFIED="1679360246949" TEXT="Implementierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563467405665" ID="ID_1989047133" MODIFIED="1575580703174" TEXT="Ausdehnung berechnen">
|
|
<arrowlink COLOR="#5f57ba" DESTINATION="ID_1448105245" ENDARROW="Default" ENDINCLINATION="-1587;-35;" ID="Arrow_ID_532403594" STARTARROW="None" STARTINCLINATION="1293;134;"/>
|
|
<linktarget COLOR="#464cb7" DESTINATION="ID_1989047133" ENDARROW="Default" ENDINCLINATION="-742;0;" ID="Arrow_ID_1408255827" SOURCE="ID_1456350700" STARTARROW="None" STARTINCLINATION="440;27;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1582931496462" ID="ID_1920766923" MODIFIED="1582931599326" TEXT="Ausdehnung der Tracks Header/Body koordinieren">
|
|
<linktarget COLOR="#fe5b57" DESTINATION="ID_1920766923" ENDARROW="Default" ENDINCLINATION="595;0;" ID="Arrow_ID_1362710635" SOURCE="ID_1623890878" STARTARROW="Default" STARTINCLINATION="529;0;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563467415158" ID="ID_29134005" MODIFIED="1563467420585" TEXT="Profil generieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563467424456" ID="ID_1723744174" MODIFIED="1563467445803" TEXT="collapsed/hidden berücksichtigen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1674160114980" ID="ID_852402445" MODIFIED="1674160219744" TEXT="1/2023 noch nicht ganz klar wie">
|
|
<arrowlink COLOR="#c65e7c" DESTINATION="ID_1440303749" ENDARROW="Default" ENDINCLINATION="-1806;-99;" ID="Arrow_ID_537995229" STARTARROW="None" STARTINCLINATION="-421;38;"/>
|
|
</node>
|
|
<node CREATED="1674160134114" ID="ID_141550042" MODIFIED="1674160141660" TEXT="vermutich bereits beim Aufbau des Profils"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1563467451739" ID="ID_1414960950" MODIFIED="1575053380683" TEXT="(re)Konstruieren">
|
|
<linktarget COLOR="#d73f41" DESTINATION="ID_1414960950" ENDARROW="Default" ENDINCLINATION="699;-94;" ID="Arrow_ID_1514395934" SOURCE="ID_283854399" STARTARROW="None" STARTINCLINATION="236;12;"/>
|
|
<linktarget COLOR="#d73f41" DESTINATION="ID_1414960950" ENDARROW="Default" ENDINCLINATION="203;-36;" ID="Arrow_ID_1023645457" SOURCE="ID_737072989" STARTARROW="None" STARTINCLINATION="2;57;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node CREATED="1563467519263" ID="ID_497587608" MODIFIED="1576282358071" TEXT="anders als der initiale Aufbau">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beim initialen Aufbau sitzen wir in einem ctor-Aufruf,
|
|
</p>
|
|
<p>
|
|
und zwar der ctor-TrackPresenter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563467588351" ID="ID_1224899798" MODIFIED="1563467595841" TEXT="Unterscheidung root/nested">
|
|
<node CREATED="1563467597287" ID="ID_1571128409" MODIFIED="1576282358070" TEXT="beim ctor-Aufruf implizit/automatisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insofern der ctor für den root-Track (fork-root) vom TimelineController aufgerufen wird,
|
|
</p>
|
|
<p>
|
|
alle anderen verschachtelten ctors aber von den TrackPresentern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563467604327" ID="ID_175300386" MODIFIED="1563467621867" TEXT="nur sub-Tracks werden re-Konstruiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563467848565" ID="ID_1150018491" MODIFIED="1576282358069" TEXT="re-Konstruieren müssen letztlich die TrackPresenter machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil <i>nur sie </i>durch ihren Display-Frame die beiden Kind-Widgets kennen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563467916708" ID="ID_568904515" MODIFIED="1576282358069" TEXT="klären: Kind-Widget managen/entfernen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
inwiefern gibt es Beschränkungen, wenn man ein Kind-Widget von einem Container entfernt?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576710302057" ID="ID_1083674973" MODIFIED="1576710309540" TEXT="#1198 clarify removing of widgets in timeline">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1563468083453" ID="ID_988508640" MODIFIED="1576282358068" TEXT="Interface Gtk::Container ist nur für single-Child">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"This interface is used for all single item holding containers. Multi-item containers provide their own unique interface as their items are generally more complex. The methods of the derived classes should be prefered over these..."
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563468845867" ID="ID_1400714108" MODIFIED="1563468859195" TEXT="aber: Gtk::Container hat iterative Methoden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563468094444" ID="ID_638941576" MODIFIED="1563468103423" TEXT="multi-Widget Container haben spezielle Methoden">
|
|
<node CREATED="1563468293265" ID="ID_1078909584" MODIFIED="1563468329357" TEXT="bei uns: PatchbayWidget::installFork (TrackHeadWidget& rootTrackHead)">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1563468335579" ID="ID_1427740391" MODIFIED="1563468353099" TEXT="PatchbayWidget ist ein Gtk::Viewport (a scrollable pane)"/>
|
|
<node CREATED="1563468377867" ID="ID_1246261771" MODIFIED="1575131340955" TEXT="TrackHeadWidget is a Gtk::Grid">
|
|
<linktarget COLOR="#7bd7ba" DESTINATION="ID_1246261771" ENDARROW="Default" ENDINCLINATION="572;-24;" ID="Arrow_ID_1664699016" SOURCE="ID_1911416938" STARTARROW="None" STARTINCLINATION="860;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1575131300019" ID="ID_1668819881" MODIFIED="1576964962650" TEXT="Gtk::Container::remove(Widget&)"/>
|
|
<node CREATED="1575131316505" ID="ID_364347304" MODIFIED="1575131328851" TEXT="Gtk::Grid::attach(widget, pos...)"/>
|
|
</node>
|
|
<node CREATED="1563468411262" ID="ID_738452608" MODIFIED="1563468413323" TEXT="TrackHeadWidget::injectSubFork (TrackHeadWidget& subForkHead)"/>
|
|
</node>
|
|
<node CREATED="1576966531922" ID="ID_88110124" LINK="https://issues.lumiera.org/ticket/1198#comment:5" MODIFIED="1576966563610" TEXT="siehe Detail-Kommentar im Ticket">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1576966573366" ID="ID_552334044" MODIFIED="1576966591254" TEXT="Gtk::Container managed den ref-count des C-Objekts"/>
|
|
<node CREATED="1576966592939" ID="ID_495877115" MODIFIED="1576966611564" TEXT="Objekte, die zerstört werden, werden automatisch aus dem Container entfernt"/>
|
|
<node CREATED="1576966612744" ID="ID_1380812898" MODIFIED="1576966693515" TEXT="der Gtkmm-Wrapper Gtk::Widget hält einen ref-count">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und hält damit sein unterliegendes C-Objekt am Leben
|
|
</p>
|
|
<p>
|
|
(genauer gesagt, die Basisklasse Gtk::Object macht das)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1573412013164" FOLDED="true" ID="ID_1135588379" MODIFIED="1679359993215" TEXT="Analyse der Situation">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1573412027270" ID="ID_333121233" MODIFIED="1573412030884" TEXT="Fall-1">
|
|
<node CREATED="1573412032669" ID="ID_1928241145" MODIFIED="1573412064854" TEXT="neuer Track">
|
|
<node CREATED="1573424510571" ID="ID_1970637049" MODIFIED="1573424545467" TEXT="Header-Widget wird angehängt, mithin ggfs an der falschen Stelle"/>
|
|
<node CREATED="1573424546799" ID="ID_1600792539" MODIFIED="1573424566536" TEXT="Root-Body wird ebenfalls angehängt, und damit ebenso ggfs an der falschen Stelle"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573412072736" ID="ID_1432670869" MODIFIED="1573412077919" TEXT="Fall-2">
|
|
<node CREATED="1573412078991" ID="ID_1620957397" MODIFIED="1573412086433" TEXT="Track fällt weg">
|
|
<node CREATED="1573424479816" ID="ID_1733070752" MODIFIED="1573424490530" TEXT="Header-Widget wird obsolet und muß weg"/>
|
|
<node CREATED="1573424491747" ID="ID_735914292" MODIFIED="1573744342118" TEXT="Track-Body ist schon gelöscht -> dangling Pointer in der Kinder-Collection des Vaters"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573412088422" ID="ID_1809192896" MODIFIED="1573412091217" TEXT="Fall-3">
|
|
<node CREATED="1573412092916" ID="ID_5252596" MODIFIED="1573412100336" TEXT="Umordnung (auch indirekt)"/>
|
|
<node CREATED="1573412128366" ID="ID_518244916" MODIFIED="1573412148434" TEXT="es besteht eine Verknüpfung...">
|
|
<node CREATED="1573412149566" ID="ID_920888107" MODIFIED="1573412159121" TEXT="die nicht mehr valide ist"/>
|
|
<node CREATED="1573412162340" ID="ID_1639454562" MODIFIED="1573412170495" TEXT="die aber als Solche garantiert bestehen bleibt">
|
|
<node CREATED="1573742980812" ID="ID_701589566" MODIFIED="1573743018643" TEXT="sofern wir Fall-1|2 ausschließen können">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1573742994843" ID="ID_427824389" MODIFIED="1573743021381" TEXT="Trennung der Fälle ist essentiell">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573424578050" ID="ID_1381344686" MODIFIED="1573424594636" TEXT="alle Elemente müßten entfernt und erneut angehängt werden">
|
|
<node CREATED="1575051390743" ID="ID_734317772" MODIFIED="1575052370826">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es läuft auf eine <b>Sortier-Operation</b> hinaus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_734317772" ENDARROW="Default" ENDINCLINATION="13;48;" ID="Arrow_ID_1113611998" SOURCE="ID_936490073" STARTARROW="None" STARTINCLINATION="86;7;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573424733614" FOLDED="true" ID="ID_1581320485" MODIFIED="1575580929792" TEXT="Idee: Reparatur-Durchgang">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1573424745836" ID="ID_1099334229" MODIFIED="1573424761824" TEXT="Aufruf mit dem Element, welches als nächstes kommen müßte"/>
|
|
<node CREATED="1573424763026" ID="ID_187176618" MODIFIED="1573424866527" TEXT="sobald etwas anderes als dieses Element ansteht...">
|
|
<node CREATED="1573424867525" ID="ID_184724441" MODIFIED="1573424867525" TEXT="wird der gesamte Rest weggeworfen"/>
|
|
<node CREATED="1573424869699" ID="ID_1553301411" MODIFIED="1573424884797" TEXT="oder zumindest solange weggeworfen, bis es wieder paßt"/>
|
|
<node CREATED="1575051446848" ID="ID_936490073" MODIFIED="1575052370825" TEXT="Stop. Das ist ein »bubble sort«">
|
|
<arrowlink DESTINATION="ID_734317772" ENDARROW="Default" ENDINCLINATION="13;48;" ID="Arrow_ID_1113611998" STARTARROW="None" STARTINCLINATION="86;7;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573424888306" ID="ID_1069769655" MODIFIED="1573424917681" TEXT="Problem: verfügbares API für Kind-Widgets im Gtk::Container">
|
|
<node CREATED="1573425004589" ID="ID_182890491" MODIFIED="1573425028633" TEXT="man müßte sich mit get_children die Liste aller Widget* geben lassen"/>
|
|
<node CREATED="1573425320822" ID="ID_697283629" MODIFIED="1573425373163" TEXT="Umschichten ist nicht so ohne Weiteres möglich"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1573425072103" ID="ID_263082856" MODIFIED="1573425312415" TEXT="Frage: wer verwendet eigentlich die TrackBody-Objekte?">
|
|
<node CREATED="1573425179133" ID="ID_1985243477" MODIFIED="1573425187274" TEXT="subTracks_ ist private"/>
|
|
<node CREATED="1573425238895" ID="ID_1011487695" MODIFIED="1573425238895" TEXT="TrackBody::calcHeight()"/>
|
|
<node CREATED="1573425269964" ID="ID_719978190" MODIFIED="1573425269964" TEXT="TrackBody::establishTrackSpace (TrackProfile& profile)"/>
|
|
<node COLOR="#435e98" CREATED="1573425287886" ID="ID_1908598157" MODIFIED="1573425307155" TEXT="Fazit: nur iterativer Zugriff (und nil-Check)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573425401827" ID="ID_1879825231" MODIFIED="1573425405599" TEXT="Zwischenstand">
|
|
<node CREATED="1573425406826" ID="ID_1838031996" MODIFIED="1573425425244" TEXT="TrackBody ist gar nicht so schlimm">
|
|
<node CREATED="1573425438222" ID="ID_224907016" MODIFIED="1573425443506" TEXT="die Objekte bleiben bestehen"/>
|
|
<node CREATED="1573425444286" ID="ID_714582673" MODIFIED="1573425466462" TEXT="füge sie lediglich in der richtigen Reihenfolge wieder ein"/>
|
|
<node CREATED="1573425467578" ID="ID_855524059" MODIFIED="1573425476468" TEXT="gefolgt von einem neuen evaluation pass"/>
|
|
<node CREATED="1573425575308" ID="ID_1100592812" MODIFIED="1573425584283" TEXT="man müßte ggfs einige Werte zurücksetzen">
|
|
<node CREATED="1573425585442" ID="ID_683130698" MODIFIED="1575052398117" TEXT="startLine_ = 0"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573425775929" ID="ID_385747502" MODIFIED="1573425793245" TEXT="dagegen Gtk::Grid ist aufwendiger">
|
|
<node CREATED="1573425794934" ID="ID_1806364197" MODIFIED="1573425808512" TEXT="man kann zwar indirekt die Kind-Elemente enumerieren"/>
|
|
<node CREATED="1573425814356" ID="ID_684750058" MODIFIED="1575133305653" TEXT="und man kann per Container::remove() ein Widget entfernen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und müßte es danach explizit manuell löschen!!
|
|
</p>
|
|
<p>
|
|
d.h. es wird dann nicht mehr gemanaged (was in diesem Fall hilfreich ist)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1573425898969" ID="ID_278841451" MODIFIED="1573425910100" TEXT="aber unser Aufbau ist ehr komplex">
|
|
<node CREATED="1573425919742" ID="ID_914009908" MODIFIED="1575052422466" TEXT="d.h. wir müßten Sub-Grids und sonstigen Content erhalten"/>
|
|
<node CREATED="1575052437324" ID="ID_719843409" MODIFIED="1575052451208" TEXT="und insgesamt als Widget an der richtigen Stelle wieder einfügen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575063986126" FOLDED="true" ID="ID_237283777" MODIFIED="1582930967369" TEXT="konkretisiert: als ViewHook-Mechanismus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist zunächst ein Versuch, ein mühsam errungenes Design zu verifizieren...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#261eb7" DESTINATION="ID_237283777" ENDARROW="Default" ENDINCLINATION="551;-700;" ID="Arrow_ID_119083900" SOURCE="ID_1018000905" STARTARROW="None" STARTINCLINATION="-962;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575064318098" ID="ID_293965279" MODIFIED="1575064328652" TEXT="Fall Track-Head">
|
|
<node CREATED="1575064338701" ID="ID_415507995" MODIFIED="1575064375893" TEXT="DisplayFrame hat einen ViewHook in das korrespondierende TrackHeadWidget"/>
|
|
<node CREATED="1575064401006" ID="ID_1441033648" MODIFIED="1575064462745" TEXT="nach Struktur-Änderung dekoriert der TrackPresenter einen Subtrack-Iterator"/>
|
|
<node CREATED="1575064464430" ID="ID_312804063" MODIFIED="1575064465801" TEXT="mit Zugriff auf alle diese Track-Head ViewHooks"/>
|
|
<node CREATED="1575064550915" ID="ID_240478975" MODIFIED="1575064563346" TEXT="und gibt ihn an welches ViewHook?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1575064564486" ID="ID_1865914633" MODIFIED="1575132210050" TEXT="klären">
|
|
<linktarget COLOR="#4880c1" DESTINATION="ID_1865914633" ENDARROW="Default" ENDINCLINATION="259;77;" ID="Arrow_ID_1022537409" SOURCE="ID_1502992527" STARTARROW="None" STARTINCLINATION="206;43;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575130722129" ID="ID_1376658524" MODIFIED="1575130746502" TEXT="dieses muß konkret für die zu bearbeitenden ViewHooks zuständig sein"/>
|
|
<node CREATED="1575130747730" ID="ID_782210944" MODIFIED="1575130767965">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ViewHooks können <i>nach Hause telefonieren</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1575130800635" ID="ID_1683855693" MODIFIED="1575130824075" TEXT="hier also das (sub)TrackHeadWidget, welches die umzuordnenden Zeilen enthält"/>
|
|
</node>
|
|
<node CREATED="1575130831063" ID="ID_708770207" MODIFIED="1575130894498" TEXT="dieses kann irgend einem der involvierten ViewHooks entnommen werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575064581374" ID="ID_1196434993" MODIFIED="1575064594600" TEXT="dieser ViewHook ist in der Tat ein TrackHeadWidget"/>
|
|
<node CREATED="1575064653804" ID="ID_448564345" MODIFIED="1575064688635" TEXT="und es pullt den Iterator und ruft für jedes Element (ViewHooked&) auf..."/>
|
|
<node CREATED="1575064679128" ID="ID_1963787462" MODIFIED="1575064684603" TEXT="reHook()">
|
|
<node CREATED="1575064711612" ID="ID_1603635315" MODIFIED="1575064721990" TEXT="sucht die passende Grid-Zeile">
|
|
<node COLOR="#338800" CREATED="1575064723058" ID="ID_1911416938" MODIFIED="1575131358651" TEXT="wie geht das?">
|
|
<arrowlink COLOR="#7bd7ba" DESTINATION="ID_1246261771" ENDARROW="Default" ENDINCLINATION="572;-24;" ID="Arrow_ID_1664699016" STARTARROW="None" STARTINCLINATION="860;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1575131369810" HGAP="26" ID="ID_1240564721" MODIFIED="1575131382246" TEXT="gar nicht notwendig" VSHIFT="14">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1575131388840" ID="ID_1983492601" MODIFIED="1576964804007" TEXT="man muß nur das Widget herausnehmen...."/>
|
|
<node CREATED="1575131395663" ID="ID_335595760" MODIFIED="1575131407476" TEXT="und den TrackHeadWidget::childCnt_ sauber mitzählen"/>
|
|
<node CREATED="1576964721751" ID="ID_1854636458" MODIFIED="1576964809066" TEXT="jede Grid-Zelle ist wie eine Gtk::Box">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576964730941" ID="ID_1794365436" MODIFIED="1576964744279" TEXT="d.h. da könnten mehrere Widgets drinnen liegen"/>
|
|
<node CREATED="1576964745132" ID="ID_127744235" MODIFIED="1576964754158" TEXT="in der konfigurierten ORIENTATION"/>
|
|
</node>
|
|
<node CREATED="1576964815114" ID="ID_341368382" MODIFIED="1576964827251" TEXT="Zellen werden on demand erzeugt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575064734265" ID="ID_332197090" MODIFIED="1575064749715" TEXT="nimmt das Widget heraus und löscht die Zeile"/>
|
|
<node CREATED="1575064751217" ID="ID_292440090" MODIFIED="1575064765089" TEXT="fügt das Widget ganz regulär als neue Zeile am Ende an"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575064805462" ID="ID_731805099" MODIFIED="1575064810107" TEXT="Fall Track-Body">
|
|
<node CREATED="1575064815198" ID="ID_1801360702" MODIFIED="1575064827177" TEXT="DisplayFrame hat einen ViewHook in den TrackBodyCanvas"/>
|
|
<node CREATED="1575064833095" ID="ID_593172418" MODIFIED="1575064854765" TEXT="nach Struktur-Änderung dekoriert der TrackPresenter einen Subtrack-Iterator"/>
|
|
<node CREATED="1575064855544" ID="ID_1131024510" MODIFIED="1575064916996" TEXT="mit Zugriff auf alle diese TrackBody ViewHooks">
|
|
<node CREATED="1575064918904" ID="ID_562010334" MODIFIED="1575064937486" TEXT="Vorsicht: nicht irritieren lassen">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1575064939788" ID="ID_896603255" MODIFIED="1575064952071" TEXT="die TrackBody-Objekte selber liegen im DisplayFrame"/>
|
|
<node CREATED="1575064953275" ID="ID_1410573489" MODIFIED="1575064968229" TEXT="aber der Canvas / DisplayManager hat eine Liste von TrackBody*"/>
|
|
</node>
|
|
<node CREATED="1575065001141" ID="ID_1381752265" MODIFIED="1575065027911" TEXT="wiederum die Frage: wie erfolgt der Zugang zum ViewHook?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1575064564486" ID="ID_1502992527" MODIFIED="1575132210050" TEXT="TODO klären">
|
|
<arrowlink COLOR="#4880c1" DESTINATION="ID_1865914633" ENDARROW="Default" ENDINCLINATION="259;77;" ID="Arrow_ID_1022537409" STARTARROW="None" STARTINCLINATION="206;43;"/>
|
|
</node>
|
|
<node CREATED="1582926781626" ID="ID_1990000066" MODIFIED="1582926793526" TEXT="über ein spezielles Interface vom Parent her">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575065047103" ID="ID_949577790" MODIFIED="1575065064472" TEXT="dieses pullt und ruft auf jedem ViewHooked...."/>
|
|
<node CREATED="1575065065436" ID="ID_870630036" MODIFIED="1575065068376" TEXT="reHook()">
|
|
<node CREATED="1575065071619" ID="ID_868399500" MODIFIED="1575065084870" TEXT="findet die passende Sub-Liste von TrackBody*">
|
|
<node CREATED="1575064723058" ID="ID_640324891" MODIFIED="1575132217084" TEXT="TODO wie geht das?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1575132218659" ID="ID_477189517" MODIFIED="1576282358067" TEXT="gar nicht notwendig, er hat sie schon">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn, wie sich herausgestellt hat, muß das Interface ViewHook hierarchisch heruntergebrochen werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575065153720" ID="ID_542989067" MODIFIED="1575065164547" TEXT="nimmt den TrackBody* heraus"/>
|
|
<node CREATED="1575065165679" ID="ID_1342524311" MODIFIED="1575065176156" TEXT="fügt den TrackBody* hinten neu an"/>
|
|
<node CREATED="1575065178531" ID="ID_1083347222" MODIFIED="1575065192431" TEXT="der später folgende Display-Evaluation-Pass">
|
|
<node CREATED="1575065193925" ID="ID_964654254" MODIFIED="1575065208561" TEXT="ausgelöst durch das nun geleerte TrackProfile"/>
|
|
<node CREATED="1575065210080" ID="ID_984570817" MODIFIED="1582930995724" TEXT="iteriert über diese und baut die Zeichen-Struktur neu auf"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575132277131" ID="ID_1311922241" MODIFIED="1575132286415" TEXT="Fazit/Konsequenz">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1575132287961" ID="ID_1273254233" MODIFIED="1575132460335" TEXT="das Interface ViewHook muß hierarchisch heruntergebrochen werden">
|
|
<arrowlink COLOR="#3c3061" DESTINATION="ID_29287629" ENDARROW="Default" ENDINCLINATION="-725;0;" ID="Arrow_ID_1727524131" STARTARROW="None" STARTINCLINATION="-243;9;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1575132319988" ID="ID_1036911668" MODIFIED="1575132345916" TEXT="Begründung: es abstrahiert das Anhängen an eine Liste"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576705892034" ID="ID_1125539403" MODIFIED="1576973261034" TEXT="(um)Bau für Struktur-Änderungen">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1575579955362" ID="ID_931838684" MODIFIED="1575670594063" STYLE="fork" TEXT="strukturell-generische Implementierung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1575579987443" ID="ID_1007243980" MODIFIED="1582926752028" TEXT="Analyse allgemein">
|
|
<arrowlink COLOR="#2e1d90" DESTINATION="ID_274573678" ENDARROW="Default" ENDINCLINATION="-1890;235;" ID="Arrow_ID_1905963364" STARTARROW="None" STARTINCLINATION="537;68;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575580660604" ID="ID_932505699" MODIFIED="1576441760509" TEXT="Change-Listener auf dem Diff-System notwendig">
|
|
<arrowlink COLOR="#4d81bf" DESTINATION="ID_350484232" ENDARROW="Default" ENDINCLINATION="-77;-68;" ID="Arrow_ID_658076840" STARTARROW="None" STARTINCLINATION="-201;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1575576971732" ID="ID_673183519" MODIFIED="1575670587273" TEXT="Mechanismus zum Umordnen">
|
|
<arrowlink COLOR="#507b9b" DESTINATION="ID_1193961919" ENDARROW="Default" ENDINCLINATION="-877;88;" ID="Arrow_ID_624713040" STARTARROW="None" STARTINCLINATION="483;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576757730509" ID="ID_1816490333" MODIFIED="1582926717705" TEXT="Thema »Widget-Position«">
|
|
<arrowlink COLOR="#605bb8" DESTINATION="ID_1949130658" ENDARROW="Default" ENDINCLINATION="204;611;" ID="Arrow_ID_993970158" STARTARROW="None" STARTINCLINATION="299;12;"/>
|
|
<linktarget COLOR="#15bcc9" DESTINATION="ID_1816490333" ENDARROW="Default" ENDINCLINATION="-454;46;" ID="Arrow_ID_408864676" SOURCE="ID_1121301646" STARTARROW="None" STARTINCLINATION="-235;17;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1576758030604" HGAP="54" ID="ID_1869378616" MODIFIED="1576876023320" TEXT="entsprechende Erweiterung für delegating-ViewHook notwendig" VSHIFT="26">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576876029833" HGAP="57" ID="ID_893654405" MODIFIED="1576876116458" TEXT="klären: brauchen wir verschiedene Offsets per Typ" VSHIFT="3">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also einen speziellen Offset für Clips und einen anderen speziellen Offset für Effekt-Marker?
|
|
</p>
|
|
<p>
|
|
Oder, anders, wie bekommen wir diese Dinger jeweils in den richtigen unter-Bereich des Track-Layouts??
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705136916" ID="ID_576958386" MODIFIED="1678406924035" TEXT="Restrukturierung Timeline/Tracks/view">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1576705150754" FOLDED="true" ID="ID_584153731" MODIFIED="1576973221801" TEXT="bestehendes Design muß "justiert" werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....sonst wird es zur Sackgasse.
|
|
</p>
|
|
<p>
|
|
Die zugrundeliegende Idee war gut, aber ich hab mich in einer <i>cleveren Implementierung</i> mit einem Lambda-Parameter festgefahren. Zwar brauche ich <i>nicht</i> die volle Generizität und Quer-Beweglichkeit, aber der verallgemeinerte Enwurf für ViewHook(ed) ist auch ohne das um Längen besser als die bestehende Struktur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1576705055911" ID="ID_665871359" MODIFIED="1576705095215" TEXT="sinnvolle Teile des geplanten Refactoring">
|
|
<arrowlink COLOR="#3c62b6" DESTINATION="ID_1681994818" ENDARROW="Default" ENDINCLINATION="-1457;26;" ID="Arrow_ID_1666541151" STARTARROW="None" STARTINCLINATION="898;63;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705325443" ID="ID_423600338" MODIFIED="1576973217276" TEXT="Struktur und Bedeutung der Interfaces übernehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576705602597" ID="ID_658097030" MODIFIED="1576705612832" TEXT="ViewHook : verallgemeintertes Display"/>
|
|
<node CREATED="1575223172838" ID="ID_243088075" MODIFIED="1576705835515" TEXT="Display-Frame...">
|
|
<linktarget COLOR="#5983d3" DESTINATION="ID_243088075" ENDARROW="Default" ENDINCLINATION="-97;303;" ID="Arrow_ID_1676257131" SOURCE="ID_1544442721" STARTARROW="None" STARTINCLINATION="290;-167;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1575223418428" ID="ID_410282263" MODIFIED="1576705672399" TEXT="hält einen ViewHooked<TrackBody>"/>
|
|
<node CREATED="1575223430819" ID="ID_801224548" MODIFIED="1576705676303" TEXT="hält einen ViewHooked<TrackHeaderWidget>"/>
|
|
<node CREATED="1575223465392" ID="ID_616543749" MODIFIED="1576705680836" TEXT="hält eine Referenz auf ViewHook<Widget>"/>
|
|
<node CREATED="1576705693529" ID="ID_306131588" MODIFIED="1576705702364" TEXT="delegierende ViewHook-Implementierung">
|
|
<node CREATED="1575223491827" ID="ID_1877460309" MODIFIED="1576705686323" TEXT="implementiert selber ViewHook<Clip>"/>
|
|
<node CREATED="1575223505705" ID="ID_1991875840" MODIFIED="1576705691469" TEXT="implementiert selber ViewHook<Marker>"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576705354416" ID="ID_494165942" MODIFIED="1576705377752" TEXT="Interfaces generisch ausdrücken"/>
|
|
<node CREATED="1576705379219" ID="ID_594097888" MODIFIED="1576705393981" TEXT="Verallgemeinern des Konzepts »Display-Attachment«"/>
|
|
<node CREATED="1576705301390" ID="ID_738352208" MODIFIED="1576705323162">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber <b>keine</b> generische Quer-Beweglichkeit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576973126460" ID="ID_1007307799" MODIFIED="1576973186181" TEXT="Design ist letzlich besser geworden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705400592" FOLDED="true" ID="ID_1892542246" MODIFIED="1576973227762" TEXT="top-level ViewHook schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576705652570" ID="ID_551481195" MODIFIED="1576705666257" TEXT="ViewHook<Widget>">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705712654" ID="ID_1745971143" MODIFIED="1582502959217" TEXT="implementieren im TrackCanvas">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705413085" FOLDED="true" ID="ID_1979905155" MODIFIED="1576973024213" TEXT="Konstruktor / "ein-Häkel"-Mchanismus darauf umstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576710340808" FOLDED="true" ID="ID_1326638754" MODIFIED="1576973190436" TEXT="enger verwobene Konstruktoren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576710359933" ID="ID_915757567" MODIFIED="1576710379670" TEXT="ViewHooked<TrackBody> braucht ViewHook<TrackBody>"/>
|
|
<node CREATED="1576710359933" ID="ID_1122829974" MODIFIED="1576710422214" TEXT="ViewHooked<TrackHeadWidget> braucht ViewHook<TrackHeadWidget>"/>
|
|
<node COLOR="#338800" CREATED="1576760201752" ID="ID_958849078" MODIFIED="1576973058150" TEXT="Problem: ViewHook-Subinterfaces">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576760226038" ID="ID_1753803962" MODIFIED="1576760241450" TEXT="oh weh... die Quer-Beweglichkeit ist wieder da">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1576760324713" ID="ID_1267786696" MODIFIED="1576760340354" TEXT="einziger Ausweg... Display-Manager wird zum Super-Hook"/>
|
|
<node COLOR="#338800" CREATED="1576806720057" ID="ID_805988831" MODIFIED="1576875959056" TEXT="noch besser: das in ein Sammel-Interface packen">
|
|
<linktarget COLOR="#67d289" DESTINATION="ID_805988831" ENDARROW="Default" ENDINCLINATION="-36;221;" ID="Arrow_ID_909815140" SOURCE="ID_1966295709" STARTARROW="None" STARTINCLINATION="495;16;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576806744893" ID="ID_526365809" MODIFIED="1576855570801" TEXT="vielleicht sogar ein Accessor-Interface">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576806754123" ID="ID_931227814" MODIFIED="1576806765651" TEXT="das was wir brauchen -- nicht generisch">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1576806780944" ID="ID_424677663" MODIFIED="1576806787371" TEXT="wo definieren?">
|
|
<node CREATED="1576806800277" ID="ID_1586259922" MODIFIED="1576806811655" TEXT="Track-Presenter (zumindest) muß das sehen"/>
|
|
<node CREATED="1576806815591" ID="ID_1412328590" MODIFIED="1576806824733" TEXT="ViewHook sollte reine Implementierung bleiben"/>
|
|
<node COLOR="#435e98" CREATED="1576806845175" ID="ID_302576498" MODIFIED="1576855554242" TEXT="DisplayManager">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1576806881586" ID="ID_1243796008" MODIFIED="1576806891357" TEXT="ja da gehört's eigentlich hin"/>
|
|
<node CREATED="1576806892609" ID="ID_981763412" MODIFIED="1576806908361" TEXT="versuch, möglichst mit forward-decl zu arbeiten"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576855633920" ID="ID_1642579599" MODIFIED="1576855726346" TEXT="damit ist auch die Basis zum relativen Positionieren gegeben">
|
|
<arrowlink COLOR="#6780d3" DESTINATION="ID_1121301646" ENDARROW="Default" ENDINCLINATION="551;-498;" ID="Arrow_ID_229033893" STARTARROW="None" STARTINCLINATION="-477;21;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576710544415" FOLDED="true" ID="ID_88564726" MODIFIED="1576973053608" TEXT="zwei Fälle zu unterscheiden">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1576710558354" ID="ID_146653361" MODIFIED="1576973031122" TEXT="top-Level">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576710810240" ID="ID_1493306680" MODIFIED="1576710989724" TEXT="bisher...">
|
|
<node CREATED="1576710991266" ID="ID_544968183" MODIFIED="1576710991266" TEXT="TimelineLayout::installRootTrack(TrackHeadWidget&, TrackBody&)"/>
|
|
<node CREATED="1576710993235" ID="ID_64093228" MODIFIED="1576711013678" TEXT="Abbauen war nicht implementiert"/>
|
|
<node CREATED="1576711169203" ID="ID_1075649932" MODIFIED="1576711179426" TEXT="Move ist hier explizit nicht vorgesehen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576713454074" ID="ID_175021708" MODIFIED="1576973039128" TEXT="müßte nun die zwei ViewHook-Interfaces pro forma implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576713516746" ID="ID_908928403" MODIFIED="1576714570369" TEXT="aber eigentlich nur zum einmaligen Gebrauch"/>
|
|
<node CREATED="1576714892102" ID="ID_1235287514" MODIFIED="1576714911362" TEXT="um die Wurzel zu verankern"/>
|
|
<node CREATED="1576714597064" ID="ID_123363250" MODIFIED="1576757177602" STYLE="fork" TEXT="that's Life?">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1576757179611" ID="ID_857948859" MODIFIED="1576757182790" TEXT="ja">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1576757228532" ID="ID_292264284" MODIFIED="1576757344691" TEXT="es ist eine direkte Konsequenz der Abstraktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar, genauer gesagt, eine Konsequenz der Entscheidung, nicht nur einen ViewHook, sondern ein ViewHooked zu machen. Ich hab die Beziehung in's Strukturelle hinen genommen. Damit muß auch die Wurzel diese Struktur unterstützen, und damit wird an dieser Stelle die Abstraktion undicht.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1576757241132" ID="ID_1435695009" MODIFIED="1576757247151" TEXT="sozusagen ein Preis dieser"/>
|
|
</node>
|
|
<node CREATED="1576714633667" ID="ID_53757225" MODIFIED="1576756316761" TEXT="oder DisplayFrame zum Über-Hook ausbauen?">
|
|
<linktarget COLOR="#696f88" DESTINATION="ID_53757225" ENDARROW="Default" ENDINCLINATION="57;121;" ID="Arrow_ID_362033711" SOURCE="ID_1656418231" STARTARROW="None" STARTINCLINATION="9;-141;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1576714722676" ID="ID_511678024" MODIFIED="1576714736872" TEXT="damit könnte ich das ganze "ein-Häkeln" ersetzen"/>
|
|
<node CREATED="1576714737885" ID="ID_143709986" MODIFIED="1576714780020" TEXT="aber unterstütze das Interface nur teilweise">
|
|
<node CREATED="1576714781887" ID="ID_586224465" MODIFIED="1576714793748" TEXT="move() macht allgemein keinen Sinn"/>
|
|
<node CREATED="1576714837439" ID="ID_679289748" MODIFIED="1576714854343" TEXT="reOrder / rehook() eigentlich auch nicht"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576710566905" ID="ID_1380718144" MODIFIED="1576968908894" TEXT="Rekursion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576875874270" ID="ID_345044928" MODIFIED="1576875883513" TEXT="unproblematisch"/>
|
|
<node CREATED="1576875884389" ID="ID_209901177" MODIFIED="1576875891784" TEXT="basierend auf der Lösung für top-Level"/>
|
|
<node CREATED="1576875892588" ID="ID_1966295709" MODIFIED="1576875968903" TEXT="DisplayFrame selber implementiert wieder das DisplayViewHooks Sammel-Interface">
|
|
<arrowlink COLOR="#67d289" DESTINATION="ID_805988831" ENDARROW="Default" ENDINCLINATION="-36;221;" ID="Arrow_ID_909815140" STARTARROW="None" STARTINCLINATION="495;16;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576753128134" FOLDED="true" ID="ID_1066136383" MODIFIED="1576973168017" TEXT="signalStructureChange_ anders lösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576753507885" ID="ID_1311899789" MODIFIED="1576968873199" TEXT="is vermutlich gar nicht mehr nötig">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1576968874470" ID="ID_801145838" MODIFIED="1576968878449" TEXT="doch ist nötig"/>
|
|
<node CREATED="1576968881005" ID="ID_984848180" MODIFIED="1576968898327" TEXT="aber eine innere Angelegenheit des Profil-Zeichen-Codes">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576753808609" ID="ID_1786295426" MODIFIED="1576753817108" TEXT="triggert bisher nur BodyCanvasWidget::slotStructureChange"/>
|
|
<node CREATED="1576753870146" ID="ID_585664275" MODIFIED="1576753909519" TEXT="erst mal auf den Display-Manager beschränken?">
|
|
<node CREATED="1576754072397" ID="ID_46871319" MODIFIED="1576754079511" TEXT="genügt nicht"/>
|
|
<node CREATED="1576754087251" ID="ID_843375867" MODIFIED="1576754106301" TEXT="muß auch Struktur-Änderungen weiter unten mitbekommen"/>
|
|
<node CREATED="1576754985572" ID="ID_84032417" MODIFIED="1576755004609" TEXT="zwei Lösungen">
|
|
<node CREATED="1576755005945" ID="ID_180843072" MODIFIED="1576756369600" TEXT="in einer Kette verwandter Objekte durchverdrahten">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1576755080360" ID="ID_1435594508" MODIFIED="1576756328976" TEXT="an geeigneter Stelle auf reHook() reagieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1576755445747" ID="ID_858059536" MODIFIED="1576755448918" TEXT="wo?"/>
|
|
<node CREATED="1576755498409" ID="ID_1656418231" MODIFIED="1576756316761">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur wenn DisplayFrame selber ein ViewHook <i>wäre</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#696f88" DESTINATION="ID_53757225" ENDARROW="Default" ENDINCLINATION="57;121;" ID="Arrow_ID_362033711" STARTARROW="None" STARTINCLINATION="9;-141;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1576756331616" ID="ID_1376732304" MODIFIED="1576756364407" TEXT="Nein! auch dann brauchen wir noch eine Kette">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil der Trigger irgendwo unten passiert, und nicht auf dem top-Level ViewHook
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576756393353" ID="ID_1634637216" MODIFIED="1576968855663" TEXT="letztlich brauchen wir eine Kombination der Möglichkeiten">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1576756408221" ID="ID_931947512" MODIFIED="1576756426206" TEXT="ein signalStructureChange_"/>
|
|
<node CREATED="1576756427034" ID="ID_1212535566" MODIFIED="1576756440540" TEXT="durchverkettet durch die TrackBody"/>
|
|
<node COLOR="#338800" CREATED="1576756442383" ID="ID_1410170658" MODIFIED="1576968842323" TEXT="und getriggert von allen relevanten Änderungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576756455861" ID="ID_1387794404" MODIFIED="1576756460006" TEXT="neuer sub-Body"/>
|
|
<node CREATED="1576756461090" ID="ID_120810428" MODIFIED="1576756473518" TEXT="sub-Body geht weg"/>
|
|
<node CREATED="1576756481001" ID="ID_1180573389" MODIFIED="1576756490503" TEXT="reHook() (=Umordnung)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705433836" FOLDED="true" ID="ID_1544442721" MODIFIED="1576973090826" TEXT="konkrete ViewHook(ed) einbinden">
|
|
<arrowlink COLOR="#5983d3" DESTINATION="ID_243088075" ENDARROW="Default" ENDINCLINATION="-97;303;" ID="Arrow_ID_1676257131" STARTARROW="None" STARTINCLINATION="290;-167;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1576705460961" ID="ID_363231858" MODIFIED="1576973087699" TEXT="ViewHooked<TrackBody>">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576705473228" ID="ID_1846992278" MODIFIED="1576705482735" TEXT="Mechanismus für Track-Profil"/>
|
|
<node CREATED="1576705483541" ID="ID_707363124" MODIFIED="1576705490984" TEXT="mit verschachtelten Sub-Tracks"/>
|
|
<node CREATED="1576705491972" ID="ID_1199800790" MODIFIED="1576705509384" TEXT="verwenden des bestehenden Display-Code">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
soweit möglich ohne grundlegende Änderungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705517369" ID="ID_1956333092" MODIFIED="1576973079830" TEXT="ViewHooked<TrackHeadWidget>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576705769431" ID="ID_6854402" MODIFIED="1576973078336" TEXT="delegierende ViewHook-Implementierung schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1576705779910" ID="ID_968522268" MODIFIED="1576705792920" TEXT="damit ViewHook<Clip>"/>
|
|
<node CREATED="1576705802515" ID="ID_674496871" MODIFIED="1576705809765" TEXT="und ViewHook<Marker>"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576855620250" ID="ID_1121301646" MODIFIED="1612031401163" TEXT="relatives Positionieren ermöglichen">
|
|
<arrowlink COLOR="#15bcc9" DESTINATION="ID_1816490333" ENDARROW="Default" ENDINCLINATION="-454;46;" ID="Arrow_ID_408864676" STARTARROW="None" STARTINCLINATION="-235;17;"/>
|
|
<linktarget COLOR="#6780d3" DESTINATION="ID_1121301646" ENDARROW="Default" ENDINCLINATION="551;-498;" ID="Arrow_ID_229033893" SOURCE="ID_1642579599" STARTARROW="None" STARTINCLINATION="-477;21;"/>
|
|
<linktarget COLOR="#4668c0" DESTINATION="ID_1121301646" ENDARROW="Default" ENDINCLINATION="-360;299;" ID="Arrow_ID_1147127867" SOURCE="ID_1574493569" STARTARROW="None" STARTINCLINATION="472;50;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582410135584" ID="ID_969058360" MODIFIED="1611478497698" TEXT="#1207 relative attachment and (custom) drawing of sub-widgets">
|
|
<arrowlink COLOR="#4567f1" DESTINATION="ID_1208770677" ENDARROW="Default" ENDINCLINATION="-696;74;" ID="Arrow_ID_1555581659" STARTARROW="None" STARTINCLINATION="1109;48;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1666448252605" HGAP="50" ID="ID_1855630485" MODIFIED="1678381794319" TEXT="Thema abschließen" VSHIFT="19">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1666448281749" ID="ID_307630617" MODIFIED="1666448292451" TEXT="tatsächlich mit LayoutManager integrieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672799750522" ID="ID_1514900067" MODIFIED="1672799760652" TEXT="LayoutManager(impl) ↔ Display-Evaluation ↔ ZoomWindow">
|
|
<arrowlink COLOR="#517488" DESTINATION="ID_650213030" ENDARROW="Default" ENDINCLINATION="515;561;" ID="Arrow_ID_113145433" STARTARROW="None" STARTINCLINATION="754;37;"/>
|
|
<arrowlink COLOR="#6bb1c5" DESTINATION="ID_382705289" ENDARROW="Default" ENDINCLINATION="782;41;" ID="Arrow_ID_1372440678" STARTARROW="None" STARTINCLINATION="441;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672799760652" ID="ID_891324479" MODIFIED="1678381593940" TEXT="Zoom-Window steuert DisplayMetric">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678381623392" ID="ID_222335481" MODIFIED="1678381792387" TEXT="Zusammenhang abstrahiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Habe mich hier für eine <i>komplett unterirdische Verbindung</i> entschieden, denn ich möchte keinesfalls den Layout-Manager zu einem sichtbaren Akteur ausbauen — ein »Layout-Manager« wäre eine derart offensichtliche zentrale Autorität, daß der Weg zur „Gott-Klasse“ nicht mehr weit ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576974013309" ID="ID_662883026" MODIFIED="1611478368089" TEXT="muß der Overview-Canvas überhaupt berücksichtigt werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#990000" CREATED="1576974036176" ID="ID_1084997647" MODIFIED="1611478475301" TEXT="wenn ja: dann hätten wir ein Problem mit remove()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dieses nämlich keine Koordinaten bekommt, und daher nicht weiß, in welchem Canvas das zu entfernde Widget steckt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1582926631295" ID="ID_1387833468" MODIFIED="1582926643826">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>wenn</i> das so relevant werden sollte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582926644653" ID="ID_365029590" MODIFIED="1582926660863" TEXT="...dann muß wohl an beide Sub-Canvas delegiert werden"/>
|
|
</node>
|
|
<node COLOR="#864e6a" CREATED="1576974796984" ID="ID_680399486" MODIFIED="1611478422761" TEXT="wenn nein wird die Sache einfach....">
|
|
<arrowlink COLOR="#efd0af" DESTINATION="ID_364410899" ENDARROW="Default" ENDINCLINATION="1299;64;" ID="Arrow_ID_1373879262" STARTARROW="None" STARTINCLINATION="477;28;"/>
|
|
<linktarget COLOR="#ec6f0c" DESTINATION="ID_680399486" ENDARROW="Default" ENDINCLINATION="172;6;" ID="Arrow_ID_465598539" SOURCE="ID_1473334633" STARTARROW="None" STARTINCLINATION="198;19;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1611478373512" ID="ID_1982297015" MODIFIED="1611478399631">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist auf <i>nein</i> hinausgelaufen....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582503247986" ID="ID_1081924103" MODIFIED="1582835894937" TEXT="Problem Covarianz Clip vs Widget">
|
|
<arrowlink COLOR="#66226c" DESTINATION="ID_1439869815" ENDARROW="Default" ENDINCLINATION="-760;97;" ID="Arrow_ID_655919678" STARTARROW="None" STARTINCLINATION="1574;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582503411035" HGAP="45" ID="ID_1293494572" MODIFIED="1582503470645" TEXT="der Canvas braucht nur ein Widget, wir aber konstruieren einen Clip" VSHIFT="22">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eigentlich brauchen wir den konkreten Typ nur für den ctor-Aufruf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1582833357879" ID="ID_35914064" MODIFIED="1666448220727">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Proof-of-Concept</u>: <i>grundsätzlich</i> lassen sich die Aufrufe so realisieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576974176981" ID="ID_1792139654" MODIFIED="1612031398076" TEXT="Kind-Widget-Offsets">
|
|
<linktarget COLOR="#5e57bd" DESTINATION="ID_1792139654" ENDARROW="Default" ENDINCLINATION="-2065;214;" ID="Arrow_ID_1917645572" SOURCE="ID_178738138" STARTARROW="None" STARTINCLINATION="-949;44;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576974190516" ID="ID_1324645925" MODIFIED="1582836038184" TEXT="welche Offsets treten konkret auf?"/>
|
|
<node COLOR="#435e98" CREATED="1582835948615" ID="ID_75969285" MODIFIED="1582926572549" TEXT="Kind-Offsets sind falsch">
|
|
<arrowlink COLOR="#38acd3" DESTINATION="ID_1855510589" ENDARROW="Default" ENDINCLINATION="-764;-101;" ID="Arrow_ID_1877663178" STARTARROW="None" STARTINCLINATION="570;60;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1576974515950" ID="ID_1628336999" MODIFIED="1576974623765" TEXT="gibt es ein gemeinsames Koordinatensystem?">
|
|
<arrowlink COLOR="#474293" DESTINATION="ID_1222461806" ENDARROW="Default" ENDINCLINATION="-912;90;" ID="Arrow_ID_890343372" STARTARROW="None" STARTINCLINATION="-1540;96;"/>
|
|
<node CREATED="1576975245489" ID="ID_1473334633" MODIFIED="1582926930308" TEXT="es läuft auf "nein" hinaus....">
|
|
<arrowlink COLOR="#ec6f0c" DESTINATION="ID_680399486" ENDARROW="Default" ENDINCLINATION="172;6;" ID="Arrow_ID_465598539" STARTARROW="None" STARTINCLINATION="198;19;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1576975314849" ID="ID_504699963" MODIFIED="1576975336570" TEXT="dann muß aber das relative-attachment hier adaptieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576975078209" ID="ID_272168913" MODIFIED="1582926869860" TEXT="suche Lösung für Koordinaten pro Canvas">
|
|
<linktarget COLOR="#406fc9" DESTINATION="ID_272168913" ENDARROW="Default" ENDINCLINATION="-1471;82;" ID="Arrow_ID_1415590908" SOURCE="ID_1095950959" STARTARROW="None" STARTINCLINATION="-1695;79;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1582503867646" ID="ID_1320872157" MODIFIED="1582926877646" TEXT="versuchen, das ViewHook-Konzept dafür nutzbar zu machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. der Versuch, die Probleme geschickt wegzuabstrahieren.
|
|
</p>
|
|
<p>
|
|
Außerdem ist ja beim Design des ViewHook aufgefallen, daß der Fall mit dem Positionieren per Koordinaten ehr der Spezialfall ist, und nicht der Basisfall, als welches er modlliert wurde...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582926842105" ID="ID_41570451" MODIFIED="1582926860190" TEXT="geht eigentlich ganz glatt auf">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582926889589" ID="ID_452794094" MODIFIED="1582926901582" TEXT="Ankerpunkt bereits im Basis-Interface ViewHook<WID>"/>
|
|
<node CREATED="1582926902478" ID="ID_1289395901" MODIFIED="1582926913092" TEXT="das Verketten wird damit Teil des Prinzips"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1576705946751" ID="ID_478555928" MODIFIED="1678407144057" TEXT="den re-Konstrkutions-Mechanismus realisieren">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#435e98" CREATED="1678406932620" ID="ID_1079071766" MODIFIED="1678407138241" TEXT="Stand 3/23: geplant und angelegt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Lösungsansatz ist entschieden...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
über das ViewHook-Interface ist die Verbindung zwischen Container und Element abstrahiert
|
|
</li>
|
|
<li>
|
|
darauf aufbauend werden zum Umordnen alle Elemente "beiseite geschoben" und neu eingehängt (in geänderter Reihenfolge)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
....<i>theoretisch sollte das so ohne Weiteres funktionieren.... </i>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font size="2">(habs gemäß Konzept schon so implementiert für das Track-Head,</font><br /><font size="2">aber noch nie geprüft, ob es auch tatsächlich funktioniert)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575050224708" ID="ID_1911321905" MODIFIED="1582988334867" TEXT="Trigger">
|
|
<linktarget COLOR="#6e8c9b" DESTINATION="ID_1911321905" ENDARROW="Default" ENDINCLINATION="-733;-208;" ID="Arrow_ID_528411186" SOURCE="ID_1886398385" STARTARROW="None" STARTINCLINATION="1622;164;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1575050232723" ID="ID_1373278767" MODIFIED="1575050241511" TEXT="Struktur-Änderung">
|
|
<node CREATED="1575050261439" ID="ID_1211501481" MODIFIED="1575050408505" TEXT="Sequenz der unmittelbaren Kinder geändert">
|
|
<linktarget COLOR="#1252d1" DESTINATION="ID_1211501481" ENDARROW="Default" ENDINCLINATION="54;39;" ID="Arrow_ID_407564614" SOURCE="ID_1445748451" STARTARROW="None" STARTINCLINATION="-41;-50;"/>
|
|
<node CREATED="1575050290679" ID="ID_1523080748" MODIFIED="1575050294573" TEXT="Reihenfolge"/>
|
|
<node CREATED="1575050279796" ID="ID_997158526" MODIFIED="1575050282831" TEXT="neues Kind"/>
|
|
<node CREATED="1575050283587" ID="ID_173333062" MODIFIED="1575050286863" TEXT="totes Kind"/>
|
|
</node>
|
|
<node CREATED="1575050302522" ID="ID_1068694513" MODIFIED="1575050313251" TEXT="mittelbar im Kind-Baum">
|
|
<node CREATED="1575050317354" ID="ID_1445748451" MODIFIED="1575050408504" TEXT="rekursiv zurückgeführt">
|
|
<arrowlink COLOR="#1252d1" DESTINATION="ID_1211501481" ENDARROW="Default" ENDINCLINATION="54;39;" ID="Arrow_ID_407564614" STARTARROW="None" STARTINCLINATION="-41;-50;"/>
|
|
</node>
|
|
<node CREATED="1575050424190" ID="ID_1324169888" MODIFIED="1575050472496" TEXT="Voraussetzungen">
|
|
<node CREATED="1575050474252" ID="ID_1248517025" MODIFIED="1575050474252" TEXT="Rekonstruktion ist lokal"/>
|
|
<node CREATED="1575050476163" ID="ID_389515387" MODIFIED="1575050496236" TEXT="Rekunstruktion wirkt nur auf einen Teilbaum abwärts"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1575050510878" ID="ID_350484232" MODIFIED="1575580714937" TEXT="Basis ist vom Diff-System zu leisten">
|
|
<arrowlink COLOR="#624d7d" DESTINATION="ID_101148427" ENDARROW="Default" ENDINCLINATION="-3637;-782;" ID="Arrow_ID_1277214644" STARTARROW="None" STARTINCLINATION="3792;340;"/>
|
|
<linktarget COLOR="#4d81bf" DESTINATION="ID_350484232" ENDARROW="Default" ENDINCLINATION="-77;-68;" ID="Arrow_ID_658076840" SOURCE="ID_932505699" STARTARROW="None" STARTINCLINATION="-201;12;"/>
|
|
<node COLOR="#338800" CREATED="1576168044826" ID="ID_1912653386" MODIFIED="1576441631231" TEXT="#1206 diff structure change listener">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" ID="ID_1999928728" MODIFIED="1557498707227" TEXT="Track-Anzeige">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_1999928728" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_506785204" SOURCE="ID_1131206858" STARTARROW="None" STARTINCLINATION="368;125;"/>
|
|
<linktarget COLOR="#7696bb" DESTINATION="ID_1999928728" ENDARROW="Default" ENDINCLINATION="113;285;" ID="Arrow_ID_198017810" SOURCE="ID_1389266781" STARTARROW="None" STARTINCLINATION="-139;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1480607033512" ID="ID_1815699851" MODIFIED="1557498707227" TEXT="Kopf">
|
|
<node CREATED="1540684299064" ID="ID_1911781593" MODIFIED="1557498707227" TEXT="Header-Pane">
|
|
<node CREATED="1540641296565" HGAP="31" ID="ID_991484939" MODIFIED="1557498707227" TEXT="NavigationWidget" VSHIFT="40">
|
|
<arrowlink DESTINATION="ID_1952536945" ENDARROW="Default" ENDINCLINATION="136;-157;" ID="Arrow_ID_1459742640" STARTARROW="None" STARTINCLINATION="112;0;"/>
|
|
<node CREATED="1540682850119" HGAP="39" ID="ID_1885212949" MODIFIED="1557498707227" TEXT="ein Grid">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540641305092" HGAP="50" ID="ID_18552766" MODIFIED="1557498707227" TEXT="PatchbayWidget" VSHIFT="-2">
|
|
<arrowlink DESTINATION="ID_151954769" ENDARROW="Default" ENDINCLINATION="263;-88;" ID="Arrow_ID_1923805019" STARTARROW="None" STARTINCLINATION="93;24;"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1540682893097" HGAP="65" ID="ID_419298158" MODIFIED="1557498707227" TEXT="interne Struktur" VSHIFT="11">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1540682901320" ID="ID_1054686680" MODIFIED="1557498707227" TEXT="stacked boxes?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1540682908088" ID="ID_785207504" MODIFIED="1557498707227" TEXT="table grid?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1540683803329" ID="ID_290204038" MODIFIED="1557498707227" TEXT="rekursive Struktur">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1540683824278" ID="ID_1473337838" MODIFIED="1675897700431" TEXT="ein Grid anfangs 3 Zeilen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1540683889813" ID="ID_1511067098" MODIFIED="1675897738578" TEXT="1Zeile (komplett) : Placement-Menü+Label">
|
|
<node CREATED="1541095855984" ID="ID_1032237384" MODIFIED="1557498707227" TEXT="verwendet ElementBoxWidget">
|
|
<arrowlink COLOR="#f6cca4" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-599;39;" ID="Arrow_ID_1199047781" STARTARROW="None" STARTINCLINATION="-698;-271;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540683900716" ID="ID_212914080" MODIFIED="1675897808377" TEXT="Zelle 2 | Spalte 2 : Controls"/>
|
|
<node CREATED="1540683829267" ID="ID_828415712" MODIFIED="1675897854794" TEXT="Zeile 3++">
|
|
<node CREATED="1675897911895" ID="ID_1127109872" MODIFIED="1675897937960" TEXT="leer auf Blatt-Ebene des Baumes"/>
|
|
<node CREATED="1540683879103" ID="ID_96481889" MODIFIED="1675897894389" TEXT="Sub-Track ⟹ eine nested HeaderPane"/>
|
|
<node CREATED="1675897858886" ID="ID_728481021" MODIFIED="1675897869225" TEXT="weitere Zeilen für jeden weiteren Kind-Track"/>
|
|
</node>
|
|
<node CREATED="1540683916490" ID="ID_191999039" MODIFIED="1675897842188" TEXT="linke Spalte : Fork-Struktur zeichnen"/>
|
|
<node CREATED="1563469351023" ID="ID_805950777" MODIFIED="1563469358660" TEXT="weitere Zeilen nach Bedarf....">
|
|
<node CREATED="1563469368703" ID="ID_856512794" MODIFIED="1563469385040" TEXT="jeder weitere Sub-Track hängt eine Zeile an"/>
|
|
<node CREATED="1563469415896" ID="ID_307382994" MODIFIED="1563469442614">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber verschachtelte sub-Tracks werden <i>in</i> dieser gehandhabt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563469388316" ID="ID_312880827" MODIFIED="1563469409266" TEXT="beim re-Konstruieren alle platt machen und neu besetzen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1540747470806" FOLDED="true" HGAP="97" ID="ID_831752558" MODIFIED="1557498707227" TEXT="Frage: Patchbay vs TrackHead?" VSHIFT="5">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1540747516509" ID="ID_1965076800" MODIFIED="1557498707227" TEXT="ist TrackHeadWidget überflüssig?">
|
|
<arrowlink COLOR="#6ba7db" DESTINATION="ID_415092517" ENDARROW="Default" ENDINCLINATION="-390;0;" ID="Arrow_ID_1346421423" STARTARROW="None" STARTINCLINATION="445;0;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1540747533463" ID="ID_1845120165" MODIFIED="1557498707227" TEXT="dann wäre TimelineHeader == PatchbayWidget"/>
|
|
<node CREATED="1540747550734" ID="ID_843399235" MODIFIED="1576282358067" TEXT="macht Sinn...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das Patchbay-Widget muß diverse Interna des Tracks beachten,
|
|
</p>
|
|
<p>
|
|
so z.B. sein Placement, welches <i>teilweise als Properties</i> des Track abgebildet wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540862631576" ID="ID_136673309" MODIFIED="1557498707227" TEXT="aber: Patchbay ist mehr als ein TrackHead">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1540862657930" ID="ID_505897358" MODIFIED="1557498707227" TEXT="das Scrollen nicht vergessen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1540862671211" ID="ID_1297724441" MODIFIED="1557498707227" TEXT="brauche eine Scroll-Pane ohne Scrolbar">
|
|
<node CREATED="1540862789523" ID="ID_1163137569" MODIFIED="1557498707227" TEXT="geht das?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1540863135984" ID="ID_1095034635" MODIFIED="1557498707227" TEXT="wohl nicht direkt"/>
|
|
<node CREATED="1540863146507" ID="ID_1788133857" MODIFIED="1557498707227" TEXT="ScrolledWindow verwendet Gtk::Viewport">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540863578545" ID="ID_1986597218" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-adjustments-easy.html.en" MODIFIED="1557498707227" TEXT="Tutorial: separate Scrollbar für TextView"/>
|
|
<node CREATED="1540863719920" ID="ID_1675657033" MODIFIED="1557498707227" TEXT="analog: das Adjustment von der BodyPane verwenden"/>
|
|
<node CREATED="1540863740331" ID="ID_432547471" MODIFIED="1557498707227" TEXT="und ein (passives) Adjustment für horizontal"/>
|
|
<node COLOR="#338800" CREATED="1540866723618" ID="ID_943818911" MODIFIED="1557498707227" TEXT="sofort im ctor verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540862691920" ID="ID_415092517" MODIFIED="1557498707227" TEXT="das ist dann sinnvollerweise die Patchbay als Ganzes">
|
|
<linktarget COLOR="#6ba7db" DESTINATION="ID_415092517" ENDARROW="Default" ENDINCLINATION="-390;0;" ID="Arrow_ID_1346421423" SOURCE="ID_1965076800" STARTARROW="None" STARTINCLINATION="445;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1553907064499" HGAP="11" ID="ID_1688412302" MODIFIED="1678026754379" TEXT="Fazit" VSHIFT="5">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1553907073255" ID="ID_1710444282" MODIFIED="1557498707227" TEXT="Patchbay ist ein Container für die Track Heads"/>
|
|
<node CREATED="1553907087204" ID="ID_752287871" MODIFIED="1563469756375" TEXT="zuständig für das Einhängen und das vertikale Scrolling"/>
|
|
<node CREATED="1678026759149" ID="ID_1362126122" MODIFIED="1678026778735" TEXT="künftig ggfs. auch für globale Belange">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
z.B. Folding
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563469593872" FOLDED="true" HGAP="84" ID="ID_1533093205" MODIFIED="1679082604804" TEXT="sub-Navigation" VSHIFT="1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1674161525129" ID="ID_1762683235" MODIFIED="1675897471975" TEXT="Grid-Zelle für die Placement-Controls vorsehen">
|
|
<linktarget COLOR="#463cb1" DESTINATION="ID_1762683235" ENDARROW="Default" ENDINCLINATION="624;37;" ID="Arrow_ID_1560223761" SOURCE="ID_1332292119" STARTARROW="None" STARTINCLINATION="129;-6;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1674170380401" HGAP="36" ID="ID_600466568" MODIFIED="1674170473951" TEXT="sollte dann doch besser in eine eigene Zeile" VSHIFT="-3">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wozu haben wir das Gtk::Grid
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674170423490" HGAP="62" ID="ID_1552228594" MODIFIED="1674170479627" TEXT="ist immer Zelle (1,1) ⟹ für vertikale Content-Anpassung nutzen" VSHIFT="-9">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675898002475" ID="ID_1561724587" MODIFIED="1675898068906" TEXT="verikalte Pos der sub-Tracks koordinieren">
|
|
<linktarget COLOR="#6493a2" DESTINATION="ID_1561724587" ENDARROW="Default" ENDINCLINATION="7;82;" ID="Arrow_ID_1646540229" SOURCE="ID_478580800" STARTARROW="None" STARTINCLINATION="-16;-50;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1675898071801" ID="ID_813971014" MODIFIED="1675898089191" TEXT="steuern per zusätzlicher Leerzeile unter den Placement-Controls">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1675898099757" ID="ID_1841035930" MODIFIED="1675898623818" TEXT="Konsequenz: Placement-Controls expandieren nie über Content-Höhe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head></head>
|
|
<body>
|
|
<p>
|
|
�� das ist <i>kein Fehler...</i><br>Da sie zuerst eingefügt
|
|
werden, und ohne vexpand() niemals zusätzlichen Platz aufgreifen, wird
|
|
das Grid insgesamt nur so hoch wie minimal nötig, und jedwedes
|
|
Alignment-Setting auf der Zelle mit den Placement-Controls bleibt
|
|
wirkungslos; anschließend wird die zusätzliche Zeile eingefügt und
|
|
aufgespreitzt, um den Kind-Navigationsbereich auf den Level des ersten
|
|
Kind-tracks runter zu drücken
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1675898226900" ID="ID_1938543250" MODIFIED="1675898245198" TEXT="Pufferplatzt wird immer darunter einngebracht"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675898265975" ID="ID_1633915372" LINK="#ID_1129757567" MODIFIED="1675898508287" TEXT="integriert in 2.Phase der DisplayEvaluation">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563469608318" ID="ID_174979019" MODIFIED="1675897507574" TEXT="zusätzliche sub-Tracks resultieren in zusätzlichen Zeilen">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1563469770472" ID="ID_1252550324" MODIFIED="1674170526467" TEXT="einfügen gemäß Zahl der Kind-Tracks">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1674170489677" ID="ID_1683231262" MODIFIED="1674170519062" TEXT="ab Zeile 2">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674170497184" ID="ID_904031404" MODIFIED="1674170560370" TEXT="jeweils auch den Platz für das Struktur-Diagramm mit anpassen">
|
|
<arrowlink COLOR="#5ba7d5" DESTINATION="ID_478580800" ENDARROW="Default" ENDINCLINATION="358;-30;" ID="Arrow_ID_776518349" STARTARROW="None" STARTINCLINATION="-77;131;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563469790905" ID="ID_1917094772" MODIFIED="1563469795921" TEXT="re-Konstruieren">
|
|
<node CREATED="1563469797573" ID="ID_615107402" MODIFIED="1563469801027" TEXT="platt machen"/>
|
|
<node CREATED="1563469807081" ID="ID_1454613932" MODIFIED="1563469830842" TEXT="auf erneutes Einfügen warten"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563469620357" ID="ID_530086217" MODIFIED="1679084608014" TEXT="Fork-Anzeige passend malen">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_530086217" ENDARROW="Default" ENDINCLINATION="-1511;-125;" ID="Arrow_ID_1923188182" SOURCE="ID_1575894780" STARTARROW="None" STARTINCLINATION="1147;124;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1563469700651" ID="ID_478580800" MODIFIED="1674513411592" TEXT="auf die richtige Höhe zielen">
|
|
<arrowlink COLOR="#6493a2" DESTINATION="ID_1561724587" ENDARROW="Default" ENDINCLINATION="7;82;" ID="Arrow_ID_1646540229" STARTARROW="None" STARTINCLINATION="-16;-50;"/>
|
|
<linktarget COLOR="#5ba7d5" DESTINATION="ID_478580800" ENDARROW="Default" ENDINCLINATION="358;-30;" ID="Arrow_ID_776518349" SOURCE="ID_904031404" STARTARROW="None" STARTINCLINATION="-77;131;"/>
|
|
<linktarget COLOR="#5a7c92" DESTINATION="ID_478580800" ENDARROW="Default" ENDINCLINATION="451;41;" ID="Arrow_ID_513449931" SOURCE="ID_1311832889" STARTARROW="None" STARTINCLINATION="481;-27;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675898638485" ID="ID_164545383" MODIFIED="1678063046265" TEXT="Strukturdiagramm rendern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1675898729441" ID="ID_1183614893" MODIFIED="1676047503876" TEXT="verwende direkt eine DrawingArea">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1675898738064" ID="ID_736159731" LINK="https://developer-old.gnome.org/gtkmm-tutorial/stable/chapter-drawingarea.html.en" MODIFIED="1675898751929" TEXT="Tutorial">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675901157415" ID="ID_1671076758" MODIFIED="1676047495780" TEXT="aber als Komponente abstrahiert">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1675901877549" ID="ID_1912760164" MODIFIED="1676042929930" TEXT="Name: StaveBracket">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
In Anspielung auf
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
eine Leiter
|
|
</li>
|
|
<li>
|
|
ein Notensystem (stave)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
<sup>(*)</sup> <i>stave</i> ist zwar selterner und ausgeprägt Brittisch, <i>staff</i>  wäre geläufiger. Aber <i>staff</i> versteht man heutzutage als Personal, wohingegen <i>stave</i> auch die Leitersprosse oder ein Vers in einem Gedicht sein könnte (BE und AE)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1675902281219" ID="ID_562499167" MODIFIED="1675902293521" TEXT="Zweck: Ausprägungen abstrahieren">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1675902368504" ID="ID_239257634" MODIFIED="1675902380758" TEXT="ggfs expanded/collapsed">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1675902382537" ID="ID_861207485" MODIFIED="1675902467097" TEXT="Anknüpfung für Sub-Tracks"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675902513027" ID="ID_1162268597" MODIFIED="1678063043688" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1675902520928" ID="ID_468397914" MODIFIED="1678063037542" TEXT="Basisfunktionalität">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1675902529503" FOLDED="true" ID="ID_544667587" MODIFIED="1678063124524" TEXT="draw()-Funktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1676045132371" ID="ID_1480458495" MODIFIED="1676045152492" TEXT="Bezugspunkt: Tutorial + BodyCanvasWidget"/>
|
|
<node COLOR="#338800" CREATED="1676045153720" ID="ID_1064401846" MODIFIED="1676047466829" TEXT="on_draw() überlagern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1676045162558" ID="ID_1938495472" LINK="#ID_1978068021" MODIFIED="1676046631665" TEXT="brauche Ausdehnng des Widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar die konkret wirksame Ausdehnung ⟹ meiner Analyse zufolge ist das get_width|height()
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
das ist die vom Framework gesetzte Allokation
|
|
</li>
|
|
<li>
|
|
aber vor dem Abspeichern bereits um Dekoration verringert
|
|
</li>
|
|
<li>
|
|
zuzüglich aller Anpassungen für das Flow-Layout
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1676046608013" ID="ID_1701009358" MODIFIED="1676047576094" TEXT="erst mal einfachen Platzhalter zeichnen">
|
|
<linktarget COLOR="#60a5a0" DESTINATION="ID_1701009358" ENDARROW="Default" ENDINCLINATION="234;0;" ID="Arrow_ID_1201169468" SOURCE="ID_1689678210" STARTARROW="None" STARTINCLINATION="8;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1676156477801" ID="ID_772056246" MODIFIED="1677851184706" TEXT="Grundstruktur zeichnen: Klammer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1676156693199" FOLDED="true" ID="ID_1410623513" MODIFIED="1677851190441" TEXT="geschwungene Kappen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1676156831767" FOLDED="true" ID="ID_1352090582" MODIFIED="1677284185352" TEXT="Problem: wie konstruieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1676156890344" ID="ID_324278944" MODIFIED="1676156912279" TEXT="Geheimwissen — wie so oft in der Typographie"/>
|
|
<node CREATED="1676156918897" ID="ID_489719344" LINK="https://en.wikipedia.org/wiki/List_of_musical_symbols" MODIFIED="1676156951217" TEXT="habe nur visuelle Beispiele — z.B. Wikipedia"/>
|
|
<node COLOR="#435e98" CREATED="1676164934114" ID="ID_1016418668" MODIFIED="1677364828075" TEXT="Konstruktion auf Basis Φ anlegen">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1677205470277" ID="ID_1204016759" MODIFIED="1677205474955" TEXT="Doppellinie">
|
|
<node CREATED="1677364438087" ID="ID_932649273" MODIFIED="1677364453281" TEXT="Gesamtbreite legt Dimensionen insgesamt fest"/>
|
|
<node CREATED="1677364389022" ID="ID_1623449329" MODIFIED="1677364408921" TEXT="dicker Balken ist Φ-minor der Gesamtbreite"/>
|
|
<node CREATED="1677364411435" ID="ID_781796888" MODIFIED="1677364434492" TEXT="dünner Balken ist Φ-minor des dicken Balkens"/>
|
|
</node>
|
|
<node CREATED="1677205476133" ID="ID_451249239" MODIFIED="1677205482653" TEXT="Hauptquadrat">
|
|
<node CREATED="1677205505659" ID="ID_1891862127" MODIFIED="1677205530156" TEXT="scale{ 1/(1-1/Φ) }"/>
|
|
<node CREATED="1677205538913" ID="ID_1613242195" MODIFIED="1677205581045" TEXT="vertikaler Minor ⟼ Endpunkt vertikale Linie"/>
|
|
</node>
|
|
<node CREATED="1677205616988" ID="ID_470162114" MODIFIED="1677205624711" TEXT="Außenkurve">
|
|
<node CREATED="1677205631010" ID="ID_1117749219" MODIFIED="1677205640109" TEXT="Sehne = Diagonale Hauptquadrat"/>
|
|
<node CREATED="1677205650958" ID="ID_155372806" MODIFIED="1677205703445" TEXT="Tangente: Spize ⟶ horiz.Minor Hauptquadrat"/>
|
|
<node CREATED="1677205740036" ID="ID_788217131" MODIFIED="1677364478714" TEXT="Zentrum konstruieren">
|
|
<node CREATED="1677205747920" ID="ID_1509790675" MODIFIED="1677205759434" TEXT="Lot auf Mitte der Diagonale"/>
|
|
<node CREATED="1677205764916" ID="ID_30297184" MODIFIED="1677205777594" TEXT="Lot auf Tangente an der Spitze"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677205625515" ID="ID_411317980" MODIFIED="1677205629214" TEXT="Innenkurve">
|
|
<node CREATED="1677205631010" ID="ID_780001839" MODIFIED="1677364489149" TEXT="Tangente = Diagonale Hauptquadrat"/>
|
|
<node CREATED="1677364496607" ID="ID_578436980" MODIFIED="1677364509846" TEXT="Tangente: Spize ⟶ vertikaler Minor Hauptquadrat"/>
|
|
</node>
|
|
<node CREATED="1676165507261" ID="ID_562483038" MODIFIED="1677190170688" TEXT="vom Einheitsvektor ausgehen">
|
|
<node CREATED="1677190210159" ID="ID_1346884569" MODIFIED="1677190317384" TEXT="Basiseinheit: Breite der Doppellinie"/>
|
|
<node CREATED="1677167813605" ID="ID_997308984" MODIFIED="1677167818070" TEXT="sauber eichen">
|
|
<node CREATED="1677190330303" ID="ID_885253503" MODIFIED="1677190343796" TEXT="Zielwert ≔ 1mm"/>
|
|
<node CREATED="1677205286217" ID="ID_1445174518" MODIFIED="1677205301480">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nominell: <b>96</b>dpi
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677167818898" ID="ID_1345692974" MODIFIED="1677190343808">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mein Display: <b>90</b>dpi
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ich habe beim Upgrade auf Debian-Stretch mal nachgemessen: tatsächlich hat mein Display 94dpi. Demnach wäre der andere weithin übliche Wert von 96dpi präziser. Jedoch bin ich nach mehreren Experimenten bei 90dpi geblieben, da für mich so die Schriftarten die „richtige Größe“ haben — das mag auch daran liegen, daß ich leicht kurzsichtig bin und typischeweise etwas näher am Bildschirm sitze.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1676164971685" ID="ID_1507492450" MODIFIED="1677284035539" TEXT="Problem: das ist Geometrie — in Formeln wird das ekelig komplex">
|
|
<arrowlink COLOR="#5152b9" DESTINATION="ID_202336910" ENDARROW="Default" ENDINCLINATION="-527;-15;" ID="Arrow_ID_977343845" STARTARROW="None" STARTINCLINATION="-163;204;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#dcb49d" COLOR="#990033" CREATED="1676165456820" ID="ID_1427913040" MODIFIED="1677283981558" TEXT="Alternative? in SVG konstruieren...">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1676165519603" ID="ID_376786419" MODIFIED="1677364763179" TEXT="Ziel...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1677364725006" ID="ID_768569378" MODIFIED="1677364747014" TEXT="von der Basisbreite ausgehend aufbauen"/>
|
|
<node CREATED="1676165528682" ID="ID_235151946" MODIFIED="1676165554904" TEXT="dann Koordinaten der Kreismittelpunkte abgreifen"/>
|
|
<node CREATED="1676165556446" ID="ID_211841098" MODIFIED="1676165562730" TEXT="...und numerisch übernehmen"/>
|
|
</node>
|
|
<node CREATED="1677205326328" ID="ID_1478270063" MODIFIED="1677205332495" TEXT="Konstruktion ausführen">
|
|
<node CREATED="1677364619517" ID="ID_769583838" MODIFIED="1677364632896" TEXT="zunächst am Nullpunkt anlegen mit Basis = 1mm"/>
|
|
<node CREATED="1677191805647" ID="ID_1613786140" MODIFIED="1677364656553" TEXT="numerische Koordinaten in SVG">
|
|
<arrowlink COLOR="#6f90b6" DESTINATION="ID_1597077699" ENDARROW="Default" ENDINCLINATION="-895;71;" ID="Arrow_ID_1698154465" STARTARROW="None" STARTINCLINATION="-1020;86;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677205333819" ID="ID_1685591638" MODIFIED="1677283853536" TEXT="mühsam ... Inkscape ist nicht das richtige Tool">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich kann zwar einrasten, aber ich kann weder um einen definierten Punkt drehen, noch kann ich Schnittpunkte ermitteln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e6ddbc" COLOR="#ff0000" CREATED="1677283856940" ID="ID_118538540" MODIFIED="1677283923821" TEXT="Abbruch : mein Design ist nicht mit adäquatem Aufwand umsetzbar">
|
|
<arrowlink COLOR="#cf74ac" DESTINATION="ID_165173262" ENDARROW="Default" ENDINCLINATION="-34;-68;" ID="Arrow_ID_1819141539" STARTARROW="None" STARTINCLINATION="-222;9;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677238756686" ID="ID_165173262" MODIFIED="1677283951972" TEXT="Alternative: CAD oder Geometrie-Software">
|
|
<linktarget COLOR="#cf74ac" DESTINATION="ID_165173262" ENDARROW="Default" ENDINCLINATION="-34;-68;" ID="Arrow_ID_1819141539" SOURCE="ID_118538540" STARTARROW="None" STARTINCLINATION="-222;9;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1677238769330" ID="ID_617917879" MODIFIED="1677238790265" TEXT="Software">
|
|
<node CREATED="1677238794907" FOLDED="true" ID="ID_1719994425" LINK="https://www.geogebra.org/" MODIFIED="1677244193493" TEXT="GeoGebra">
|
|
<arrowlink COLOR="#da185e" DESTINATION="ID_1078055608" ENDARROW="Default" ENDINCLINATION="-64;0;" ID="Arrow_ID_1447934837" STARTARROW="None" STARTINCLINATION="9;138;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1677238915023" ID="ID_953437888" MODIFIED="1677238928092" TEXT="Geometrie und Algebra Toolbox">
|
|
<node CREATED="1677240624402" ID="ID_515446896" MODIFIED="1677240641754" TEXT="Fokus auf Lehre / Schule"/>
|
|
<node CREATED="1677240642624" ID="ID_189832046" MODIFIED="1677240663713" TEXT="Aktivität : eine schrittweise Konstruktion oder Problemlösung"/>
|
|
<node CREATED="1677240664813" ID="ID_1212012977" MODIFIED="1677240675112" TEXT="viele Online-Ressourcen und Lehrmittel"/>
|
|
<node CREATED="1677240745370" ID="ID_128860" MODIFIED="1677240758719" TEXT="SVG-Export (und PNG, EPS, ...)"/>
|
|
</node>
|
|
<node CREATED="1677239908146" ID="ID_1839763021" MODIFIED="1677239917765" TEXT="Java / Swing-Applikation">
|
|
<node CREATED="1677242327780" ID="ID_1944426459" LINK="https://www.geogebra.org/classic" MODIFIED="1677242340669" TEXT="auch online als Web-Tool"/>
|
|
</node>
|
|
<node CREATED="1677239038943" ID="ID_1843905901" MODIFIED="1677239044954" TEXT="in Debian paketiert"/>
|
|
<node CREATED="1677242504444" ID="ID_1552853335" MODIFIED="1677243232265" TEXT="Dokumentation problematisch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1677242518868" ID="ID_361444559" MODIFIED="1677242527763" TEXT="es gibt eine Unmenge an Einzeltutorials"/>
|
|
<node CREATED="1677242528649" ID="ID_1133975830" MODIFIED="1677242536188" TEXT="kein richties Handbuch">
|
|
<node CREATED="1677242594624" ID="ID_741403940" MODIFIED="1677242644637" TEXT="nur sehr spezifische Lehrmaterialien">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"Mathe für 6-13 järige" etc
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677242603776" ID="ID_56189532" MODIFIED="1677242615900" TEXT="und jede Menge online-Aktivitäten, aber ohne Erklärung"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677242537008" ID="ID_910645802" MODIFIED="1677242546207" TEXT="diverse Links sind obsolet">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1677243177482" ID="ID_705204121" LINK="https://wiki.geogebra.org/en/Manual" MODIFIED="1677243238963" TEXT="»Geogebra Manual«">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1677243516505" ID="ID_953227506" MODIFIED="1677243647101" TEXT="grr... erklärt zwar jeden Button, aber nicht wie man damit arbeitet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677241885336" ID="ID_922881345" MODIFIED="1677241917669" TEXT="verwirrend">
|
|
<node CREATED="1677241919382" ID="ID_212507936" MODIFIED="1677241941020" TEXT="zwar numerische Anzeige, aber nicht editierbar"/>
|
|
<node CREATED="1677242720631" ID="ID_1715446782" MODIFIED="1677242734352" TEXT="es gibt ein "Konstruktionsprotokoll"">
|
|
<node CREATED="1677242735581" ID="ID_1534936589" MODIFIED="1677242750107" TEXT="Doppelklick öffnet einen Editor"/>
|
|
<node CREATED="1677242750955" ID="ID_1710116847" MODIFIED="1677242765269" TEXT="der bietet eins symbolische Notation, aber nirgends die Zahlenwerte"/>
|
|
<node CREATED="1677243712139" ID="ID_175318062" MODIFIED="1677243737909" TEXT="man kann einzelne Objekte per Zuweisung redefinieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
b = 0.6180339887498948482
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1677243789088" ID="ID_1550304217" MODIFIED="1677243866319" TEXT="aber man kann nicht einen Parameter ändern und die Konstruktion als Solche erhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man nachträglich einzelne Objekte modifiziert, ändern sicn nur diese, aber keine davon abhängigen weiteren Schritte der Konstruktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677243870078" ID="ID_1078055608" MODIFIED="1677244131861" TEXT="das heißt: man kann eine Konstruktion zwar machen, aber nicht korrigieren">
|
|
<linktarget COLOR="#da185e" DESTINATION="ID_1078055608" ENDARROW="Default" ENDINCLINATION="-64;0;" ID="Arrow_ID_1447934837" SOURCE="ID_1719994425" STARTARROW="None" STARTINCLINATION="9;138;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677238808005" FOLDED="true" ID="ID_1447394424" LINK="http://car.rene-grothmann.de/doc_en/download.html" MODIFIED="1677244191316" TEXT="CaR / CaRMetal">
|
|
<arrowlink COLOR="#d92b65" DESTINATION="ID_297781372" ENDARROW="Default" ENDINCLINATION="-296;0;" ID="Arrow_ID_1075588267" STARTARROW="None" STARTINCLINATION="40;58;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1677238883419" ID="ID_996300782" MODIFIED="1677238894961" TEXT="»Compass and Ruler«">
|
|
<node CREATED="1677238901406" ID="ID_1722907500" MODIFIED="1677238907188" TEXT="in Java geschriebene Engine"/>
|
|
<node CREATED="1677238907984" ID="ID_1026090446" MODIFIED="1677238912707" TEXT="einfache Konstruktionstool"/>
|
|
</node>
|
|
<node CREATED="1677238845913" ID="ID_843441309" MODIFIED="1677238866366" TEXT="CaR Metal : altenative Oberfläche">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1677238867829" ID="ID_943917483" MODIFIED="1677241856930" TEXT="keine Webseite / Doku mehr">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1677238875812" ID="ID_1852293959" MODIFIED="1677238881527" TEXT="aber paketiert in Debian"/>
|
|
<node CREATED="1677241653479" ID="ID_1785287496" MODIFIED="1677241732497" TEXT="einfache Konstruktionsmittel">
|
|
<node CREATED="1677241733629" ID="ID_71114216" MODIFIED="1677241738194" TEXT="Grade, Strecke, Winkel"/>
|
|
<node CREATED="1677241738953" ID="ID_1098408302" MODIFIED="1677241773986" TEXT=""point and shot"-Interface">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Anweisungen in der Statuszeile: wähle ersten Punkt, setze zweiten Punkt....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677241777330" ID="ID_424248281" MODIFIED="1677241786137" TEXT="Liste der Operationen, numerisch editierbar"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677241862331" ID="ID_297781372" MODIFIED="1677244098449" TEXT="komme damit nicht zurecht">
|
|
<linktarget COLOR="#d92b65" DESTINATION="ID_297781372" ENDARROW="Default" ENDINCLINATION="-296;0;" ID="Arrow_ID_1075588267" SOURCE="ID_1447394424" STARTARROW="None" STARTINCLINATION="40;58;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1677241973839" ID="ID_1096129274" MODIFIED="1677241987298" TEXT="kann zwar Punkte / Strecken numerisch definieren"/>
|
|
<node CREATED="1677242051018" ID="ID_684143104" MODIFIED="1677242075172" TEXT="auf Strecke eingerasteter Punkt numerisch nicht editierbar"/>
|
|
<node CREATED="1677241988241" ID="ID_1052932142" MODIFIED="1677241995958" TEXT="kann aber nicht eine Teilkonstruktion drehen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677238791314" ID="ID_732751692" LINK="https://wiki.freecad.org/Getting_started" MODIFIED="1677282549626" TEXT="FreeCAD">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1677238946963" ID="ID_872231218" MODIFIED="1677238966708" TEXT="3D-CAD Software für Bauteil-Konstruktion">
|
|
<node CREATED="1677238982982" ID="ID_778717508" MODIFIED="1677239008236" TEXT="Paradigma: dynamisch-funktional">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man zeichnet nicht, sondern man stellt eine Liste von Operationen zusammen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677244165006" ID="ID_726530336" MODIFIED="1677244170985" TEXT="sehr mächtig (und komplex)"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677244173653" ID="ID_1314330853" MODIFIED="1677282545474" TEXT="Versuch: Umgang lernen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1677244515831" ID="ID_475033609" MODIFIED="1677244547510" TEXT="Debian-oldstable ⟹ 0.18 / aktuell 0.20"/>
|
|
<node CREATED="1677244552626" ID="ID_1256925438" MODIFIED="1677244574933" TEXT="Hilfe aus der Applikation heraus funktioniert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
embedded browser control
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677246748493" ID="ID_764653557" MODIFIED="1677246767781" TEXT="siehe auch Notizen in Buster.mm">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1677244993104" ID="ID_1394628058" LINK="https://wiki.freecad.org/Workbenches" MODIFIED="1677246774020" TEXT="Konzept: Workbenches">
|
|
<node CREATED="1677246775288" ID="ID_632741732" MODIFIED="1677279255738" TEXT="für mich: Sketcher Workbench"/>
|
|
<node CREATED="1677279264883" ID="ID_1434090599" LINK="https://wiki.freecad.org/Basic_Sketcher_Tutorial" MODIFIED="1677279278124" TEXT="Basic Sketcher Tutorial">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677282525678" ID="ID_661917025" MODIFIED="1677282542592" TEXT="konnte meinen Design-Enwurf ohne Weiteres umsetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e2e4a6" COLOR="#338800" CREATED="1677283407557" ID="ID_1887076724" MODIFIED="1677283453893" TEXT="das Konzept mit den Constraints ist sehr intuitiv und elegant">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677282565360" ID="ID_1318516899" MODIFIED="1677282579408" TEXT="Aber: Integration ist problematisch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1677282651864" ID="ID_749202376" MODIFIED="1677282788849" TEXT="Applikation ist robust aber verhällt sich teilweise absonderlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das liegt vielleicht auch an der etwas „alten“ Version von ca. 2018.
|
|
</p>
|
|
<p>
|
|
Könnte aber auch auf grundsätzliche Limitierungen hinweisen; man hat eben vor allem an das Design von 3D-Bauteilen gedacht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677282582168" ID="ID_1875937065" MODIFIED="1677283406645" TEXT="Das UI ist nicht ausreichend konfigurierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das UI-Design ist vom konkreten Einzelfall-Nutzen ausgegangen, nicht von einem stimmigen Gesamtentwurf. Alles ist auf das Konstruieren von 3D-Bauteilen in typischem handlichen Format ausgelegt: eine kleine Zahl an Einzelobjekten im cm-Bereich....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Ich komme jetzt mit einer Konstruktion im Sub-Millimeter-Bereich, und ich bräuchte sich überlappende Formen ....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Anzeige-Handhabung wird dann "frickelig"
|
|
</li>
|
|
<li>
|
|
die Beschriftungen sind viel zu groß und lassen sich nicht sinnvoll platzieren
|
|
</li>
|
|
<li>
|
|
es gibt nur die starre Unterscheidung in »Hilfslinien« (construction) und »Geometrie«
|
|
</li>
|
|
<li>
|
|
letztere muß überschneidungsfrei sein
|
|
</li>
|
|
<li>
|
|
für mein Design habe ich dann ca 50 nummerierte Constraints, die anhand der Anzeige kaum mehr sinnvoll nachvollziehbar sind...
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677285183885" ID="ID_1263712065" MODIFIED="1677285326059" TEXT="Expressions, Objektmodell und Rererenzen lassen zu wünschen übrig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Geometrie-Elemente in den Sketch-Objekten sind eine Spezial-Implementierung, und keine »first class citizens«. Es ist nicht klar, wie man sie aus Expressions referenzieren kann (kein sauberes DSL-Design). Das Dependency-Management ist viel zu naiv implementiert, und es wird empfohlen, mit Tricks und Kniffen zu arbeiten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677284865478" ID="ID_1467561719" MODIFIED="1677285153626" TEXT="Contstraints und Expressions sind noch nicht vollständig entwickelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Eine Funktion, um eine Linie gemäß Proportion zu teilen, wird zwar oft gewünscht, ist aber derzeit (2022) noch in Entwicklung. Daher kann man im Moment nur eine feste Basislänge als benannter Constraint vorgeben, und dann andere Längen per Expression <font face="Monospaced" color="#1418c4">=Constraint.basis * (1+sqrt(5)/2</font>  daran binden. Außerdem kann man solche Expressions zwar einmal initial eigeben, dann aber nur noch über das XML editieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1677283111823" ID="ID_991289244" MODIFIED="1677283133867">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ ich kann das <b>Ergebnis nicht exportieren</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677283135738" ID="ID_924427179" MODIFIED="1677283153136" TEXT="läßt sich nicht in ein Bauteil übersetzen"/>
|
|
<node CREATED="1677283209076" ID="ID_1767198864" MODIFIED="1677283225596" TEXT="läßt sich nicht sinnvoll in eine technische Zeichnung integriern"/>
|
|
<node CREATED="1677283226896" ID="ID_1105190200" MODIFIED="1677283257013" TEXT="als Skizze verwendet ⟹ die Hilfslinien fehlen"/>
|
|
<node CREATED="1677283259677" ID="ID_1713241605" MODIFIED="1677283331779" TEXT="Export als »Flat SVG« scheitert mit einem Logikfehler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
a bytes-like object is required, not "str"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677283465368" ID="ID_1881375763" MODIFIED="1677283523222" TEXT="muß mir die Geometrie aus dem XML per Hand extrahieren">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677283530663" ID="ID_643259548" MODIFIED="1677284165733">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die konkrete Aufgabe ist mit FreeCAD elegant<br />— aber Resultate sind schwer zugänglich —
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node COLOR="#435e98" CREATED="1677283735683" ID="ID_202336910" MODIFIED="1677284152469" TEXT="die Konstruktionsmittel sind adäquat">
|
|
<linktarget COLOR="#5152b9" DESTINATION="ID_202336910" ENDARROW="Default" ENDINCLINATION="-527;-15;" ID="Arrow_ID_977343845" SOURCE="ID_1507492450" STARTARROW="None" STARTINCLINATION="-163;204;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677283745698" ID="ID_1707816095" MODIFIED="1677284160611" TEXT="die Konstruktion läßt sich leicht aufbauen"/>
|
|
<node CREATED="1677283756954" ID="ID_550771506" MODIFIED="1677283773330" TEXT="das Resultat ist aber schwer nachvollziehbar"/>
|
|
<node CREATED="1677283775971" ID="ID_906696321" MODIFIED="1677283797495" TEXT="die Konstruktion kann nicht exportiert oder sauber dargestellt werden"/>
|
|
<node COLOR="#435e98" CREATED="1677283798612" ID="ID_178736804" MODIFIED="1677284158056" TEXT="letztlich habe ich nur die Koordinaten im XML">
|
|
<arrowlink COLOR="#d93353" DESTINATION="ID_314954569" ENDARROW="Default" ENDINCLINATION="229;0;" ID="Arrow_ID_1387442926" STARTARROW="None" STARTINCLINATION="-193;12;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677284059069" ID="ID_239372381" MODIFIED="1677284076170" TEXT="in diesem konkreten Fall brauche ich nur ein paar numerische Koordinaten"/>
|
|
<node CREATED="1677284078398" ID="ID_314954569" MODIFIED="1677284135625" TEXT="die habe ich jetzt (manuell aus dem XML entnehmen)">
|
|
<arrowlink COLOR="#4e50ba" DESTINATION="ID_175092425" ENDARROW="Default" ENDINCLINATION="20;-39;" ID="Arrow_ID_1002715155" STARTARROW="None" STARTINCLINATION="-95;5;"/>
|
|
<linktarget COLOR="#d93353" DESTINATION="ID_314954569" ENDARROW="Default" ENDINCLINATION="229;0;" ID="Arrow_ID_1387442926" SOURCE="ID_178736804" STARTARROW="None" STARTINCLINATION="-193;12;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677284093289" ID="ID_445049749" MODIFIED="1677284109270" TEXT="Fazit: keine generell brauchbare Lösung">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677331147847" ID="ID_175092425" MODIFIED="1677370706976" TEXT="ermittelte Koordinaten extrahieren">
|
|
<linktarget COLOR="#4e50ba" DESTINATION="ID_175092425" ENDARROW="Default" ENDINCLINATION="20;-39;" ID="Arrow_ID_1002715155" SOURCE="ID_314954569" STARTARROW="None" STARTINCLINATION="-95;5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677331237859" ID="ID_437122420" MODIFIED="1677332146589" TEXT="bezogen auf Linienweite == 1mm">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_437122420" ENDARROW="Default" ENDINCLINATION="352;0;" ID="Arrow_ID_881918480" SOURCE="ID_21344516" STARTARROW="None" STARTINCLINATION="368;-26;"/>
|
|
</node>
|
|
<node CREATED="1677364959969" ID="ID_369230805" MODIFIED="1677364964269" TEXT="Doppellinie">
|
|
<node CREATED="1677365146529" ID="ID_615879743" MODIFIED="1677365149756" TEXT="Balken">
|
|
<node CREATED="1677365150864" ID="ID_721966969" MODIFIED="1677365152884" TEXT="links">
|
|
<node CREATED="1677365787195" ID="ID_372898739" MODIFIED="1677365789420" TEXT="-0.3819660112501033"/>
|
|
</node>
|
|
<node CREATED="1677365153860" ID="ID_1720144005" MODIFIED="1677365157523" TEXT="Breite">
|
|
<node CREATED="1677366839611" ID="ID_1835454334" MODIFIED="1677366839611" TEXT="0.3819660112501033"/>
|
|
<node CREATED="1677861231484" ID="ID_1930167405" MODIFIED="1677861233712" TEXT="Φ-minor"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677365163942" ID="ID_1262283150" MODIFIED="1677365167810" TEXT="Linie">
|
|
<node CREATED="1677365150864" ID="ID_786192191" MODIFIED="1677365152884" TEXT="links">
|
|
<node CREATED="1677366744194" ID="ID_576965784" MODIFIED="1677366744194" TEXT="0.4721359549995793"/>
|
|
<node CREATED="1677861270767" ID="ID_1949339527" MODIFIED="1677861283377" TEXT="Φ-major - Breite"/>
|
|
</node>
|
|
<node CREATED="1677365153860" ID="ID_595356019" MODIFIED="1677365157523" TEXT="Breite">
|
|
<node CREATED="1677366786332" ID="ID_1751894187" MODIFIED="1677366789785" TEXT="0.1458980337503155"/>
|
|
<node CREATED="1677861251177" ID="ID_211146367" MODIFIED="1677861259039" TEXT="(Φ-minor)²"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677366276186" ID="ID_457752414" MODIFIED="1677366882793" TEXT="rechts">
|
|
<node CREATED="1677366281105" ID="ID_1207712165" MODIFIED="1677366283333" TEXT="0.6180339887498948"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677364965121" ID="ID_800468010" MODIFIED="1677364972443" TEXT="Hauptquadrat">
|
|
<node CREATED="1677364975639" ID="ID_980972277" MODIFIED="1677365000890" TEXT="Gesamtbreite">
|
|
<node CREATED="1677365581447" ID="ID_1536779924" MODIFIED="1677365584420" TEXT="2.6180339887498953"/>
|
|
<node CREATED="1677365948797" ID="ID_439638462" MODIFIED="1677365956616" TEXT="Φ²"/>
|
|
</node>
|
|
<node CREATED="1677365002626" ID="ID_1214050837" MODIFIED="1677365013534" TEXT="Φ-minor">
|
|
<node CREATED="1677365873056" ID="ID_21344516" MODIFIED="1677365942712" TEXT="1.0">
|
|
<arrowlink DESTINATION="ID_437122420" ENDARROW="Default" ENDINCLINATION="352;0;" ID="Arrow_ID_881918480" STARTARROW="None" STARTINCLINATION="368;-26;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677365024897" ID="ID_1080324350" MODIFIED="1677365030156" TEXT="Spitze">
|
|
<node CREATED="1677366042929" ID="ID_931394195" MODIFIED="1677861076642" TEXT="Φ² - Φ-minor">
|
|
<node CREATED="1677366042929" ID="ID_861341963" MODIFIED="1677861104342" TEXT="2.2360679774997880"/>
|
|
</node>
|
|
<node CREATED="1677366091306" ID="ID_1220515657" MODIFIED="1677861059471" TEXT="Φ²">
|
|
<node CREATED="1677366091306" ID="ID_1245813830" MODIFIED="1677861105707" TEXT="2.6180339887498931"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677365057285" ID="ID_1262105297" MODIFIED="1677365060840" TEXT="Mitte">
|
|
<node CREATED="1677861431937" ID="ID_734498141" MODIFIED="1677861482575" TEXT="Φ²/2 - Φ-minor">
|
|
<node CREATED="1677366380685" ID="ID_1473309857" MODIFIED="1677366382633" TEXT="0.9270509831248426"/>
|
|
</node>
|
|
<node CREATED="1677861472620" ID="ID_462202557" MODIFIED="1677861478375" TEXT="Φ²/2">
|
|
<node CREATED="1677366414197" ID="ID_980628298" MODIFIED="1677861494360" TEXT="1.3090169943749477"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677366530209" ID="ID_1369679680" MODIFIED="1677861872506" TEXT="Auge">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mitte der »Oberdiogonalen«, d.h die Diagonale durch das obere Rechteck mit Höhe Φ-major und voller Breite
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677366380685" ID="ID_1234225514" MODIFIED="1677366604271" TEXT="0.9270509831248426"/>
|
|
<node CREATED="1677366596379" ID="ID_888978877" MODIFIED="1677366596379" TEXT="1.8090169943749466"/>
|
|
<node CREATED="1677861748026" ID="ID_686856800" MODIFIED="1677861797202" TEXT="1 + (Φ²-1)/2 = 1+Φ/2"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677365073270" ID="ID_1583254932" MODIFIED="1677365077542" TEXT="Außenbogen">
|
|
<node CREATED="1677365085156" ID="ID_653816127" MODIFIED="1677365088556" TEXT="Zentrum">
|
|
<node CREATED="1677861176926" ID="ID_1292417077" MODIFIED="1677861194492" TEXT="-(Φ+3)">
|
|
<node CREATED="1677366982576" ID="ID_1594210270" MODIFIED="1677366982576" TEXT="-4.6180339887498949"/>
|
|
</node>
|
|
<node CREATED="1677366993247" ID="ID_712675731" MODIFIED="1677366993247" TEXT="6.8541019662496847"/>
|
|
</node>
|
|
<node CREATED="1677365089489" ID="ID_1183768368" MODIFIED="1677365092867" TEXT="Radius">
|
|
<node CREATED="1677367032877" ID="ID_818254257" MODIFIED="1677367032877" TEXT="8.0574801069408135"/>
|
|
</node>
|
|
<node CREATED="1677365093931" ID="ID_1368458373" MODIFIED="1677365099512" TEXT="Bogen">
|
|
<node CREATED="1677368264383" ID="ID_1877634925" MODIFIED="1677368499104" TEXT="jeweils in Radians">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
↶ freeCAD : rechtsdrehend(mathematisch)
|
|
</p>
|
|
<p>
|
|
↻ SVG : linksdrehend(im Uhrzeigersinn)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1677373465002" ID="ID_524475211" LINK="#ID_1744669640" MODIFIED="1677373610517" TEXT="SVG-Format (Bogen)"/>
|
|
</node>
|
|
<node CREATED="1677365101279" ID="ID_309582280" MODIFIED="1677365104554" TEXT="start">
|
|
<node CREATED="1677367072268" ID="ID_388732438" MODIFIED="1677368175707" TEXT="↶ 5.7296109482825415"/>
|
|
<node CREATED="1677368199136" ID="ID_1326605326" MODIFIED="1677368257564" TEXT="↻ 0.55357435889704497693"/>
|
|
</node>
|
|
<node CREATED="1677365105470" ID="ID_1213567454" MODIFIED="1677365108865" TEXT="ende">
|
|
<node CREATED="1677367057705" ID="ID_91931169" MODIFIED="1677368179501" TEXT="↶ 5.2659633392817353"/>
|
|
<node CREATED="1677368224317" ID="ID_1444212890" MODIFIED="1677368744466" TEXT="↻ 1.01722196789785117693"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677365078501" ID="ID_955005504" MODIFIED="1677365081405" TEXT="Innenbogen">
|
|
<node CREATED="1677365085156" ID="ID_813159851" MODIFIED="1677365088556" TEXT="Zentrum">
|
|
<node CREATED="1677368552079" ID="ID_1476258553" MODIFIED="1677368612404" TEXT="-2.5"/>
|
|
<node CREATED="1677368596904" ID="ID_1839296871" MODIFIED="1677368596904" TEXT="7.3541019662496883"/>
|
|
</node>
|
|
<node CREATED="1677365089489" ID="ID_890819800" MODIFIED="1677365092867" TEXT="Radius">
|
|
<node CREATED="1677368633644" ID="ID_500144152" MODIFIED="1677368633644" TEXT="6.6978115661011230"/>
|
|
</node>
|
|
<node CREATED="1677365093931" ID="ID_685249674" MODIFIED="1677365099512" TEXT="Bogen">
|
|
<node CREATED="1677365101279" ID="ID_1674682593" MODIFIED="1677365104554" TEXT="start">
|
|
<node CREATED="1677367072268" ID="ID_1866888240" MODIFIED="1677368682376" TEXT="↶ 5.4977871437821380"/>
|
|
<node CREATED="1677368199136" ID="ID_900568930" MODIFIED="1677368772734" TEXT="↻ 0.78539816339744847693"/>
|
|
</node>
|
|
<node CREATED="1677365105470" ID="ID_1589081319" MODIFIED="1677365108865" TEXT="ende">
|
|
<node CREATED="1677367057705" ID="ID_16066835" MODIFIED="1677368698709" TEXT="↶ 5.0341395347813327"/>
|
|
<node CREATED="1677368224317" ID="ID_368023948" MODIFIED="1677368739395" TEXT="↻ 1.24904577239825377693"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677284189119" ID="ID_848175311" MODIFIED="1677984956527" TEXT="Dokumentation im SVG darstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677285339149" ID="ID_622350527" MODIFIED="1677373894578" TEXT="manuell die Koordinaten ins SVG reinschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677336149759" ID="ID_436410709" MODIFIED="1677336194334" TEXT="Konstruktion vollständig anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677336159392" ID="ID_721716534" MODIFIED="1677336193101" TEXT="Elemente im SVG konsistent reorganisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1677336199897" ID="ID_1876418381" MODIFIED="1677336290693" TEXT="Gruppe r_trans für die Platzierung auf der Seite"/>
|
|
<node COLOR="#435e98" CREATED="1677336215871" ID="ID_142480272" MODIFIED="1677336290694" TEXT="Gruppe_r_ref umfaßt die Konstruktion und trägt den Style"/>
|
|
<node COLOR="#435e98" CREATED="1677336240060" ID="ID_1544427721" MODIFIED="1677336290694" TEXT="Gruppe r_rubline für die vertikale Doppelline"/>
|
|
<node COLOR="#435e98" CREATED="1677336251555" ID="ID_595975745" MODIFIED="1677336290694" TEXT="Gruppe r_mainsquare für das die Klammer umschliepende Quadrat"/>
|
|
<node COLOR="#435e98" CREATED="1677336274103" ID="ID_1407156022" MODIFIED="1677336290694" TEXT="Gruppe r_construct für die Hilfskonstruktion"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677373822502" ID="ID_451537185" MODIFIED="1677373832016" TEXT="Koordinaten reinkleben und runden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677373465002" ID="ID_863876376" LINK="#ID_1744669640" MODIFIED="1677373847959" TEXT="SVG-Format (Bogen)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677285356443" ID="ID_1264869426" MODIFIED="1677969711023" TEXT="von diesen Eckpunkten ausgehend die Konstruktion rekonstruieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677373881642" ID="ID_1218195679" MODIFIED="1677373890994" TEXT="skalieren mit Faktor 10">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677969712922" ID="ID_1925495036" MODIFIED="1677969746070" TEXT="platzieren nach (50, 70)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677969764690" ID="ID_1467582175" MODIFIED="1677969832530" TEXT="Beschriftung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677969777393" ID="ID_1079168037" MODIFIED="1677969793058" TEXT="Φ und Φ² anzeigen"/>
|
|
<node CREATED="1677969815402" ID="ID_1142467839" MODIFIED="1677969819526" TEXT="square_minor"/>
|
|
<node CREATED="1677969794531" ID="ID_36594722" MODIFIED="1677969823012" TEXT="base_width"/>
|
|
<node CREATED="1677969824779" ID="ID_1673607654" MODIFIED="1677969829494" TEXT="origin"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677984963525" ID="ID_1359201455" MODIFIED="1677984979078" TEXT="die Konstruktion textuell beschreiben (im TiddlyWiki)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677285374042" ID="ID_597185643" MODIFIED="1677984959942" TEXT="Maßgabe: jemand anders soll diese Konstruktion verstehen können">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677285400989" ID="ID_771507385" MODIFIED="1677775780712" TEXT="Koordinaten direkt in den Cairo-Zeichencode übernehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677417336095" ID="ID_953306031" MODIFIED="1677425935036" TEXT="Einrichtung : Zeichnen gefüllter Formen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677417369338" ID="ID_711895669" LINK="https://www.cairographics.org/tutorial/" MODIFIED="1677771883067" TEXT="siehe Zeichenkonzepte in Cairo">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Cairo Zeichen-Operationen sind modelliert als Druckvorgang
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
ein Pfad definiert die Maske
|
|
</li>
|
|
<li>
|
|
durch diese hindurch wird die <i>Source</i> auf die <i>Surface</i>  (Ausgabe) gestempelt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6460c9" DESTINATION="ID_1173541827" ENDARROW="Default" ENDINCLINATION="-1791;132;" ID="Arrow_ID_1651743539" STARTARROW="None" STARTINCLINATION="-2602;211;"/>
|
|
</node>
|
|
<node CREATED="1677417491547" ID="ID_832294440" MODIFIED="1677417510732" TEXT="ein geschlossener Path erzeugt eine Maske, die gefüllt wird">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1677771904411" ID="ID_1955328342" MODIFIED="1677771918204" TEXT="per Transformation kann ein virtuelles Koordinatensystem erzeugt werden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426171012" ID="ID_183450251" MODIFIED="1677426297532" TEXT="Benennung">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1677426176707" ID="ID_1699845140" MODIFIED="1677426300779" TEXT="bleibe bei »Außenbogen« und »Innenbogen«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil ich diese Benennungen von Anfang an auch so in FreeCAD verwendet habe, und jetzt nicht alles umbenennen möchte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677426194737" ID="ID_465793703" MODIFIED="1677426300779" TEXT="mache aber die umgekehrte Ordnung im Kommentar klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist nämlich potentiell verwirrend: der <i>Außenbogen</i>  bildet die <i>Innenkontur<b> </b></i>der Klammer, weil der Schwung von der Klammer weg nach oben bzw. unten geht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677425937349" ID="ID_368774299" MODIFIED="1677718382736" TEXT="Koordinaten als Konstanten übernehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677426110196" ID="ID_843421619" MODIFIED="1677426129464" TEXT="Erkennbare Basiseinheiten durch Φ ausdrücken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426131233" ID="ID_231769096" MODIFIED="1677718377099" TEXT="BAR">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_231769096" ENDARROW="Default" ENDINCLINATION="-186;54;" ID="Arrow_ID_1647326271" SOURCE="ID_270081654" STARTARROW="None" STARTINCLINATION="120;19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426131233" ID="ID_1111801677" MODIFIED="1677718378915" TEXT="LINE">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1111801677" ENDARROW="Default" ENDINCLINATION="-186;54;" ID="Arrow_ID_1520723305" SOURCE="ID_1333503744" STARTARROW="None" STARTINCLINATION="71;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426140000" ID="ID_916071681" MODIFIED="1677718380765" TEXT="SQUARE">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426145410" ID="ID_1241973163" MODIFIED="1677426155118" TEXT="ARC_I">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426150023" ID="ID_1243678552" MODIFIED="1677426155119" TEXT="ARC_O">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677425955233" ID="ID_898214588" MODIFIED="1677425968693" TEXT="Funktion zum Zeichnen der Kappe(n)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677425981509" ID="ID_63989852" MODIFIED="1677426000480" TEXT="wendet low-Level-Skalierung an">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426001458" ID="ID_1476057716" MODIFIED="1677426010466" TEXT="implementiert Bogensegmente">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677426011889" ID="ID_106770327" MODIFIED="1677426024465" TEXT="Cairo bietet beide Drehrichtungen an">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1677426025872" ID="ID_217470533" MODIFIED="1677426037264" TEXT="aber wir müssen einen geschlossenen Pfad zeichnen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677426040749" ID="ID_1140979110" MODIFIED="1677426066194" TEXT="zeichne erst den äußeren Bogen, dann den inneren Bogen zurück">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426076977" ID="ID_22251519" MODIFIED="1677426088890" TEXT="visueller Test : Ergebnis plausibel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426582635" ID="ID_78847857" MODIFIED="1677861018300" TEXT="Balken zeichnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677426794738" ID="ID_270081654" MODIFIED="1677861020212" TEXT="dicker Balken">
|
|
<arrowlink DESTINATION="ID_231769096" ENDARROW="Default" ENDINCLINATION="-186;54;" ID="Arrow_ID_1647326271" STARTARROW="None" STARTINCLINATION="120;19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426794738" ID="ID_1333503744" MODIFIED="1677861022079" TEXT="dünne Linie">
|
|
<arrowlink DESTINATION="ID_1111801677" ENDARROW="Default" ENDINCLINATION="-186;54;" ID="Arrow_ID_1520723305" STARTARROW="None" STARTINCLINATION="71;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426603105" ID="ID_243044944" MODIFIED="1678054539122" TEXT="Gesamtanordnung steuern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677458294653" ID="ID_1105975491" MODIFIED="1677851113897" TEXT="brauche Zugriff auf Layout-Steuerung">
|
|
<arrowlink COLOR="#5586b2" DESTINATION="ID_883997565" ENDARROW="Default" ENDINCLINATION="108;-242;" ID="Arrow_ID_1785981386" STARTARROW="None" STARTINCLINATION="-291;20;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426726852" ID="ID_1196135559" MODIFIED="1677861006427" TEXT="Klammer sinnvoll positionieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677426763414" FOLDED="true" ID="ID_591151065" MODIFIED="1677775763826" TEXT="Balken-Länge">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1677718715763" FOLDED="true" ID="ID_354383908" MODIFIED="1677775372224" TEXT="Balken ist unten zu kurz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber der Code schaut <i>komplett richtig</i> aus; man muß ja die Differenz zwischen oberem und unterem Anker als Höhe ansetzen, und man muß dabei bedenken, daß die Zeichnung des Balkens dann skaliert wird, jedoch <i>nach Skalierung</i> genau bis zum unteren Anker reichen soll (und eben dieses funktioniert nicht)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1677773935683" ID="ID_962519428" MODIFIED="1677775318994" TEXT="Beobachtung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1677773960728" ID="ID_212260747" MODIFIED="1677773975135" TEXT="(w,h) = (30,12)"/>
|
|
<node CREATED="1677773939755" ID="ID_1896356153" MODIFIED="1677773951614" TEXT="scale=5.625"/>
|
|
<node COLOR="#338800" CREATED="1677774010934" ID="ID_369296092" MODIFIED="1677774057367" TEXT="left=2.1485588132818414">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677774080400" ID="ID_288963687" MODIFIED="1677774134353" TEXT="upper=14.726441186718159">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1677774169532" ID="ID_836073358" MODIFIED="1677774175875" TEXT="lower=29.452882373436317">
|
|
<node CREATED="1677774513323" ID="ID_1581390277" MODIFIED="1677774963008" TEXT="das ist die Fallback-Min-Height">
|
|
<linktarget COLOR="#e32757" DESTINATION="ID_1581390277" ENDARROW="Default" ENDINCLINATION="92;0;" ID="Arrow_ID_1988182153" SOURCE="ID_401418051" STARTARROW="None" STARTINCLINATION="92;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677774822709" ID="ID_660710029" MODIFIED="1677774826026" TEXT="drawBar">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#a21b22" CREATED="1677774833327" ID="ID_1452011719" MODIFIED="1677775343109" TEXT="height=2">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677774837611" ID="ID_1315743678" MODIFIED="1677774848361" TEXT="AUA: das ist ein Int">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1677775070456" ID="ID_224207909" MODIFIED="1677775323625" TEXT="linkes Argument von min ist int{0}"/>
|
|
<node CREATED="1677775094584" ID="ID_713816284" MODIFIED="1677775117646" TEXT="das ist mein util::min (implicit conversion)"/>
|
|
</node>
|
|
<node CREATED="1677774892926" ID="ID_1618649666" MODIFIED="1677774904662" TEXT="lower-upper == upper">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677774946622" ID="ID_401418051" MODIFIED="1677774969807" TEXT="Denkfehler im Fallback">
|
|
<arrowlink COLOR="#e32757" DESTINATION="ID_1581390277" ENDARROW="Default" ENDINCLINATION="92;0;" ID="Arrow_ID_1988182153" STARTARROW="None" STARTINCLINATION="92;0;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677774909790" ID="ID_1344204520" MODIFIED="1677774937023" TEXT="/ scale = Φ+1"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677775347540" ID="ID_483885409" MODIFIED="1677775363174" TEXT="Zeichenfehler damit behoben...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es war der int vs double
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677775374922" FOLDED="true" ID="ID_758069702" MODIFIED="1677775760407" TEXT="Zweifel: verwenden Gtk und Cairo die gleichen »device units«?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1677775564913" ID="ID_933287576" MODIFIED="1677775585136" TEXT="Beobachte Höhe = 12, allerdings nur im ersten Durchlauf"/>
|
|
<node CREATED="1677775586262" ID="ID_712638262" MODIFIED="1677775598515" TEXT="im zweiten Durchlauf ist die kleinste Höhe = 62"/>
|
|
<node COLOR="#338800" CREATED="1677775730195" ID="ID_42889671" MODIFIED="1677775753486" TEXT="nachgemessen: 62px ist die kleinste Höhe im final sichtbaren GUI">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426770828" ID="ID_515832295" MODIFIED="1677718397562" TEXT="Ober/Unterkappe">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426740361" FOLDED="true" ID="ID_1498455508" MODIFIED="1678063029999" TEXT="Ankerpunkt für Sub-Scopes">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1678027707725" ID="ID_1088634692" MODIFIED="1678027911538" TEXT="Informationsfluß?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1678027725255" ID="ID_244001513" MODIFIED="1678027744477" TEXT="Ankerpunkt-Höhe zu setzen auf der aktuellen StaveBracket"/>
|
|
<node CREATED="1678027785347" ID="ID_1776470057" MODIFIED="1678027806812" TEXT="Quelle ist der aktuelle relative Offset des Child-Track"/>
|
|
<node CREATED="1678027811599" ID="ID_137446567" MODIFIED="1678027856711" TEXT="alle Info liegt lokal vor ⟹ im Display-Evaluation-Pass">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678027913100" ID="ID_1469793297" MODIFIED="1678054528877" TEXT="Aktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#5b280f" CREATED="1678027923050" ID="ID_290002506" MODIFIED="1678028880024" TEXT="Ankerpunkt als Solchen vorsehen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1678027936823" ID="ID_1498868700" MODIFIED="1678027946209" TEXT="attach|detach SubFork"/>
|
|
<node CREATED="1678028843581" ID="ID_1168167530" MODIFIED="1678028951827" TEXT="überflüssig: bringt eigentlich nix">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir müssen sowiso einen globalen Pass machen, und zwar erst spät, wenn das Layout bereits komplett geregelt ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#903134" DESTINATION="ID_1168167530" ENDARROW="Default" ENDINCLINATION="226;18;" ID="Arrow_ID_982689463" SOURCE="ID_1938349456" STARTARROW="None" STARTINCLINATION="81;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678027951474" ID="ID_1668829531" MODIFIED="1678054530558" TEXT="Ankerpunkt-Höhe präzise festsetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1678028166248" ID="ID_1827737851" MODIFIED="1678028674353">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">TrackHeadWidget::syncSubtrackStartHeight (uint directHeight)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#bc2454" DESTINATION="ID_1938349456" ENDARROW="Default" ENDINCLINATION="-147;6;" ID="Arrow_ID_969124444" STARTARROW="None" STARTINCLINATION="-99;5;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1678028227991" ID="ID_1354143607" MODIFIED="1678028733057">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⤷ <i>kommend von</i> <font face="Monospaced" size="2">DisplayFrame::sync_and_balance (DisplayEvaluation&)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1678028276056" ID="ID_641317895" MODIFIED="1678028291624" TEXT="2. Pass der DisplayEvaluation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1678028495768" ID="ID_1391860613" MODIFIED="1678028514740" TEXT="Reihenfolge OK: depth-first-Postfix">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1678028348927" ID="ID_942182996" MODIFIED="1678028413547" TEXT="liefert aber nur den relativen Offset des sub-Track-Bereichs"/>
|
|
<node CREATED="1678028377219" ID="ID_1791569099" MODIFIED="1678028406664" TEXT="muß zudem auch die konkrete Höhe der einzelnen sub-Tracks propagieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1678028613860" ID="ID_1938349456" MODIFIED="1678028956492" TEXT="also doch besser dann als Operation für den ganzen Track-Head">
|
|
<arrowlink COLOR="#903134" DESTINATION="ID_1168167530" ENDARROW="Default" ENDINCLINATION="226;18;" ID="Arrow_ID_982689463" STARTARROW="None" STARTINCLINATION="81;0;"/>
|
|
<linktarget COLOR="#bc2454" DESTINATION="ID_1938349456" ENDARROW="Default" ENDINCLINATION="-147;6;" ID="Arrow_ID_969124444" SOURCE="ID_1827737851" STARTARROW="None" STARTINCLINATION="-99;5;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1678028693313" ID="ID_1210494901" MODIFIED="1678028703577">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">TrackHeadWidget::accommodateOverallHeight(uint overallHeight)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678028969854" ID="ID_1010346697" MODIFIED="1678049461158" TEXT="neue Funktion für TrackHeadWidget">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1678029068390" ID="ID_628565460" MODIFIED="1678029075809" TEXT="linkSubTrackPositions"/>
|
|
<node CREATED="1678049436749" ID="ID_1061735805" MODIFIED="1678049447451" TEXT="rechnet den Offsett kumulativ..."/>
|
|
<node CREATED="1678049449631" ID="ID_295850096" MODIFIED="1678049459298" TEXT="übergibt ihn "schleppend""/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678058911756" ID="ID_316615403" MODIFIED="1678062933937" TEXT="Position nicht akkurat ermittelt">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1678058927261" ID="ID_2489808" MODIFIED="1678058959142" TEXT="fällt zunächst fast nicht auf, aber der Pfeil ist um 1-2px zu hoch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1678059097715" ID="ID_367366159" MODIFIED="1678059119084" TEXT="Experiment: alle gemessenen Offsets jeweils explizit mit einerm Connector markieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1678058960509" ID="ID_755126006" MODIFIED="1678059095895" TEXT="anscheinend eine Kombination mehrerer Fehler in der Layout-Logik">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
zum Einen habe ich unbemerkt die getLabelHeight() vom Parent zum Child verschleppt. Das ist aber unter dem Strich korrekt, weil jedes Kind wieder mit einem Label beginnt
|
|
</li>
|
|
<li>
|
|
außerdem gibt es da anscheinend im Grid ein zusätzliches Padding, was mir bisher entgangen war
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#5b280f" CREATED="1678061441159" ID="ID_1093502682" MODIFIED="1678061454811" TEXT="nein: es ist kein row_spacing gesetzt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1678061459565" HGAP="33" ID="ID_1977884766" MODIFIED="1678061483474" TEXT="sicherheitshalber das auch explizit = 0" VSHIFT="6">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1678061488359" ID="ID_1016675845" MODIFIED="1678061698397" TEXT="Ha! der Spreiz-Effekt der Expander-Spalte wird zwischen die Zeilen verteilt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Expander in der ersten Spalte dient dazu, das TrackHeadWidget auf eine geforderte Nenn-Höhe aufzuspannen. Anscheinend habe ich die Zellen so definiert, daß diese Diskrepanz als spacing zwischen Label, Content und SyncPadding verteilt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678061699565" ID="ID_1726897504" MODIFIED="1678061716315" TEXT="diese Diskrepanz erfassen und zusätzlich als Offset einreichnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678049477756" ID="ID_341782472" MODIFIED="1678062950593" TEXT="Verbindung zeichnen">
|
|
<linktarget COLOR="#74bc9c" DESTINATION="ID_341782472" ENDARROW="Default" ENDINCLINATION="-47;311;" ID="Arrow_ID_796598927" SOURCE="ID_916814047" STARTARROW="None" STARTINCLINATION="312;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1678049497561" ID="ID_1369706059" MODIFIED="1678049721195" TEXT="den Offset mit der Geometrie des StaveBracket verbinden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678049544501" ID="ID_1360937684" MODIFIED="1678049683125" TEXT="Offset der Kappe berücksichtigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1678049558487" ID="ID_1961258061" MODIFIED="1678049687672" TEXT="verwende Nullpunkt der oberen Kappe als Bezugssystem">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1678049569243" ID="ID_1792975653" MODIFIED="1678049691033" TEXT="nochmal die Höhe der Kappe als zusätzlicher Offset">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1678049589007" ID="ID_114677730" MODIFIED="1678049717907" TEXT="damit die Verbindung am Nullpunkt der Kind-Klammer ansetzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mache hier die vereinfachtende Annahme, daß alle Brackets die gleiche Metrik haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678049635786" ID="ID_1684871223" MODIFIED="1678049681821" TEXT="sieht visuell korrekt aus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geprüft mit Screenshot in Gimp.
|
|
</p>
|
|
<p>
|
|
Unter der Einschränkung, daß hier viel Aliasing passiert und das Bild schon relativ klein ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678049724136" ID="ID_895610001" MODIFIED="1678049829318" TEXT="Zweifel an der Genauigkeit der Zeichnung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1678049738310" ID="ID_1123952666" MODIFIED="1678049749873" TEXT="das liegt vermutlich vor allem am Zeichnen eines Kreises"/>
|
|
<node CREATED="1678049750825" ID="ID_1765806485" MODIFIED="1678049761575" TEXT="und außerdem fülle ich nur (ohne Stroke)"/>
|
|
<node CREATED="1678049763211" ID="ID_53745567" MODIFIED="1678049778700" TEXT="mit einem Rechteck kommt die Breite ganz exakt raus"/>
|
|
<node COLOR="#338800" CREATED="1678049788263" ID="ID_1352330785" MODIFIED="1678049835012" TEXT="⟹ den Kreis auf Radius PHI_MAJOR vergrößern"/>
|
|
<node COLOR="#338800" CREATED="1678049817972" ID="ID_167200594" MODIFIED="1678049835012" TEXT="⟹ auch noch eine Kontur zeichnen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678054029564" ID="ID_386732686" MODIFIED="1678054319420" TEXT="Außerdem noch einen Pfeil as Verbindung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1678054045057" ID="ID_374835137" MODIFIED="1678054054417" TEXT="brauche dafür die Gesamtbreite">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678054055874" ID="ID_800035074" MODIFIED="1678054377273" TEXT="Bugfix: Breite muß padding-right einschließen">
|
|
<linktarget COLOR="#77a6bb" DESTINATION="ID_800035074" ENDARROW="Default" ENDINCLINATION="87;5;" ID="Arrow_ID_1851726914" SOURCE="ID_325851993" STARTARROW="None" STARTINCLINATION="129;-3;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678054322417" ID="ID_1962694218" MODIFIED="1678054509666" TEXT="Pfeile sehen unsauber aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1678054332187" ID="ID_1403282354" MODIFIED="1678054514935" TEXT="mehrere Probleme...">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678054338408" ID="ID_325851993" MODIFIED="1678054518906" TEXT="zu wenig Platz ⟹ auch noch das Padding nutzen">
|
|
<arrowlink COLOR="#77a6bb" DESTINATION="ID_800035074" ENDARROW="Default" ENDINCLINATION="87;5;" ID="Arrow_ID_1851726914" STARTARROW="None" STARTINCLINATION="129;-3;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678054386819" ID="ID_650165799" MODIFIED="1678054518906" TEXT="Pfeile dürfen nicht zu schlank sein"/>
|
|
<node COLOR="#435e98" CREATED="1678054403496" ID="ID_910454360" MODIFIED="1678054518905" TEXT="Pfeil-Breite per Φ an joint-Durchmesser"/>
|
|
<node COLOR="#435e98" CREATED="1678054437780" ID="ID_289152885" MODIFIED="1678054518905" TEXT="brauche eine scharfe Gehrung ("miter")">
|
|
<node CREATED="1678054454505" ID="ID_829025847" MODIFIED="1678054489675" TEXT="miter_limit auf 20 hochsetzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...der default ist 10, und das erzeugt eine Gehrung nur bis ca 20°
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1678054491002" ID="ID_1642552980" MODIFIED="1678054506894" TEXT="zusätzlich 1 unit (px) Luft lassen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677426668947" ID="ID_1313952369" MODIFIED="1677867091124" TEXT="Farbe setzen">
|
|
<linktarget COLOR="#346382" DESTINATION="ID_1313952369" ENDARROW="Default" ENDINCLINATION="-273;44;" ID="Arrow_ID_1766960947" SOURCE="ID_1533322932" STARTARROW="None" STARTINCLINATION="102;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677451594072" FOLDED="true" ID="ID_1658195962" MODIFIED="1678063122123" TEXT="Layout-Steuerung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1676046656020" FOLDED="true" ID="ID_739149798" MODIFIED="1677451623361" TEXT="horizontale Ausdehnung steuern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1676046671288" ID="ID_823909101" MODIFIED="1676047541409" TEXT="intrinsich feste Ausdehnung erforderlich, nun Höhe variabel">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1676046707056" ID="ID_1489341239" MODIFIED="1676047541408" TEXT="aber GTK weist ggfs auch gar keine Ausdehnung zu, oder teilt 50:50">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1676047544344" ID="ID_1689678210" MODIFIED="1676047576094" TEXT="...jetzt wird schon mal grundsätzlich korrekt gezeichnet">
|
|
<arrowlink COLOR="#60a5a0" DESTINATION="ID_1701009358" ENDARROW="Default" ENDINCLINATION="234;0;" ID="Arrow_ID_1201169468" STARTARROW="None" STARTINCLINATION="8;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1676047436191" FOLDED="true" ID="ID_1883772058" MODIFIED="1676085951547" TEXT="Problem: GTK weist manchmal trotzdem mehr zu">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1676085625293" ID="ID_1842723782" MODIFIED="1676085879659" TEXT="Uh-oh ... es ist kompliziert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head></head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
das Problem tritt auf bei »Leaf-Tracks«
|
|
</li>
|
|
<li>
|
|
bei diesen liegen hier zwei Zellen nebeneinander, und sonst nichts, was eine Verankerung geben könnte
|
|
</li>
|
|
<li>
|
|
zwar habe ich kein homogenous-spacing gesetzt (geht das überhaupt?)
|
|
</li>
|
|
<li>
|
|
aber die Zelle (0,1) enthält ein weiteres Grid-Control
|
|
</li>
|
|
<li>
|
|
das aber seinerseits nur eine einzige Zelle mit einem Platzhalter beinhaltet
|
|
</li>
|
|
<li>
|
|
...also selbst komplett unterfüllt ist und keine signifikante Allokation erzeugt
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
⟹ längerfristig wird sich das sowiso regeln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1676085882028" ID="ID_1638208695" MODIFIED="1676085948819" TEXT="Verhalten explizit anfordern">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1676085910066" ID="ID_1461288066" MODIFIED="1676085927242" TEXT="das Stave-Bracket : expand = false"/>
|
|
<node CREATED="1676085928118" ID="ID_1335925100" MODIFIED="1676085936857" TEXT="das Head-Control : expand= true"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1676085939157" ID="ID_1665806137" MODIFIED="1676085945174" TEXT="Problem gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675902536517" ID="ID_827367364" MODIFIED="1677860993690" TEXT="Anpassung an Allocation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1677851231787" ID="ID_989353390" MODIFIED="1677851251627" TEXT="Höhe wird fest vorgegeben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677851253034" ID="ID_534111962" MODIFIED="1677860992436" TEXT="notwendige Breite aus CSS + Konstruktion ermitteln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677851285924" ID="ID_452245483" MODIFIED="1677860991136" TEXT="Realisierbarkeit sicherstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677851305897" ID="ID_724109318" MODIFIED="1677851357078" TEXT="es gibt eine Minimal-Höhe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es muß die obere und die untere Kappe gezeichnet werden, und deren Höhe ergibt sich qua Konstruktion aus der Basisbreite
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677851359498" ID="ID_1131290489" MODIFIED="1677860989026" TEXT="⟹ notfalls Basisbreite reduzieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
➩ Skala für gesamte Klammer verkleinern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677451786789" ID="ID_883997565" MODIFIED="1677860999220" TEXT="Styling per CSS">
|
|
<linktarget COLOR="#5586b2" DESTINATION="ID_883997565" ENDARROW="Default" ENDINCLINATION="108;-242;" ID="Arrow_ID_1785981386" SOURCE="ID_1105975491" STARTARROW="None" STARTINCLINATION="-291;20;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1677451800420" ID="ID_1164109956" MODIFIED="1677457558599" TEXT="Entscheidung: Modell?">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1677451818657" FOLDED="true" ID="ID_1508791771" MODIFIED="1677457503784" TEXT="global oder individuell?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1677451850726" ID="ID_1657882401" MODIFIED="1677457383789" TEXT="global">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1677451889120" ID="ID_1375157373" MODIFIED="1677451890620" TEXT="alle StaveBracket-Instanzen teilen sich ein Setting"/>
|
|
<node CREATED="1677457339549" ID="ID_1266593311" MODIFIED="1677457369607" TEXT="das wäre der YAGNI-Ansatz: zeig mir daß Du differenziertes Styling überhaupt brauchst">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1677451946578" ID="ID_256050915" MODIFIED="1677452020472" TEXT="hierfür wäre eine non-Standard-Konvention notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um festzulegen, an welcher Stelle in der Hierarchie dieses Styling definiert ist; allerdings machen wir bereits genau dies für die Timeline im Allgemeinen (und zwar genau wegen dem custom-drawing)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677451877866" ID="ID_1658993921" MODIFIED="1677457386662" TEXT="individuell">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1677451923027" ID="ID_1111541133" MODIFIED="1677451935717" TEXT="das wäre das reguläre Verhalten eines Widgets"/>
|
|
<node CREATED="1677451894781" ID="ID_563371586" MODIFIED="1677451919408" TEXT="jedes StaveBracket ruft CSS-Style gemäß Widget-Path ab"/>
|
|
<node CREATED="1677457154222" ID="ID_1190875296" MODIFIED="1677457162257" TEXT="Performance-Implikationen unklar">
|
|
<node CREATED="1677457165969" ID="ID_906548629" MODIFIED="1677457196177" TEXT="API und Beispiele implizieren Zugriff auf einfache Settings"/>
|
|
<node CREATED="1677457246159" ID="ID_974418122" MODIFIED="1677457264603" TEXT="rein praktisch wird aber der draw()-Code schon oft aufgerufen"/>
|
|
<node CREATED="1677457197200" ID="ID_1837634552" MODIFIED="1677457215893" TEXT="vermutlich gibt es irgendwo im Framework ein Caching"/>
|
|
<node CREATED="1677457217538" ID="ID_789755094" MODIFIED="1677457490369" TEXT="und der GTK-Drawing-Code macht ähnliche Zugriffe">
|
|
<arrowlink COLOR="#9e3662" DESTINATION="ID_1307381473" ENDARROW="Default" ENDINCLINATION="-2;-37;" ID="Arrow_ID_826896124" STARTARROW="None" STARTINCLINATION="-50;3;"/>
|
|
</node>
|
|
<node CREATED="1677457273534" ID="ID_617186212" MODIFIED="1677457320336" TEXT="letztlich haben wir hier keinen gefährlichen Hebel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...anders als bei den Einzel-Widgets im Timeline-Content, haben wir hier im Header nur ein StaveBracket-Widget pro Track
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677457389357" ID="ID_1307381473" MODIFIED="1677457500256" TEXT="gemäß "principle of least surprise" ... erst mal an den Standard halten">
|
|
<linktarget COLOR="#9e3662" DESTINATION="ID_1307381473" ENDARROW="Default" ENDINCLINATION="-2;-37;" ID="Arrow_ID_826896124" SOURCE="ID_789755094" STARTARROW="None" STARTINCLINATION="-50;3;"/>
|
|
<linktarget COLOR="#feebc6" DESTINATION="ID_1307381473" ENDARROW="Default" ENDINCLINATION="-168;7;" ID="Arrow_ID_1516635946" SOURCE="ID_1850988964" STARTARROW="None" STARTINCLINATION="-107;-380;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677457522290" ID="ID_1098941719" MODIFIED="1677776070853" TEXT="Direktzugriff vom Widget ⟶ StyleContext">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1677457632425" ID="ID_1473941449" MODIFIED="1677457653079" TEXT="⟹ Konsequenz: es muß eine Instanz-Methode sein"/>
|
|
<node CREATED="1677457677976" ID="ID_1603877421" MODIFIED="1677457706351" TEXT="(inline)Accessor-Funktionen zur Vereinfachung der Notation"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677546010944" FOLDED="true" ID="ID_1646590066" MODIFIED="1678032781761" TEXT="Ermitteln des Skalenfaktors">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677546026066" ID="ID_909459060" MODIFIED="1677546037940" TEXT="hängt zusammen mit der Bildschirmauflösung (dpi)">
|
|
<node CREATED="1677546064069" ID="ID_1332973072" LINK="https://stackoverflow.com/a/446280" MODIFIED="1677546112075">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dpi-Wert für aktuellen <i>Screen</i> herausfinden GTK ⟵ GDK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677546237446" ID="ID_33898017" MODIFIED="1677546258583" TEXT="ein typographischer Punkt = 1/72 inch"/>
|
|
<node CREATED="1677546270185" ID="ID_1566124944" LINK="#ID_1345692974" MODIFIED="1677546358775" TEXT="default-Auflösung: 1px = 1/96 inch"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677546376907" ID="ID_1490214511" MODIFIED="1677718453503" TEXT="ich möchte es aber am ex des Font festmachen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1677546452825" ID="ID_1035857158" LINK="https://developer-old.gnome.org/gtkmm/3.20/classGtk_1_1StyleContext.html#aa7152d36c584d7be8e3769fc8b865aaf" MODIFIED="1677546546279" TEXT="Gtk::StyleContext::get_font() ⟼ Pango::FontDescription"/>
|
|
<node CREATED="1677547827538" ID="ID_205149789" MODIFIED="1677547884742" TEXT="in CSS ist 'em' direkt an die Font-Size im Kontext gebunen"/>
|
|
<node CREATED="1677624520830" ID="ID_1887034328" MODIFIED="1677624768305" TEXT="Vorsicht: 'ex' ist unzuverlässig implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Streng genommen sollte 'ex' die Höhe eines kleinen-x sein. Aber diese Information ist in vielen Fonts überhaupt nicht zuverlässig feststellbar; die resultierende Angabe kann daher unzuverlässig und fehlerhaft, oder gar nicht vorhanden sein, in welchem Fall es statthaft ist, auf ex ≔ em/2 zurückzufallen. Im Gegensatz dazu weiß man bei 'em', was man bekommt, nämlich die nominelle Font-Size (auch hierin unterscheidet sich CSS von der klassischen typographischen Praxis, in der 'em' definiert ist als die Höhe des großen-M)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1677548906490" ID="ID_1334871412" MODIFIED="1677548924251" TEXT="aber was genau ist dann "font-size"?">
|
|
<node CREATED="1677549097512" ID="ID_1309259825" MODIFIED="1677549382705" TEXT="warum kann man das nicht einfach explizit und klar sagen, Leute?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die ganze Doku, sowohl in GTK, alsauch die CSS Spec liest sich so, als wollte man sich vor einer Festlegung drücken. Möglicherweise hatte man Sorge, die dummen Leute würden zu einfache Schlußfolgerungen ziehen, und darob die Auflösung des Bildschirms übersehen — 96dpi ist ja nur ein <i>Default, </i>und ob 1pt= 1/72 inch wirklich gilt, darauf möchte sich niemand festnageln lasse, vermute ich (es hängt nämlich davon ab, daß Monitor und Grafikkarte diesen Wert richtig reporten)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1677549011508" ID="ID_1030834105" LINK="https://docs.gtk.org/Pango/method.FontDescription.get_size.html" MODIFIED="1677549122645" TEXT="gint pango_font_description_get_size()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<a http-equiv="content-type" content="text/html; charset=utf-8" href="javascript:void(0)" class="collapse-toggle">
|
|
</a> </p>
|
|
<h4 id="return-value">
|
|
Return value <a href="https://docs.gtk.org/Pango/method.FontDescription.get_size.html#return-value" class="anchor">
|
|
</a> </h4>
|
|
<div class="docblock">
|
|
<div class="returns">
|
|
<div class="arg-description">
|
|
<p>
|
|
<em>Type:</em> <code>gint</code>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
The size field for the font description in points or device units. You must call <a href="https://docs.gtk.org/Pango/method.FontDescription.get_size_is_absolute.html"><code>pango_font_description_get_size_is_absolute()</code></a>  to find out which is the case. Returns 0 if the size field has not previously been set or it has been set to 0 explicitly. Use <a href="https://docs.gtk.org/Pango/method.FontDescription.get_set_fields.html"><code>pango_font_description_get_set_fields()</code></a>  to find out if the field was explicitly set or not.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677549455712" ID="ID_1132983571" MODIFIED="1677549481974" TEXT="der CairoContext kann übersetzen user-coord ⟼ device-coord">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677549522584" ID="ID_1432682127" LINK="https://www.cairographics.org/documentation/cairomm/reference/classCairo_1_1Context.html#a30ee2fbeca1cb347548d5b9d186e38ea" MODIFIED="1677549542721" TEXT="void user_to_device(double & x, double & y)"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677626008384" ID="ID_1276314266" MODIFIED="1677718443624" TEXT="was brauche ich konkret?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1677626041993" ID="ID_1160252640" MODIFIED="1677626192299">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>gegeben...</u>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677626051543" ID="ID_1734833636" MODIFIED="1677626061778" TEXT="ein Style(Context)">
|
|
<node CREATED="1677626078788" ID="ID_371730038" MODIFIED="1677626088548" TEXT="implizit: ein Screen -> DPI"/>
|
|
<node CREATED="1677626089594" ID="ID_532854318" MODIFIED="1677626096373" TEXT="implizit: eine Font-Size"/>
|
|
</node>
|
|
<node CREATED="1677626064902" ID="ID_1611854152" MODIFIED="1677626073888" TEXT="ein CairoContext"/>
|
|
</node>
|
|
<node CREATED="1677626098881" ID="ID_656135180" MODIFIED="1677626201096">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>gesucht...</u>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677626219156" ID="ID_751208280" MODIFIED="1677626226660" TEXT="Scale-Faktor für den Canvas"/>
|
|
<node CREATED="1677626293759" ID="ID_313668863" MODIFIED="1677626298635" TEXT="Rechenweg">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677626302701" ID="ID_613709734" MODIFIED="1677626717065">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u><font color="#8323d6">Fall-1</font></u>: Font-Size ist absolut gegeben ⟹
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5643b8" DESTINATION="ID_613709734" ENDARROW="Default" ENDINCLINATION="9;17;" ID="Arrow_ID_1640372143" SOURCE="ID_1985359358" STARTARROW="None" STARTINCLINATION="-136;-7;"/>
|
|
<node CREATED="1677626356166" ID="ID_550116769" MODIFIED="1677626373368" TEXT="derzeitigen Scale-Faktor im CairoContext ermitteln"/>
|
|
<node CREATED="1677626435688" ID="ID_1977307488" MODIFIED="1677626460277" TEXT="�� Verhältnis zur Font-Size ist der gewünschte Faktor"/>
|
|
</node>
|
|
<node CREATED="1677626302701" ID="ID_940600114" MODIFIED="1677626530910">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u><font color="#8323d6">Fall-1</font></u>: Font-Size relativ (in Punkten) ⟹
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677626356166" ID="ID_62015779" MODIFIED="1677626373368" TEXT="derzeitigen Scale-Faktor im CairoContext ermitteln"/>
|
|
<node CREATED="1677626550450" ID="ID_1022527690" MODIFIED="1677626559551" TEXT="1pt == 1/27 inch"/>
|
|
<node CREATED="1677626560803" ID="ID_1545300397" MODIFIED="1677626590307" TEXT="DPI ⟼ Anzahl Pixel per inch"/>
|
|
<node CREATED="1677626435688" ID="ID_1985359358" MODIFIED="1677626725417">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
daraus absolute Font-Size und weiter wie <font color="#8323d6">[Fall-1]</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5643b8" DESTINATION="ID_613709734" ENDARROW="Default" ENDINCLINATION="9;17;" ID="Arrow_ID_1640372143" STARTARROW="None" STARTINCLINATION="-136;-7;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677626961166" ID="ID_70009085" MODIFIED="1677776033894" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677626967309" ID="ID_1850988964" MODIFIED="1677627034111" TEXT="erst mal kein Caching">
|
|
<arrowlink COLOR="#feebc6" DESTINATION="ID_1307381473" ENDARROW="Default" ENDINCLINATION="-168;7;" ID="Arrow_ID_1516635946" STARTARROW="None" STARTINCLINATION="-107;-380;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677627099341" ID="ID_1048657097" MODIFIED="1677718685659" TEXT="getAbsoluteFontSize(StyleContext)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677627125432" ID="ID_1830042591" MODIFIED="1677627137685" TEXT="Fallunterscheidung der Font-Size-Angabe"/>
|
|
<node CREATED="1677627141566" ID="ID_1002293726" MODIFIED="1677627152304" TEXT="Zugriff auf die Screen-DPI"/>
|
|
<node COLOR="#435e98" CREATED="1677630910874" ID="ID_1492154354" MODIFIED="1677632493748" TEXT="Problem: Pango liefert eine sonderbare Größenangabe">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1677630976616" ID="ID_444564082" MODIFIED="1677631024852" TEXT="font.get_size() �� 9216 und font.get_size_is_absolute() �� false">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1677631757926" ID="ID_719052213" LINK="https://stackoverflow.com/a/48025455" MODIFIED="1677631787256" TEXT="Pango verwendet anscheined einenn internen Multiplikator">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677631794049" ID="ID_1699777639" LINK="https://docs.gtk.org/Pango/const.SCALE.html" MODIFIED="1677631879874" TEXT="#define PANGO_SCALE 1024"/>
|
|
<node CREATED="1677632470180" ID="ID_1459376659" MODIFIED="1677632489741" TEXT="das gilt für alle Längenangaben in Pango (Integer-Arithmetik)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677632454793" ID="ID_283578241" MODIFIED="1677632491456" TEXT="damit ergeben sich plausible Werte">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#5b280f" CREATED="1677627185944" ID="ID_1669119375" MODIFIED="1678032805070" TEXT="deviceUnitsPerUserUnit(CairoContext)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1677627310903" ID="ID_1788648551" MODIFIED="1677630788961" TEXT="prüfen: könnte verzichtbar sein....">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1677630791167" ID="ID_235578795" MODIFIED="1677630834401" TEXT="in der Tat: CairoContext::user_to_device_distance() �� 1"/>
|
|
<node COLOR="#5b280f" CREATED="1677718481581" ID="ID_655908718" MODIFIED="1677775837317" TEXT="sicherheitshalber aber doch mit einarbeiten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich weiß einfach nicht, unter welchen Umständen dann doch mal ein anderer Faktor als 1.0 im gegebenen CairoContext vorliegt; und wenn das dann passiert, wäre das ein ziemlich obskures Fehlverhalten und man wird dann nicht ohne Weiteres die richtige Stelle finden, um diesen Korrekturfaktor einzubringen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1677775842668" ID="ID_178604932" LINK="https://www.cairographics.org/tutorial/#L1transforms" MODIFIED="1677776018897" TEXT="Nein! Laut Doku ist initial der User-Space identisch mit dem Device-Space">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
The device-space coordinate system is tied to the surface, and cannot change. The user-space coordinate system
|
|
|
|
<p>
|
|
<b><font color="#a7273b">matches that space by default</font></b><font color="#a7273b">,</font> but can be changed for the above reasons. The helper functions
|
|
</p>
|
|
<p>
|
|
<a http-equiv="content-type" content="text/html; charset=utf-8" href="http://www.cairographics.org/manual/cairo-Transformations.html#cairo-user-to-device"><code>cairo_user_to_device()</code></a> and <a href="http://www.cairographics.org/manual/cairo-Transformations.html#cairo-user-to-device-distance"><code>cairo_user_to_device_distance()</code></a>  tell you what the device-coordinates are for a user-coordinates position or distance.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#c51645" CREATED="1678032808275" ID="ID_1635540981" MODIFIED="1678032853963" TEXT="man darf das nicht ausschließen — es ist ein Freiheitsgrad">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1678032857292" ID="ID_68799047" MODIFIED="1678032914626" TEXT="man sollte es auch nicht kompensieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1678032891507" ID="ID_699242092" MODIFIED="1678032911045" TEXT="denn über diesen Faktor kommt ggfs. ein expliziter Skalierungs-Wunsch"/>
|
|
<node CREATED="1678032867611" ID="ID_1608856160" MODIFIED="1678032888002" TEXT="beispielsweise: die "Lupe" vom GTK-Widget-Debugger">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1677457832609" ID="ID_1478500520" MODIFIED="1677864414871" TEXT="Festzulegende Eigenschaften">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1677458010560" ID="ID_1003264563" MODIFIED="1677851081064" TEXT="Basisgröße (=Linienbreite)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677458053102" ID="ID_1614036555" MODIFIED="1677458063936" TEXT="könnte man erst mal am DPI-Wert festmachen"/>
|
|
<node CREATED="1677458064756" ID="ID_1912408866" MODIFIED="1677458088765" TEXT="man könnte es zusätzlich auch an einer default-Schriftgröße festmachen"/>
|
|
<node CREATED="1677458115914" ID="ID_1725640561" MODIFIED="1677458124777" TEXT="alternativ wäre ein spezial-Setting denkbar"/>
|
|
<node CREATED="1677458246716" ID="ID_120680704" MODIFIED="1677458276253">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist der <b>Basiswert</b> für weiteres Layout-Entscheidungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677457850153" ID="ID_1305504262" MODIFIED="1677851083066" TEXT="Bezugsachse horizontal">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677458156264" ID="ID_857815456" MODIFIED="1677458189479" TEXT="ergbit sich aus Padding, Scale und dem Design selber (Φ-minor)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677457867207" ID="ID_1126720758" MODIFIED="1677851085119" TEXT="Ankerpunkt obere/untere Kappe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677458198238" ID="ID_1920467800" MODIFIED="1677458213788" TEXT="ganz analog, Padding + Scale"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677457975185" ID="ID_1711981540" MODIFIED="1677860996817" TEXT="Farbe der Klammer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1677458102355" ID="ID_1926644285" MODIFIED="1677458115114" TEXT="könnte man an default-Schriftfarbe festmachen"/>
|
|
<node CREATED="1677458115914" ID="ID_829449840" MODIFIED="1677458124777" TEXT="alternativ wäre ein spezial-Setting denkbar"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677457971241" ID="ID_716437219" MODIFIED="1677851087182" TEXT="Padding">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1677458131835" ID="ID_1560054657" MODIFIED="1678054570385" TEXT="direkt aus CSS entnehmen"/>
|
|
<node COLOR="#435e98" CREATED="1678054549373" ID="ID_1191383987" MODIFIED="1678054569562" TEXT="auch oben/unten und rechts berücksichtigen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1677864417723" ID="ID_692056392" MODIFIED="1677864442889">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Style-Klasse: <b><font face="Monospaced">.fork__bracket</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1675902610612" ID="ID_1308174165" MODIFIED="1678054628480" TEXT="Struktur-Schema">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1675902621506" ID="ID_916814047" MODIFIED="1678054663077" TEXT="Anknüpfungen an Sub-Scopes">
|
|
<arrowlink COLOR="#74bc9c" DESTINATION="ID_341782472" ENDARROW="Default" ENDINCLINATION="-47;311;" ID="Arrow_ID_796598927" STARTARROW="None" STARTINCLINATION="312;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678054620259" ID="ID_1530313574" MODIFIED="1678054627124" TEXT="Verbindungs-Elemente zeichnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1677426647111" ID="ID_1384220998" MODIFIED="1677426654411" TEXT="Ergänzungen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1677426657149" ID="ID_1533322932" MODIFIED="1677867106087" TEXT="Farbe der Klammer aus CSS">
|
|
<arrowlink COLOR="#346382" DESTINATION="ID_1313952369" ENDARROW="Default" ENDINCLINATION="-273;44;" ID="Arrow_ID_1766960947" STARTARROW="None" STARTINCLINATION="102;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1563469735149" ID="ID_704791408" MODIFIED="1678063062655" TEXT="Selection-State zeigen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1678231145115" ID="ID_1009372537" MODIFIED="1678231157694" TEXT="#1271 highlight active track scope">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1566955554876" ID="ID_1903815723" MODIFIED="1679082664489" TEXT="Layout-Steuerung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1566955560666" ID="ID_1506262956" MODIFIED="1566955573502" TEXT="mit Body-Canvas koordinieren">
|
|
<arrowlink COLOR="#4b98e2" DESTINATION="ID_1754764132" ENDARROW="Default" ENDINCLINATION="-2912;207;" ID="Arrow_ID_468901844" STARTARROW="None" STARTINCLINATION="698;66;"/>
|
|
</node>
|
|
<node CREATED="1566955574281" ID="ID_1649819002" MODIFIED="1566955652259" TEXT="muß gemeinsam mit unterem Body-Canvas scrollen">
|
|
<arrowlink COLOR="#327dd5" DESTINATION="ID_1718751102" ENDARROW="Default" ENDINCLINATION="-1329;-302;" ID="Arrow_ID_1962173714" STARTARROW="None" STARTINCLINATION="650;36;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679082719008" ID="ID_1600275521" MODIFIED="1679084618405" TEXT="Anzeige der Track-Scopes präzise steuern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mehrere Aspekte sind hier offen (2023: Abschluß der GUI-Neugründung und vor Playback-Vertical-Slice):
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Track-Head-Abschnitte beginnen nicht exakt korrekt bündig mit dem zugehörigen Bereich im Body; möglicherweise ein "run-away" um ein paar Pixel
|
|
</li>
|
|
<li>
|
|
die Scopes reagieren noch nicht dynamisch auf den Inhalt (und es fehlt die aktive Abstimmung)
|
|
</li>
|
|
<li>
|
|
die Scopes sollten auch eine dynamische Status-Anzeige unterstützen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#b74f6e" DESTINATION="ID_1600275521" ENDARROW="Default" ENDINCLINATION="276;749;" ID="Arrow_ID_614998223" SOURCE="ID_1366095324" STARTARROW="None" STARTINCLINATION="644;37;"/>
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_1600275521" ENDARROW="Default" ENDINCLINATION="-506;31;" ID="Arrow_ID_694017211" SOURCE="ID_430878592" STARTARROW="None" STARTINCLINATION="-2163;252;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480607035712" ID="ID_1405339006" MODIFIED="1557498707227" TEXT="Rumpf" VGAP="5">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544835109183" FOLDED="true" ID="ID_1598364198" MODIFIED="1679359934414" TEXT="Konzept: RulerTrack">
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544849233126" ID="ID_665765482" MODIFIED="1557498707227" TEXT="#1194 Handling of Ruler Tracks">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1544835125485" ID="ID_1915741861" MODIFIED="1557498707227" TEXT="Verallgemeinerung">
|
|
<node CREATED="1544835133005" ID="ID_168632162" MODIFIED="1557498707227" TEXT="Time Ruler"/>
|
|
<node CREATED="1544835135955" ID="ID_676965041" MODIFIED="1557498707227" TEXT="Overview Ruler"/>
|
|
</node>
|
|
<node CREATED="1544835146834" ID="ID_1998202502" MODIFIED="1557498707227" TEXT="Konfigurierbar">
|
|
<node CREATED="1544835156145" ID="ID_967222646" MODIFIED="1557498707227" TEXT="Content-Anzeige"/>
|
|
<node CREATED="1544835160640" ID="ID_498988220" MODIFIED="1557498707227" TEXT="Bereichs-Anzeige"/>
|
|
<node CREATED="1544835165903" ID="ID_80922465" MODIFIED="1557498707227" TEXT="Timecode + Ticks">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_80922465" ENDARROW="Default" ENDINCLINATION="343;0;" ID="Arrow_ID_630173444" SOURCE="ID_1619835790" STARTARROW="None" STARTINCLINATION="376;0;"/>
|
|
</node>
|
|
<node CREATED="1544835172206" ID="ID_429836650" MODIFIED="1557498707227" TEXT="Marker"/>
|
|
</node>
|
|
<node CREATED="1544837600332" ID="ID_415425563" MODIFIED="1557498707227" TEXT="konkrete Konfig">
|
|
<node CREATED="1544837522661" ID="ID_591280489" MODIFIED="1557498707227" TEXT="mehrere Zustände">
|
|
<node CREATED="1544837527828" ID="ID_596254877" MODIFIED="1557498707227" TEXT="collapsed"/>
|
|
<node CREATED="1544837530980" ID="ID_1927125856" MODIFIED="1557498707227" TEXT="expanded - Leaf"/>
|
|
<node CREATED="1544837543434" ID="ID_450659052" MODIFIED="1557498707227" TEXT="expanded - Fork"/>
|
|
</node>
|
|
<node CREATED="1544837618776" ID="ID_262509677" MODIFIED="1557498707227" TEXT="wer wählt Belegung?">
|
|
<node CREATED="1544837626783" ID="ID_1328055654" MODIFIED="1557498707227" TEXT="basiert auf Regeln"/>
|
|
<node CREATED="1544837630150" ID="ID_1082045785" MODIFIED="1557498707227" TEXT="hat Scope-Logik"/>
|
|
<node CREATED="1544837640573" ID="ID_599648265" MODIFIED="1557498707227" TEXT="==> "riecht" nach Placement"/>
|
|
<node CREATED="1544837700422" ID="ID_1038765642" MODIFIED="1557498707227" TEXT="Session muß für jeden Track....">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1544837719898" ID="ID_29304851" MODIFIED="1557498707227" TEXT="expanded-config senden"/>
|
|
<node CREATED="1544837729313" ID="ID_797684565" MODIFIED="1557498707227" TEXT="collapsed config senden"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1544837659506" ID="ID_1608620186" MODIFIED="1557498707227" TEXT="Fazit: GUI ist passiv!">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1554996492819" ID="ID_1391546845" MODIFIED="1557498707227" TEXT="Konfig laut systematischem Modell">
|
|
<arrowlink COLOR="#3e63c5" DESTINATION="ID_433238862" ENDARROW="Default" ENDINCLINATION="-612;-125;" ID="Arrow_ID_1858329997" STARTARROW="None" STARTINCLINATION="-747;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1553911718090" ID="ID_612121351" MODIFIED="1557498707227" TEXT="praktische Ausgestalutng">
|
|
<node CREATED="1553911730196" ID="ID_1967793006" MODIFIED="1563457386787" TEXT="grundsätzlich....">
|
|
<node COLOR="#435e98" CREATED="1553911737751" ID="ID_669315030" MODIFIED="1563457397449" TEXT="ist RulerTrack ein Tangible?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1563456133616" ID="ID_1546021764" MODIFIED="1563456136468" TEXT="Diskussion">
|
|
<node CREATED="1553911756429" ID="ID_1273721468" MODIFIED="1563457417610" TEXT="pro">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1553911764980" ID="ID_258039981" MODIFIED="1557498707227" TEXT="Diff-Binding nach Schema-F"/>
|
|
</node>
|
|
<node CREATED="1553911796208" ID="ID_1254226888" MODIFIED="1563457414715" TEXT="con">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1553911798428" ID="ID_1946109008" MODIFIED="1557498707227" TEXT="es bietet nur teilweise die Aktionen eines Tangible"/>
|
|
<node CREATED="1563466370058" ID="ID_863187721" MODIFIED="1576282358066" TEXT="automatisches Management könnte schwierig werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil der Ruler ja in die Präsentation mit einbezogen ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1563456143402" ID="ID_1942744457" MODIFIED="1563456147693" TEXT="Entscheidung: ja">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1563456157904" ID="ID_1376003516" MODIFIED="1563456166179" TEXT="der Ruler hat genügend Substanz">
|
|
<node CREATED="1563456222184" ID="ID_506318259" MODIFIED="1563456232299" TEXT="er hat eine Parametrisierung"/>
|
|
<node CREATED="1563456234334" ID="ID_792066760" MODIFIED="1563456245693" TEXT="er ist expanded/collapsed"/>
|
|
<node CREATED="1563456255701" ID="ID_1379712635" MODIFIED="1563456262198" TEXT="mit jeweils spezieller Ausstattung"/>
|
|
</node>
|
|
<node CREATED="1563456167140" ID="ID_197035076" MODIFIED="1563456180345" TEXT="der Repräsentant ist ein Controller">
|
|
<node CREATED="1563456268098" ID="ID_1014911371" MODIFIED="1563456278940" TEXT="tatsächliche Darstellung auf dem Canvas"/>
|
|
<node CREATED="1563456280732" ID="ID_350277942" MODIFIED="1563456296145" TEXT="muß sich ggfs. Marker / Selections "holen""/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563457330971" ID="ID_1988056497" MODIFIED="1563457395240" STYLE="fork" TEXT="hat ein RulerTrack eigenen Content?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1563457346678" ID="ID_1336854031" MODIFIED="1563457395240" TEXT="7/2019 ich denke: nein">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1563457361836" ID="ID_32790322" MODIFIED="1563457395240" TEXT="könnte aber später noch kommen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563466422079" ID="ID_1950304840" MODIFIED="1563466425634" TEXT="Lebenszyklus">
|
|
<node CREATED="1563466427030" ID="ID_1041447231" MODIFIED="1563466444920" TEXT="per vector<unique_ptr<RulerTrack>>"/>
|
|
<node CREATED="1563466447828" ID="ID_1400466075" MODIFIED="1563466455230" TEXT="erscheint weitgehend unproblematisch"/>
|
|
</node>
|
|
<node CREATED="1563456327642" ID="ID_216416376" MODIFIED="1563456331648" TEXT="Zustand">
|
|
<node CREATED="1563456332965" ID="ID_1615333919" MODIFIED="1563456339250" TEXT="expanded/collapsed">
|
|
<node CREATED="1563456339836" ID="ID_1625370236" MODIFIED="1563456343779" TEXT="persistent UI state"/>
|
|
<node CREATED="1563456817269" ID="ID_682486820" MODIFIED="1563456831249" TEXT="reiner UI-State"/>
|
|
<node CREATED="1563456880459" ID="ID_774164712" MODIFIED="1563456884053" TEXT="zweistufig">
|
|
<node CREATED="1563456835400" ID="ID_939422947" MODIFIED="1563456900080" TEXT="zugehöriger Track expanded/collapsed?"/>
|
|
<node CREATED="1563456901155" ID="ID_1889421343" MODIFIED="1563456935400" TEXT="Ruler selber expanded/collapsed?">
|
|
<node CREATED="1563456985129" ID="ID_1822723040" MODIFIED="1563457050520" TEXT="nur wenn sein presentationStyle "extended" ist">
|
|
<arrowlink COLOR="#5794dc" DESTINATION="ID_1218032977" ENDARROW="Default" ENDINCLINATION="23;-49;" ID="Arrow_ID_477709565" STARTARROW="None" STARTINCLINATION="-54;23;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563457226008" ID="ID_104997878" MODIFIED="1566406624648" TEXT="rulerKind">
|
|
<arrowlink COLOR="#c178a8" DESTINATION="ID_1177786099" ENDARROW="Default" ENDINCLINATION="-1830;0;" ID="Arrow_ID_829837415" STARTARROW="None" STARTINCLINATION="576;-53;"/>
|
|
</node>
|
|
<node CREATED="1563456345999" ID="ID_411877946" MODIFIED="1563456383198" TEXT="presentationBinding">
|
|
<node CREATED="1563456386610" ID="ID_1590625879" MODIFIED="1563456393668" TEXT="wie erscheint der Ruler">
|
|
<node CREATED="1563456477213" ID="ID_214170046" MODIFIED="1563456480985" TEXT="sichtbar?"/>
|
|
<node CREATED="1563456482333" ID="ID_1117291877" MODIFIED="1563456499676" TEXT="presentationStyle">
|
|
<node CREATED="1563456501722" ID="ID_342624302" MODIFIED="1563456515812" TEXT="kompakt">
|
|
<node CREATED="1563456569224" ID="ID_1752795491" MODIFIED="1563456573692" TEXT="alles in einem Overlay"/>
|
|
</node>
|
|
<node CREATED="1563456518864" ID="ID_1218032977" MODIFIED="1563457050520" TEXT="erweitert/Größe">
|
|
<linktarget COLOR="#5794dc" DESTINATION="ID_1218032977" ENDARROW="Default" ENDINCLINATION="23;-49;" ID="Arrow_ID_477709565" SOURCE="ID_1822723040" STARTARROW="None" STARTINCLINATION="-54;23;"/>
|
|
<node CREATED="1563456575488" ID="ID_1884743688" MODIFIED="1563456585226" TEXT="verschiedene Spuren/Skalen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563456394449" ID="ID_1897645470" MODIFIED="1563456399763" TEXT="wenn expanded">
|
|
<node CREATED="1563456435059" ID="ID_927353995" MODIFIED="1563456442622" TEXT="hängt von Struktur ab">
|
|
<node CREATED="1563456443867" ID="ID_1809491279" MODIFIED="1563456449319" TEXT="Leaf or Fork?"/>
|
|
<node CREATED="1563456450468" ID="ID_1604151454" MODIFIED="1563456461931" TEXT="generisch vorprogrammiert"/>
|
|
<node CREATED="1563456462928" ID="ID_443423813" MODIFIED="1563456468426" TEXT="aber trotzdem dynamisches Verhalten"/>
|
|
</node>
|
|
<node CREATED="1563456726268" ID="ID_1768365080" MODIFIED="1563456735534" TEXT="außerdem sichtbar oder verborgen?">
|
|
<node CREATED="1563456762562" ID="ID_968633527" MODIFIED="1563456775217" TEXT="Leaf: häufig verborgen"/>
|
|
<node CREATED="1563456781637" ID="ID_1656158229" MODIFIED="1576282358066" TEXT="Fork: kommt darauf an....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....ob es was sinnvolles in einem Overview-Ruler anzuzeigen gibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563456400751" ID="ID_508263117" MODIFIED="1563456404235" TEXT="wenn collapsed">
|
|
<node CREATED="1563456707526" ID="ID_1191444122" MODIFIED="1563456715230" TEXT="verborgen oder kompakt?"/>
|
|
<node CREATED="1563456694616" ID="ID_119245095" MODIFIED="1563456705916" TEXT="nur 1-dimensionale Unterscheidung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544837985030" HGAP="-90" ID="ID_528262547" MODIFIED="1557498707227" TEXT="Verhältnis zum Time-Ruler" VSHIFT="87">
|
|
<edge STYLE="linear"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1544837991621" ID="ID_1767589633" MODIFIED="1557498707227" TEXT="kühne Idee: zusammenlegen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1544838014602" ID="ID_1780110896" MODIFIED="1557498707227" TEXT="d.h. Time-Ruler == Ruler vom root-Track"/>
|
|
<node CREATED="1544838027901" ID="ID_519696967" MODIFIED="1557498707227" TEXT="Header-Pane: Platz "geschickt" nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1555082395840" ID="ID_104473939" MODIFIED="1557498707227" TEXT="ABER trotzdem separat darzustellen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1555082433635" ID="ID_1213306272" MODIFIED="1557498707227" TEXT="Time-Ruler "allways on top""/>
|
|
<node CREATED="1555082442705" ID="ID_497245117" MODIFIED="1576282358065">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Unterscheidung <b>verschoben</b> in die Darstellung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anstatt (konventionell) den Time-Ruler separat explizit auszuprogrammieren,
|
|
</p>
|
|
<p>
|
|
bekommen wir nun eine gemeinsame Darstellungs-Mechanik,
|
|
</p>
|
|
<p>
|
|
welche dann aber in zwei getrennten Bereichen jeweils anders parametrisiert
|
|
</p>
|
|
<p>
|
|
zur Anwendung kommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1555082487012" ID="ID_217824628" MODIFIED="1557498707228" TEXT="trotzdem sinnvolles Potential zur Vereinheitlichung">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544839243971" ID="ID_1000231823" MODIFIED="1557498707228" TEXT="Ausführung obliegt der Session"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540641313667" ID="ID_1952536945" MODIFIED="1557498707228" TEXT="Time-Ruler">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1952536945" ENDARROW="Default" ENDINCLINATION="136;-157;" ID="Arrow_ID_1459742640" SOURCE="ID_991484939" STARTARROW="None" STARTINCLINATION="112;0;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544849233126" ID="ID_904348697" MODIFIED="1557498707228" TEXT="#1195 Timecode Ruler">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1554996306756" ID="ID_1619835790" MODIFIED="1557498707228" TEXT="auf spezielle Konfig eines "Ruler-Tracks" zurückführen">
|
|
<arrowlink DESTINATION="ID_80922465" ENDARROW="Default" ENDINCLINATION="343;0;" ID="Arrow_ID_630173444" STARTARROW="None" STARTINCLINATION="376;0;"/>
|
|
</node>
|
|
<node CREATED="1555080526516" ID="ID_1733081392" MODIFIED="1557498707228">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: <i><font color="#bb4444">muß immer sichtbar sein</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1555080572765" ID="ID_577805455" MODIFIED="1576282358065" TEXT="im Detail etwas komplexer...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber es bleibt bei diesem Prinzip.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Des Genaueren, es gibt eine jeweils festgesetzte Menge von Elementen
|
|
</p>
|
|
<p>
|
|
am Anfang des Track-Profils, welche immer sichtbar bleiben soll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_577805455" ENDARROW="Default" ENDINCLINATION="146;-10;" ID="Arrow_ID_228489961" SOURCE="ID_447173098" STARTARROW="Default" STARTINCLINATION="110;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1555082672083" FOLDED="true" ID="ID_1185653910" MODIFIED="1679361573803" TEXT="BodyCanvasWidget">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1555082682753" ID="ID_1277383747" MODIFIED="1557498707228" TEXT="verwaltet und organisiert die Struktur">
|
|
<node CREATED="1555082693273" ID="ID_723726755" MODIFIED="1557498707228" TEXT="hat zwei konkrete TimelineCanvas">
|
|
<node CREATED="1555082703199" ID="ID_81861736" MODIFIED="1557498707228" TEXT="oben für den Time-Ruler"/>
|
|
<node CREATED="1555082710728" ID="ID_676334326" MODIFIED="1557498707228" TEXT="unten für die Track-Struktur"/>
|
|
</node>
|
|
<node CREATED="1672872295046" ID="ID_1036782095" MODIFIED="1672872302033" TEXT="srolled pane">
|
|
<node CREATED="1672874821582" ID="ID_561243870" MODIFIED="1672874837608" TEXT="jeder Canvas sitzt in einem ScrolledWindow"/>
|
|
<node CREATED="1672874838956" ID="ID_1009639331" MODIFIED="1672874865844" TEXT="aber nur für die contentArea sind die Scrollbars sichtbar"/>
|
|
<node CREATED="1672874867008" ID="ID_1904830870" MODIFIED="1672875337286" TEXT="der Ruler-Canvas läuft als Slave horizontal mit (und belegt stets/spreizend die volle Höhe)">
|
|
<linktarget COLOR="#6bbdbc" DESTINATION="ID_1904830870" ENDARROW="Default" ENDINCLINATION="693;23;" ID="Arrow_ID_1587189163" SOURCE="ID_850567919" STARTARROW="None" STARTINCLINATION="39;-248;"/>
|
|
</node>
|
|
<node CREATED="1672874901515" ID="ID_607550188" MODIFIED="1672874927495" TEXT="das Track-Head Patchbay-Widget läuft als Slave beim vertikalen Scrolling mit"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555198475915" ID="ID_216668392" MODIFIED="1557498707228" TEXT="Koordinieren der draw-Aktivität">
|
|
<node CREATED="1555198484257" ID="ID_447173098" MODIFIED="1557498707228" TEXT="Problem: Aufteilung">
|
|
<arrowlink DESTINATION="ID_577805455" ENDARROW="Default" ENDINCLINATION="146;-10;" ID="Arrow_ID_228489961" STARTARROW="Default" STARTINCLINATION="110;0;"/>
|
|
<node CREATED="1555198495266" ID="ID_118142711" MODIFIED="1557498707228" TEXT="was kommt in den (immer sichtbaren) oberen Teil?"/>
|
|
<node CREATED="1555198558887" FOLDED="true" ID="ID_1718337163" MODIFIED="1674596977895" TEXT="Beide Canvas-Instanzen verwenden das gleiche Koordinatensystem">
|
|
<arrowlink DESTINATION="ID_1220970686" ENDARROW="Default" ENDINCLINATION="-532;0;" ID="Arrow_ID_1730442283" STARTARROW="None" STARTINCLINATION="377;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#990000" CREATED="1563143974534" HGAP="122" ID="ID_130702763" MODIFIED="1674596984363" TEXT="wirklich?" VSHIFT="-39">
|
|
<linktarget COLOR="#744479" DESTINATION="ID_130702763" ENDARROW="Default" ENDINCLINATION="687;939;" ID="Arrow_ID_32276313" SOURCE="ID_43945835" STARTARROW="Default" STARTINCLINATION="199;-719;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1563143996702" ID="ID_1893904282" MODIFIED="1563144019155" TEXT="im Momment (7/2019) verwende ich eine laufende (pixel)-Zeile"/>
|
|
<node CREATED="1563144020688" ID="ID_1371868080" MODIFIED="1563144028227" TEXT="die startet jeweils bei 0"/>
|
|
<node CREATED="1563144029219" ID="ID_738243832" MODIFIED="1563144048228" TEXT="und wird für jedes Struktur-Element mit dem Offset beaufschlagt"/>
|
|
<node CREATED="1563144049378" ID="ID_1567458686" MODIFIED="1563144067157" TEXT="Konsequenz: jeder Canvas hat seine eigenen Koordinaten"/>
|
|
<node CREATED="1674596957963" ID="ID_1673725434" MODIFIED="1674596971193" TEXT="dieser Ansatz hat sich bewährt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555198633466" FOLDED="true" ID="ID_780787053" MODIFIED="1560442064470" TEXT="Auf Interpretieren des Struktur-Profils zurückgeführt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1555247298877" ID="ID_1739468610" MODIFIED="1560442477849" TEXT="das muß dann aber verallgemeinert wertden">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1555247361420" ID="ID_1263829263" MODIFIED="1576282358064" TEXT="warum?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil Verallgemeinern einer einzigen Aktion
|
|
</p>
|
|
<p>
|
|
stets besser ist, als repetitives aufdoppeln und variieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555247377809" ID="ID_281745763" MODIFIED="1576282358064" TEXT="Erwartete Anforderungen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
content renderer
|
|
</li>
|
|
<li>
|
|
vom speziellen Track abhängige Bereichsmarkierungen
|
|
</li>
|
|
<li>
|
|
lokale und spezielle Overlays sind zu zeichnen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555247320686" FOLDED="true" ID="ID_1896093043" MODIFIED="1576974421702" TEXT="brauche Visitor mit flexiblen Argumenten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555247502178" ID="ID_297247554" MODIFIED="1557498707228" TEXT="Anforderung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1555247509182" ID="ID_184476156" MODIFIED="1557498707228" TEXT="funktioniert genauso wie Visitor im Diff, mit Verb-Tokens"/>
|
|
<node CREATED="1555247526934" ID="ID_679986589" MODIFIED="1557498707228" TEXT="aber jedes Verb nimmt andere Argumente"/>
|
|
<node CREATED="1555247545556" ID="ID_425297916" MODIFIED="1557498707228" TEXT="brauche in-Place Storage (wie ein union)"/>
|
|
<node CREATED="1555247559370" ID="ID_1379389656" MODIFIED="1557498707228" TEXT="soll insgesamt typsicher bleiben"/>
|
|
<node CREATED="1555247580247" ID="ID_54654021" MODIFIED="1557498707228" TEXT="aber nur 2 Indirektionen (double dispatch)"/>
|
|
</node>
|
|
<node CREATED="1555247609372" ID="ID_984933888" MODIFIED="1557498707228" TEXT="Konzept/Ansatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1555247614626" ID="ID_279811814" MODIFIED="1557498707228" TEXT="das Verb-Token mit einem Union-Argument verwenden"/>
|
|
<node CREATED="1555247635823" ID="ID_893471557" MODIFIED="1557498707228" TEXT="und dieses Setup in einen Adapter / Builder verpacken"/>
|
|
<node CREATED="1555247665396" ID="ID_1210108422" MODIFIED="1557498707228" TEXT="vermutlich werden Lambdas eine Rolle spielen"/>
|
|
<node CREATED="1555247678988" ID="ID_1615700205" MODIFIED="1557498707228" TEXT="aber ich möchte Heap-Storage vermeiden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555247704342" ID="ID_929740643" MODIFIED="1561827465269" TEXT="Entwurf/Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1555247713060" ID="ID_1159666241" MODIFIED="1557590555065" TEXT="proof-of-concept">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555247744121" ID="ID_1280520595" MODIFIED="1557498707228" TEXT="ausgehend von Kopie des VerbToken"/>
|
|
<node CREATED="1555247757037" FOLDED="true" ID="ID_1249615365" MODIFIED="1561827483833" TEXT="(optional) vielleicht letztlich in eine Lösung verschmelzen?">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1557590535366" ID="ID_568258701" MODIFIED="1557590538950" TEXT="vermutlich ehr nicht"/>
|
|
<node CREATED="1557590539635" ID="ID_1843674392" MODIFIED="1557590549256" TEXT="da PolymorphicValue doch recht komplex ist"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555806526685" ID="ID_192016641" MODIFIED="1557590525234" TEXT="Lösungsansatz: PolymorphicValue">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555806541914" ID="ID_1260020116" MODIFIED="1576282358063" TEXT="der bietet genau den flexiblen inline-Buffer, den ich hier brauche">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich mit minimalem Admin-Overhead,
|
|
</p>
|
|
<p>
|
|
indem er sich auf die VTable des einzubettenden Typs abstützt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Die andere Alternative, der OpaqueHolder, verwendet selber nochmal einen zustäzlichen virtuellen Holder,
|
|
</p>
|
|
<p>
|
|
und Variant paßt auch nicht, da ich ja mit Template-generierten Subklassen arbeite,
|
|
</p>
|
|
<p>
|
|
und daher nicht a priori die Liste aller einzubettenden Varianten kenne
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555806670026" FOLDED="true" ID="ID_604641822" MODIFIED="1561827483833" TEXT="Probleme bei der Umsetzung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555807073875" FOLDED="true" ID="ID_1971528084" MODIFIED="1561827482929" TEXT="std::apply verwenden">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1555807086938" ID="ID_354296634" MODIFIED="1557498707228" TEXT="gitbts noch nicht auf Debian-Stretch"/>
|
|
<node CREATED="1555807099280" ID="ID_1984270952" MODIFIED="1557498707228" TEXT="nachprogrammieren / extrahieren...?"/>
|
|
<node CREATED="1555807110911" FOLDED="true" ID="ID_1729201379" MODIFIED="1561827469157" TEXT="Ist auch nicht ohne Weiteres anwendbar auf den vorliegenden Fall">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1555807137136" ID="ID_1357571620" MODIFIED="1557498707228" TEXT="wir haben ein zusätzliches erstes Argument">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich hier der Visitor, der den Aufruf letztlich emfpängt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555807172534" ID="ID_473316032" MODIFIED="1557498707228" TEXT="das müßte man dann in das Tupel reinfrickeln"/>
|
|
<node CREATED="1555807181534" ID="ID_484250647" MODIFIED="1557498707228" TEXT="und dann auch noch den double-Dispatcher (hier das VerbToken) in einen Funktor wickeln"/>
|
|
<node CREATED="1555807203432" ID="ID_1628579018" MODIFIED="1557498707228" TEXT="dann besser direkt ausprogrammieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555806696990" FOLDED="true" ID="ID_1464210384" MODIFIED="1561827482929" TEXT="kann nicht Tuple-Element per std::forward weitergeben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1555806733962" ID="ID_1424612840" MODIFIED="1557498707228" TEXT="Compiler möchte eine RValue-Referenz"/>
|
|
<node CREATED="1555806760125" FOLDED="true" ID="ID_1741677842" MODIFIED="1561827469157" TEXT="workaround: das Tuple selber per std::forward an std::get übergeben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1555806782283" ID="ID_1783286457" MODIFIED="1557498707228" TEXT="das machen andere anscheinend auch so"/>
|
|
<node CREATED="1555806792065" ID="ID_1773083646" MODIFIED="1557498707228" TEXT="Beispiel: die Textbook-Implementierung von std::apply"/>
|
|
<node CREATED="1555806824441" ID="ID_948993908" MODIFIED="1557498707228" TEXT="Resultat: aus dem std::get fällt eine rvalue-Referenz raus"/>
|
|
<node CREATED="1555806920309" ID="ID_1549876372" MODIFIED="1557498707228" TEXT="das könnte sogar das Standard-Baumuster für "perfect forwarding" sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es handelt sich hierbei um einen Konstruktionstrick.
|
|
</p>
|
|
<p>
|
|
Scott Meyers spricht deshalb auch immer von "unverersal references" und unterscheidet
|
|
</p>
|
|
<p>
|
|
diese von einer expliziten RValue-Referenz.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Demnach wäre das Standard-Baumuster, daß alle Glieder <b>in</b>  der perfect-forwarding-Kette
|
|
</p>
|
|
<p>
|
|
per universal-Reference miteinander verbunden sind. Und im Konkreten fall muß man
|
|
</p>
|
|
<p>
|
|
das so hintricksen, indem man die std::get-Funktion passend bestückt...
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Au weia
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1557437798675" ID="ID_474705115" MODIFIED="1557498707228" TEXT="aus letztlich nicht geklärten Gründen ist mir das nicht gelungen...">
|
|
<arrowlink COLOR="#f05859" DESTINATION="ID_656447545" ENDARROW="Default" ENDINCLINATION="45;-420;" ID="Arrow_ID_1477395313" STARTARROW="None" STARTINCLINATION="649;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1555806839235" FOLDED="true" ID="ID_1636335140" MODIFIED="1561827469157" TEXT="ist der workaround gefährlich?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1555806851177" ID="ID_1212118219" MODIFIED="1557498707228" TEXT="d.h. kommt am Ende nicht doch ein RValue an?"/>
|
|
<node CREATED="1555806866887" ID="ID_815971236" MODIFIED="1557498707228" TEXT="auch dann nicht: wenn die Funktion einen RValue verlangt??"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#3a0099" CREATED="1555806884936" FOLDED="true" ID="ID_1433427722" MODIFIED="1561827469137" TEXT="per Experiment verifizieren">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1555895525635" ID="ID_1402481371" MODIFIED="1557498707228" TEXT="(verwende eine ctor-tracking-Klasse)"/>
|
|
<node COLOR="#338800" CREATED="1555895463799" ID="ID_1147400949" MODIFIED="1557498707228" TEXT="Fehler entdeckt: ctor gibt Args per Value an das Tupel">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1555895488721" ID="ID_1447172232" MODIFIED="1557498707228" TEXT="JA! Es passiert eine move-Initialisierung">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555947349235" FOLDED="true" ID="ID_599059144" MODIFIED="1561827469157" TEXT="Lösung gesucht....">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555947359783" FOLDED="true" ID="ID_1366291443" MODIFIED="1561827469137" TEXT="noch schlimmer...">
|
|
<node CREATED="1555947367949" ID="ID_1145455475" MODIFIED="1557498707228" TEXT="auch die Textbook-Impl von std::apply funktioiniert genauso">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. std::get<idx> (std::forward<TUP> (tuple))
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555947482051" ID="ID_814853878" MODIFIED="1557498707228" TEXT="...und produziert den gleichen Compiler-Fehler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ich das Tupel als Referenz anliefere
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1555947514403" FOLDED="true" ID="ID_1459759406" MODIFIED="1561827469137" TEXT="Kann den Fehler isoliert nicht nachstellen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1555947535499" ID="ID_218400480" MODIFIED="1557498707228" TEXT="try.cpp"/>
|
|
<node CREATED="1555947538554" ID="ID_1700362760" MODIFIED="1557498707228" TEXT=""sinngemäß" nachgebaut"/>
|
|
<node CREATED="1555947549617" ID="ID_386072993" MODIFIED="1557498707228" TEXT="das compiliert problemlos"/>
|
|
<node CREATED="1555947561535" ID="ID_858467762" MODIFIED="1557498707228" TEXT="und macht LValue-Initialisierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sichtbar wenn man ein Trackr-Objekt
|
|
</p>
|
|
<p>
|
|
als value-Parameter auf der Zielfunktion verwendet.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Im extrahierten Beispiel wird das LValue-copy-initialisiert
|
|
</p>
|
|
<p>
|
|
wohingegen im realen code, wo auch das std::forward(tuple) dabei ist,
|
|
</p>
|
|
<p>
|
|
der betreffende Wert dann RValue-Initialisiert wird, d.h. dabei das betreffende Tupel-Element konsumiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1555947661358" FOLDED="true" ID="ID_917133929" MODIFIED="1561827465275" TEXT="Ich seh den Unterschied nicht">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1555947705866" ID="ID_139554682" MODIFIED="1557498707228" TEXT="warum akzeptiert der Compiler die korrekte variante im realen Code nicht??"/>
|
|
<node CREATED="1555947747068" ID="ID_1646796994" MODIFIED="1557498707228" TEXT="für mich sind beide Varianten (try.cpp und verb-visitor.hpp) äquivaltent"/>
|
|
<node CREATED="1555947795281" FOLDED="true" ID="ID_1250854173" MODIFIED="1561827465275" TEXT="für den Compiler anscheinend nicht">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1555947814658" ID="ID_1580965808" MODIFIED="1557498707228" TEXT="das könne ein Ansatzpunkt sein">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1557414354359" FOLDED="true" ID="ID_961298704" MODIFIED="1561827465275" TEXT="Problem ist die aufgerufene Ziel-Funktion">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1557414397598" ID="ID_1788944843" MODIFIED="1557498707228" TEXT="der std::apply-Mechanismus funktioniert nur direkt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h er funktioniert nur, wenn man das std::get<idx> (tuple) unmittelbar an den jeweiligen Ziel-Parameter bindet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1557414442871" ID="ID_501615874" MODIFIED="1557498707228" TEXT="dagegen std::forward wählt flexibel einen von zwei overloads">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich einen, der einen LValue entgegennimmt
|
|
</p>
|
|
<p>
|
|
und einen, der einen RValue entgegennimmt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1557414483962" FOLDED="true" ID="ID_656447545" MODIFIED="1561827465275" TEXT="und dies kann ich hier nicht nachbilden">
|
|
<linktarget COLOR="#f05859" DESTINATION="ID_656447545" ENDARROW="Default" ENDINCLINATION="45;-420;" ID="Arrow_ID_1477395313" SOURCE="ID_474705115" STARTARROW="None" STARTINCLINATION="649;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1557414503009" ID="ID_1020774626" MODIFIED="1557498707228" TEXT="hab schon dutzend Varianten versucht"/>
|
|
<node CREATED="1557435536324" ID="ID_13398656" MODIFIED="1557498707228" TEXT="Overload-Resolution hilft hier nicht"/>
|
|
<node CREATED="1557435548361" ID="ID_1786798505" MODIFIED="1557498707228" TEXT="würde enable_if brauchen"/>
|
|
<node CREATED="1557435559616" ID="ID_17287871" MODIFIED="1557498707228" TEXT="Stop">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
steht in keinem Verhältnis zum Zweck
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1557435595988" ID="ID_1773619805" MODIFIED="1557498707228" TEXT="abgebrochen, da unverhältnismäßig">
|
|
<arrowlink COLOR="#a98ca6" DESTINATION="ID_1691540337" ENDARROW="Default" ENDINCLINATION="2957;477;" ID="Arrow_ID_1272525320" STARTARROW="None" STARTINCLINATION="-1064;82;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1557414529997" FOLDED="true" ID="ID_45981411" MODIFIED="1561827469138" TEXT="mögliche Workarounds...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1557414537652" FOLDED="true" ID="ID_1792457460" MODIFIED="1561827465275" TEXT="VerbToken könnte Tuple akzeptieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1557435467103" ID="ID_1297559972" MODIFIED="1557498707229" TEXT="separation of concerns">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1557414564399" FOLDED="true" ID="ID_1249046596" MODIFIED="1561827465275" TEXT="VerbToken könnte den Holder als friend deklarieren">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1557414591836" ID="ID_1605277239" MODIFIED="1557498707229" TEXT="dieser würde dann auf den verb.handler_ zugreifen"/>
|
|
<node CREATED="1557414609249" ID="ID_1627303905" MODIFIED="1557498707229" TEXT="und den Aufruf direkt an's Ziel bringen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1557435436241" FOLDED="true" ID="ID_1083947599" MODIFIED="1561827465275" TEXT="Alternative: erben">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1557437869440" ID="ID_1916606467" MODIFIED="1557498707229" TEXT="das ist elegant"/>
|
|
<node CREATED="1557437880426" ID="ID_548782535" MODIFIED="1557498707229" TEXT="und logisch konsistent"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555807238238" FOLDED="true" ID="ID_383098394" MODIFIED="1561827482929" TEXT="Copy-Support von PolymorphicValue ist "komisch"">
|
|
<arrowlink COLOR="#829ebf" DESTINATION="ID_596556632" ENDARROW="Default" ENDINCLINATION="-282;0;" ID="Arrow_ID_1622655110" STARTARROW="None" STARTINCLINATION="-74;193;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1555807266221" ID="ID_262959695" MODIFIED="1557498707229" TEXT="nach heutigem Stand: unbeholfen implementiert"/>
|
|
<node CREATED="1555807285055" ID="ID_1456730365" MODIFIED="1557498707229" TEXT="braucht expliziten Support vom Payload typ"/>
|
|
<node CREATED="1555807297726" ID="ID_1905059435" MODIFIED="1557498707229" TEXT="das wäre heute gar nicht mehr notwendig"/>
|
|
<node CREATED="1555807489204" ID="ID_1385287282" MODIFIED="1557498707229" TEXT="Ausführung ist lückenhaft, und teilweise nicht korrekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel: Wenn der Typ selber keinen Support anbietet,
|
|
</p>
|
|
<p>
|
|
dann nehmen wir immer das volle CopySupport-API, und differenzieren nicht
|
|
</p>
|
|
<p>
|
|
mehr nach Typen mit reinem clone-support. Was dann tatsächlich dazu führt,
|
|
</p>
|
|
<p>
|
|
daß der Compiler verucht, den Zuweisungsoperator zu verwernden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555807646555" FOLDED="true" ID="ID_84342308" MODIFIED="1561827469157" TEXT="CloneValueSupport nicht (korrekt) erkannt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555807666086" ID="ID_1670738915" MODIFIED="1557498707229" TEXT="offensichtlich wird die falsche Trait-Variante gewählt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich diejenige für Typen ohne Support auf dem API.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555807724232" ID="ID_1817680115" MODIFIED="1557498707229" TEXT="und das, obwohl ich CloneValueSupport als Basis verwendet habe"/>
|
|
<node CREATED="1557446452899" ID="ID_454930922" MODIFIED="1557498707229" TEXT="META_DETECT_FUNCTION erkennt keine geerbten Methoden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn diese Duck-Detector-Metafunktion bildet den <b>Typ</b> eines Member-Pointers,
|
|
</p>
|
|
<p>
|
|
und dieser Typ enthält explizit den statischen Namen der Klasse, welche die gewünschte Methode trägt.
|
|
</p>
|
|
<p>
|
|
Und wenn man eine Methode bloß erbt, dann existiert diese Methode, statisch, nur auf der Basisklasse.
|
|
</p>
|
|
<p>
|
|
Also ist das sogar das korrekte Verhalten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1557446482447" FOLDED="true" ID="ID_835188518" MODIFIED="1561827469138" TEXT="Lösung: Duck-Detector für Methoden-Name">
|
|
<node CREATED="1557446494679" ID="ID_1259664145" MODIFIED="1557498707229" TEXT="verzichtet auf Signatur-Check">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wenn zufällig das Interface auch eine Methode CloneInto() enthält, aber mit einer unpassenden Signatur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1557446561925" ID="ID_1267977919" MODIFIED="1557498707229" TEXT="ist ohnehin keine wirkliche Sicherheit"/>
|
|
<node CREATED="1557446503084" ID="ID_1518606339" MODIFIED="1557498707229" TEXT="würde ohnehin später beim Compilieren scheitern"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1557446627092" ID="ID_805659416" MODIFIED="1557498707229" TEXT="mit #1197 hinfällig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil ich dann explizit ein bestimmtes Basis-Interface verlangen werde,
|
|
</p>
|
|
<p>
|
|
nämlich VirtualCopySupport<IFA>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
das ist auch gut so, zu viel Flexibilität schadet (besonders, wenn man sie dann gar nicht unterstützt)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1557446881265" FOLDED="true" ID="ID_743886485" MODIFIED="1561827469138" TEXT="Folgeproblem: ambiguous base class">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1557446902070" ID="ID_1511315997" MODIFIED="1557498707229" TEXT="kommt davon, wenn man mehrfach polyvalue::EmptyBase verwendet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil nämlich der Trait, für den optimalen Fall, ebenfalls die EmptyBase verwendet, um den Mix-In zu deaktivieren.
|
|
</p>
|
|
<p>
|
|
Leider haben wir dann zweimal die gleiche Basisklasse in beiden Zweigen der multiple inheritance...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1557446924907" ID="ID_1029661613" MODIFIED="1557498707229" TEXT="...was hier absolut naheliegend ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich immer dann, wenn man tatsächlich den CopySupport oder CloneSupport als Basis des Interfaces verwendet...
|
|
</p>
|
|
<p>
|
|
(was ich bisher in der Praxis so noch nie gemacht habe)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1557447075623" ID="ID_1422873677" MODIFIED="1557498707229" TEXT="dummerweise kann dann der GCC die EmptyBase nicht wegoptimieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was sich dann in einer Static-Assertion-Failure äußert.
|
|
</p>
|
|
<p>
|
|
hab das ganz explizit ausgeknobelt, es fehlt hier genau dieser eine zusätzliche "Slot"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1557447159900" ID="ID_691196423" MODIFIED="1557498722522" TEXT="Lösung: anderen Namen verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555807305357" FOLDED="true" ID="ID_1511870599" MODIFIED="1561827469157" TEXT="Plan: PolymorphicValue überarbeiten">
|
|
<arrowlink COLOR="#1a64bc" DESTINATION="ID_596556632" ENDARROW="Default" ENDINCLINATION="-129;0;" ID="Arrow_ID_884404467" STARTARROW="None" STARTINCLINATION="-284;0;"/>
|
|
<node CREATED="1555807415718" ID="ID_639233049" MODIFIED="1557498707229" TEXT="mit "VirtualCopySupport" von meiner Variant-Implementierung zusammenführen"/>
|
|
<node CREATED="1555807443642" ID="ID_90620144" MODIFIED="1557498707229" TEXT="sollte selbständig erkennen, ob der Zieltyp kopierbar ist"/>
|
|
<node CREATED="1555807464657" ID="ID_1089528099" MODIFIED="1557498707229" TEXT="diese meta-Intelligenz sollte komplett in dem Adapter stecken"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1557446611550" ID="ID_596556632" MODIFIED="1557590501784" TEXT="Ticket #1197 : rationalise copy support in PolymorphicValue">
|
|
<linktarget COLOR="#829ebf" DESTINATION="ID_596556632" ENDARROW="Default" ENDINCLINATION="-282;0;" ID="Arrow_ID_1622655110" SOURCE="ID_383098394" STARTARROW="None" STARTINCLINATION="-74;193;"/>
|
|
<linktarget COLOR="#1a64bc" DESTINATION="ID_596556632" ENDARROW="Default" ENDINCLINATION="-129;0;" ID="Arrow_ID_884404467" SOURCE="ID_1511870599" STARTARROW="None" STARTINCLINATION="-284;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1555807762543" FOLDED="true" ID="ID_1645640007" MODIFIED="1561827482929" TEXT="Problem: Puffergröße">
|
|
<node CREATED="1555807778751" ID="ID_1563586526" MODIFIED="1557498707229" TEXT="PolymorphicValue verlangt, daß man die Puffergröße als Template-Argument definiert"/>
|
|
<node CREATED="1555807802562" ID="ID_1845631121" MODIFIED="1557498707229" TEXT="hier hängt diese aber von der Storage für die Funktionsargumente ab."/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1555807833997" FOLDED="true" ID="ID_1153160392" MODIFIED="1561827469158" TEXT="Idealfall: das müßte automatisch funktionieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1555807861314" ID="ID_352919826" MODIFIED="1557498707229" TEXT="geht das überhaupt?"/>
|
|
<node CREATED="1555807866689" ID="ID_1851833268" MODIFIED="1557498707229" TEXT="würde vermutlich auf ein Builder-Konstrukt hinauslaufen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...etwas analog zu meinem TreeMutator.
|
|
</p>
|
|
<p>
|
|
D.h. man muß alle verwendeten Signaturen auf dem Receiver
|
|
</p>
|
|
<p>
|
|
erst mal in einem Builder-Konstrukt gewissermaßen "registrieren", um dann den passenden
|
|
</p>
|
|
<p>
|
|
VerbPack-Typ konstruiert zu bekommen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555807962932" ID="ID_378229584" MODIFIED="1557498707229" TEXT="bisher hat meine Lösung aber grade den einen Vorteil, komplet "ad hoc" zu sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. man erzeugt in einem einzigen Aufruf den VerbPack für eine Zielfunktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1557590275193" ID="ID_756824768" MODIFIED="1557590280062" TEXT="YAGNI">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555807845319" ID="ID_1999765895" MODIFIED="1557590260752" TEXT="Halbe Lösung: wenigstens eine Hilfsfunktion bereitstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555808026434" FOLDED="true" ID="ID_1634107778" MODIFIED="1561827482929" TEXT="automatische Konversionen für konkrete Argumente">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555808055328" ID="ID_1683773555" MODIFIED="1557498707229" TEXT="der VerbPack - Konstruktor sollte sich genau so verhalten wie die Zielfunktion">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1555808100082" ID="ID_1008688397" MODIFIED="1557498707229" TEXT="Beispiel: Zielfunktion nimmt einen std::string, gegeben ist ein C-String-Literal"/>
|
|
<node CREATED="1555808124882" ID="ID_364451047" MODIFIED="1557498707229" TEXT="aktuell wird exakt der korrekte Typ erwartet"/>
|
|
<node CREATED="1555808138474" ID="ID_847234596" MODIFIED="1557590439076" TEXT="Grund: Funktionsweise der Teplate-Argument-Inferenz">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1555808184873" FOLDED="true" ID="ID_804931772" MODIFIED="1561827469158" TEXT="sinnvoller Workaround">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1555808201687" ID="ID_191950649" MODIFIED="1557498707229" TEXT=""Zwiebelschalen-Konstrukt"??">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwei verschachtelte, delegierende Konstruktoren,
|
|
</p>
|
|
<p>
|
|
von denen der zweite, innere die eigentliche Typinferenz macht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1557590299574" ID="ID_1634972448" MODIFIED="1557590314138" TEXT="rein zufällig delegiere ich bereits über zwei Konstrukturen"/>
|
|
<node COLOR="#338800" CREATED="1557590314884" ID="ID_1086686390" MODIFIED="1557590420718" TEXT="also einfach die Argument-Typen vom Funktions-Handler nehmen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anstatt, wie es die bisherige (naive) implementierung macht,
|
|
</p>
|
|
<p>
|
|
die typename ARGS... auch dafür zu verwenden, den Handler-Typ zu konstruieren.
|
|
</p>
|
|
<p>
|
|
Mit diesem einfachen Kniff passiert die Konvertierung dann in dem Moment,
|
|
</p>
|
|
<p>
|
|
wo wir die konkreten Argumente in den vorbereiteten Argument-Tupel im Holder schieben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1555808280478" FOLDED="true" ID="ID_59896827" MODIFIED="1561827483833" TEXT="Testabdeckung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1557590726512" ID="ID_1345932776" MODIFIED="1557590812617" TEXT="mehrere verschiedene Receiver">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1557590733137" ID="ID_297834334" MODIFIED="1557590812186" TEXT="Kopier-Verhalten im Detail untersucht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...jeodch nicht eigens im Test dokumentiert
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
weil das sehr aufwendig wäre und den kompletten Test dominieren würde
|
|
</li>
|
|
<li>
|
|
weil die Implementierung (in dieser Hinsicht) letztlich banal ist: Anwenden eines Tupel auf eine Funktion
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1557590794163" ID="ID_497379433" MODIFIED="1557590811601" TEXT="Werte kopiert und verglichen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1557590805129" ID="ID_158433397" MODIFIED="1557590810851" TEXT="ausführlich kommentiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1555808288856" ID="ID_1931717111" MODIFIED="1557590603605" TEXT="Frage: ist das Design gut?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1555808300703" ID="ID_621465643" MODIFIED="1576282358063" TEXT="kann/sollte die Lösong mehr integriert sein?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sollten z.B. die Konstruktor-Funktionen nicht unmittelbar mit definiert werden?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555808311417" ID="ID_1932269477" MODIFIED="1576282358062" TEXT="oder ist es grade ein Vorteil, wenn sie ein roher Baustein ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil man stets noch einen Layer darübersetzt?
|
|
</p>
|
|
<p>
|
|
Wie auch im konkreten Fall das TrackProfile, was dann ein vector<VerbPack> werden würde?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#fcda04" DESTINATION="ID_1932269477" ENDARROW="Default" ENDINCLINATION="290;0;" ID="Arrow_ID_742389536" SOURCE="ID_128501904" STARTARROW="None" STARTINCLINATION="187;8;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1557590616683" ID="ID_128501904" MODIFIED="1576282358062" TEXT="ich halte es jetzt für gelungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil ich es geschafft habe,
|
|
</p>
|
|
<p>
|
|
den gesamten Auswahl-Mechanismus in einen einzigen Konstruktur-Aufruf zu packen.
|
|
</p>
|
|
<p>
|
|
Man kann also nach Belieben VerbPacks in allen Varianten bauen,
|
|
</p>
|
|
<p>
|
|
und es obliegt der nächst höheren Schicht, dies auch in sinnvollem Rahmen zu tun...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fcda04" DESTINATION="ID_1932269477" ENDARROW="Default" ENDINCLINATION="290;0;" ID="Arrow_ID_742389536" STARTARROW="None" STARTINCLINATION="187;8;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1557590586650" ID="ID_1348312855" MODIFIED="1560442031421" TEXT="den (neu gebauten) VerbPack integrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560175373902" ID="ID_1956293405" MODIFIED="1560175561475" TEXT="bestehendes TrackProfile sinngemäß umbauen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560175492578" ID="ID_1159091213" MODIFIED="1560213489122" TEXT="Verb + explizite Storage -> VerbPack">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1560213502726" ID="ID_1476369075" MODIFIED="1560213516539" TEXT="läßt sich 1:1 umschreiben"/>
|
|
<node COLOR="#338800" CREATED="1560213581507" ID="ID_691911700" MODIFIED="1560213594489" TEXT="habe die Argumente sofort komplett flexibel gemacht">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560175383722" ID="ID_107500239" MODIFIED="1560213484696" TEXT="Problem: addSlopeUp()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560175410857" ID="ID_1553338375" MODIFIED="1560175429772" TEXT="bisher konnten wir einfach das Argument manipulieren"/>
|
|
<node CREATED="1560175430998" ID="ID_125919592" MODIFIED="1576282358061" TEXT="...aber jetzt gibt es nicht mehr "das" Argument">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sondern die Argumente sind in einem Tuple eingewickelt,
|
|
</p>
|
|
<p>
|
|
und befinden sich tief vergraben in der Implementierungsklasse,
|
|
</p>
|
|
<p>
|
|
innerhalb eines PolymorphicValue.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1560213397573" ID="ID_1416770885" MODIFIED="1576282358061" TEXT="und dann muß man eben explizit casten und auspacken!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist nur technisch und etwas häslich,
|
|
</p>
|
|
<p>
|
|
aber durchaus sauber (unter der Annahme, daß wir uns unsere Token
|
|
</p>
|
|
<p>
|
|
stets selbst erzeugen und daher auf das korrekte Literal Verlaß ist)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560175529230" ID="ID_914166338" MODIFIED="1560441859516">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verhältnis zum Inteface <b>Renderer</b> klären
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#508bd1" DESTINATION="ID_1592949721" ENDARROW="Default" ENDINCLINATION="59;-58;" ID="Arrow_ID_1618633786" STARTARROW="None" STARTINCLINATION="-91;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560303652840" ID="ID_1947607603" MODIFIED="1560303667034" TEXT="Konsequenz des generischen »Ruler«-Konzepts"/>
|
|
<node CREATED="1560303597884" ID="ID_1906099403" MODIFIED="1576282358060" TEXT="wurde notwendig wegen der Aufteilung in zwei Canvas">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vorher war nämlich das Profil im Canvas selber.
|
|
</p>
|
|
<p>
|
|
Jetzt ist das Profil in das BodyCanvasWidget hochgewandert,
|
|
</p>
|
|
<p>
|
|
und soll von beiden sub-Canvas gleichermaßen jeweils passend interpretiert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1560303745209" ID="ID_202529970" MODIFIED="1560303777782" TEXT="es ergeben sich 4 verschiedene Interpretierungen eines einzigen Profils">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560175579123" FOLDED="true" ID="ID_678068478" MODIFIED="1576974455512" TEXT="in generische draw()-Routine einbinden">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1560175593361" ID="ID_1592949721" MODIFIED="1560442019836" TEXT="wo kommt der Renderer ins Spiel?">
|
|
<linktarget COLOR="#508bd1" DESTINATION="ID_1592949721" ENDARROW="Default" ENDINCLINATION="59;-58;" ID="Arrow_ID_1618633786" SOURCE="ID_914166338" STARTARROW="None" STARTINCLINATION="-91;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560303801546" ID="ID_1150937962" MODIFIED="1560442045382" TEXT="Renderer verkapselt das Profil">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1560303861175" ID="ID_1281704590" MODIFIED="1576282358060" TEXT="Renderer ist ein einmal-wegwerf-Objekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...daher die Factory
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560303951038" ID="ID_353953611" MODIFIED="1576282358059" TEXT="Frage: wirklich zweistufig konstruieren??">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ol>
|
|
<li>
|
|
getXxxRenderer(CairoC) -> packt Profil ein
|
|
</li>
|
|
<li>
|
|
Renderer.drawTo(canvas)
|
|
</li>
|
|
</ol>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1560428273738" ID="ID_149938310" MODIFIED="1560428299172" TEXT="was hab ich mir vor ein paar Monaten wohl gedacht??!"/>
|
|
<node CREATED="1560428302521" FOLDED="true" ID="ID_616331969" MODIFIED="1561827483833" TEXT="Anlaß war wohl der Unterschied zwischen Canvas und CairoContext">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1560428573068" ID="ID_1838989620" MODIFIED="1560428581790" TEXT="Canvas == Container für "Zukunft""/>
|
|
<node CREATED="1560428585872" ID="ID_1746909203" MODIFIED="1560428593856" TEXT="CairoContext: da zeichnet man konkret"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560304378008" ID="ID_1402776173" MODIFIED="1560441942501" TEXT="vereinfachen...?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1560304395781" ID="ID_1496832477" MODIFIED="1560428268414" TEXT="_RenderFactory fällt weg">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1560304412203" FOLDED="true" ID="ID_1976247827" MODIFIED="1561827483833">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Renderer <i>ist</i> bereits der Funktor
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1560304535209" ID="ID_1225485882" MODIFIED="1560304560890" TEXT="void(TimelineCanvas&)"/>
|
|
<node CREATED="1560428691244" ID="ID_1126064182" MODIFIED="1560441982757" TEXT="Konsequenz: TimelineCanvas wird zum Interface">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560441983792" ID="ID_998159430" MODIFIED="1560442009273" TEXT="nein: alles Benötigte muß als Argument übergeben werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560304868565" FOLDED="true" ID="ID_471873086" MODIFIED="1561827483833" TEXT="brauchen wir überhaupt einen Funktor als weitere Indirektion?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1560304911496" ID="ID_241280957" MODIFIED="1560305044856" TEXT="macht nämlich drei Indirektionen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ol>
|
|
<li>
|
|
der Renderer. Abstrahiert welcher Interpreter wie genau zum Einsatz kommen soll (Hintergrund/Overla sowie Ruler/Content)
|
|
</li>
|
|
<li>
|
|
der konkrete Interpreter
|
|
</li>
|
|
<li>
|
|
die einzelnen Verben im Profil
|
|
</li>
|
|
</ol>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1560305049471" ID="ID_1228128138" MODIFIED="1560305059543" TEXT="könnte man 1) und 2) zusammenlegen?"/>
|
|
<node CREATED="1560305069484" ID="ID_488264100" MODIFIED="1560305090839" TEXT="d.h. der Renderer wäre zugleich ein Profil-Interpreter"/>
|
|
<node CREATED="1560441903171" ID="ID_220479717" MODIFIED="1560441921539" TEXT="nein: der Renderer konstruiert einen transienten Profil-Interpreter">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560175646834" ID="ID_585934033" MODIFIED="1561150742874" TEXT="Selektor für den relevanten Teil des Profils">
|
|
<linktarget COLOR="#235691" DESTINATION="ID_585934033" ENDARROW="Default" ENDINCLINATION="-259;-8;" ID="Arrow_ID_975721855" SOURCE="ID_1448105245" STARTARROW="Default" STARTINCLINATION="168;-53;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560442117286" ID="ID_1565882906" MODIFIED="1560442234529" TEXT="wir haben jetzt zwei Canvas">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1560442238349" ID="ID_1013135995" MODIFIED="1560442245202" TEXT="Overview-Ruler (always on top)"/>
|
|
<node CREATED="1560442245898" ID="ID_1189464925" MODIFIED="1560442253375" TEXT="Track Body (scrollable)"/>
|
|
</node>
|
|
<node CREATED="1560442129908" ID="ID_410132191" MODIFIED="1560442196351" TEXT="jeder muß nur den für ihn relevanten Teil rendern"/>
|
|
<node CREATED="1560442220007" ID="ID_92028891" MODIFIED="1560442229810" TEXT="ist nur eine Preformance-Optimierung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1560442262544" ID="ID_1220970686" MODIFIED="1560442514142" TEXT="wir verwenden einheitliche Koordinaten">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1220970686" ENDARROW="Default" ENDINCLINATION="-532;0;" ID="Arrow_ID_1730442283" SOURCE="ID_1718337163" STARTARROW="None" STARTINCLINATION="377;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1560442275246" ID="ID_1464324660" MODIFIED="1560442286901" TEXT="deshalb ist auch nur jeweils der relevante Teil sichtbar"/>
|
|
<node CREATED="1560442288690" ID="ID_106486844" MODIFIED="1560442318651" TEXT="trotzdem kann man hier die Hälfte der draw-Anweisungen einsparen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560442439507" FOLDED="true" ID="ID_1072410115" MODIFIED="1576974439609" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560612664570" ID="ID_487480098" MODIFIED="1563117887785" TEXT="wo steckt diese Info?">
|
|
<node CREATED="1560612681316" ID="ID_1320073999" MODIFIED="1560612835546" TEXT="bisher im Argument des Prelude-Verbs">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1560612691723" ID="ID_1955365339" MODIFIED="1576282358059" TEXT="das Prelude-Verb als Solches ist sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil man damit eine generische Klammer bauen kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1560612721690" ID="ID_1010565828" MODIFIED="1560612804974" TEXT="das Argument so zu nutzen ist schon etwas "pragmatisch"">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1560612743655" ID="ID_926510331" MODIFIED="1576282358058" TEXT="andererseits ist die Storage schon da....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und bleibt anderweitig ungenutzt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1560612790659" ID="ID_977261236" MODIFIED="1560612827353" STYLE="fork" TEXT="und für die up-Slope habe ich einen solchen Zugriff auch akzeptabel befunden">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1560612863371" FOLDED="true" ID="ID_161592739" MODIFIED="1563141484962" TEXT="alternativ könnte man ein Feld im Profil selber machen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1560612942381" ID="ID_1967930581" MODIFIED="1560612949943" TEXT="und das wäre etwa die gleiche Menge Code"/>
|
|
<node CREATED="1560612951033" ID="ID_850127059" MODIFIED="1560612963343" TEXT="und auch etwa gleichermaßen lesbar"/>
|
|
</node>
|
|
<node CREATED="1560613101287" ID="ID_4285270" MODIFIED="1576282358058" TEXT="einen Monat später fand ich dann doch ein dediziertes Feld im Profil-Objekt besser">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist klarer, und erlaubt nebenbei auch noch, zwei Methoden einzusparen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#304ed9" DESTINATION="ID_4285270" ENDARROW="None" ENDINCLINATION="751;409;" ID="Arrow_ID_1197384474" SOURCE="ID_189142395" STARTARROW="Default" STARTINCLINATION="603;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560618427589" FOLDED="true" ID="ID_713762696" MODIFIED="1561827483834" TEXT="wer generiert diese Info?">
|
|
<node CREATED="1560618449106" ID="ID_450355502" MODIFIED="1560618479666" TEXT="undurchdringbar verworren">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561150468059" ID="ID_725781646" MODIFIED="1561151353967" TEXT="muß wohl letztlich irgendwie aus der Session kommen">
|
|
<arrowlink COLOR="#ce7c94" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="509;0;" ID="Arrow_ID_1589685813" STARTARROW="None" STARTINCLINATION="296;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561150497032" ID="ID_617550585" MODIFIED="1563117862694" TEXT="Aufspalten des Profils">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561150521519" FOLDED="true" ID="ID_1498693390" MODIFIED="1561827482929" TEXT="Schei...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smiley-angry"/>
|
|
<node CREATED="1561150540851" ID="ID_490080987" MODIFIED="1561150545451" TEXT="noch eine Komplexität"/>
|
|
</node>
|
|
<node CREATED="1561150547674" ID="ID_1791753235" MODIFIED="1561150564863" TEXT="naja, eigentlich nur noch einen Zähler in die For-Loop einbauen"/>
|
|
<node CREATED="1561150569779" FOLDED="true" ID="ID_1587537475" MODIFIED="1561827482929" TEXT="ich will aber den Standardfall irgendwie erhalten">
|
|
<node CREATED="1561150585582" ID="ID_791249238" MODIFIED="1561150668295" TEXT="und sei es bloß zur Dokumentation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. ich will den Standardfall als Standardfall sichtbar haben,
|
|
</p>
|
|
<p>
|
|
und dann diese zusätzliche Filterung oben drauf pflanzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1561150616496" ID="ID_942796141" MODIFIED="1561150627953" TEXT="also irgendwie noch einen Dekorator bauen??">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561150669160" FOLDED="true" ID="ID_1043420247" MODIFIED="1561827482930" TEXT="Lösung mit einem Iterator-Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561150688515" ID="ID_1217282542" MODIFIED="1561150695224" TEXT="stateful counting Filter geht doch..."/>
|
|
<node CREATED="1561150696094" ID="ID_1756846313" MODIFIED="1561150726654" TEXT="sollte am Ende genauso effizient sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
als ob es darauf ankäme...
|
|
</p>
|
|
<p>
|
|
Hauptsache, keine zusätzliche Speicher-Allokation
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563118329642" ID="ID_337327442" MODIFIED="1563141708284" TEXT="Denkfehler: prelude() muß mitgezählt werden">
|
|
<linktarget COLOR="#25e58e" DESTINATION="ID_337327442" ENDARROW="Default" ENDINCLINATION="523;0;" ID="Arrow_ID_376180455" SOURCE="ID_1599825097" STARTARROW="Default" STARTINCLINATION="1063;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563118200356" ID="ID_1267787629" MODIFIED="1563118296820" TEXT="Gegenstück im draw()-Code">
|
|
<arrowlink COLOR="#44437f" DESTINATION="ID_1017084418" ENDARROW="Default" ENDINCLINATION="1682;-201;" ID="Arrow_ID_187242024" STARTARROW="None" STARTINCLINATION="1913;158;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560442383281" ID="ID_1448105245" MODIFIED="1674596924446" TEXT="Festlegen der vertikalen Ausdehnung der Teil-Widgets">
|
|
<arrowlink COLOR="#235691" DESTINATION="ID_585934033" ENDARROW="Default" ENDINCLINATION="-259;-8;" ID="Arrow_ID_975721855" STARTARROW="Default" STARTINCLINATION="168;-53;"/>
|
|
<linktarget COLOR="#5f57ba" DESTINATION="ID_1448105245" ENDARROW="Default" ENDINCLINATION="-1587;-35;" ID="Arrow_ID_532403594" SOURCE="ID_1989047133" STARTARROW="None" STARTINCLINATION="1293;134;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1565281879855" FOLDED="true" ID="ID_386162681" MODIFIED="1674596532559" TEXT="Aufgabe: steuern">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1565281895004" ID="ID_1758019036" MODIFIED="1674596912874" TEXT="was ist der Trigger-Punkt?">
|
|
<arrowlink COLOR="#7b45d8" DESTINATION="ID_1896159832" ENDARROW="Default" ENDINCLINATION="-839;66;" ID="Arrow_ID_786196853" STARTARROW="None" STARTINCLINATION="667;67;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1674596555914" HGAP="39" ID="ID_878229637" MODIFIED="1674596749453" TEXT="signalStructureChange" VSHIFT="7">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1674596569943" ID="ID_151950407" MODIFIED="1674596795349" TEXT="�� im DisplayManager (ABC) angesiedelt"/>
|
|
<node CREATED="1674596578990" ID="ID_1742690246" MODIFIED="1674596812667" TEXT="⟿ direkt auch mit Change-Detector im ZoomWindow verdrahtet"/>
|
|
<node CREATED="1674596753359" ID="ID_828853736" MODIFIED="1674596787193" TEXT="⟼ BodyCanvasWidget::slotStructureChange"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1565281921697" ID="ID_459498695" MODIFIED="1674596912874" TEXT="wo wird ggfs diese Info gespeichert?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1674596821200" ID="ID_1373193265" MODIFIED="1674596840198" TEXT="durch Leeren des TrackProfile im BodyCanvasWidget"/>
|
|
<node CREATED="1674596842899" ID="ID_1305988233" MODIFIED="1674596856843" TEXT="ist damit idempotent und auch re-entrant"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1565281938372" ID="ID_1188639528" MODIFIED="1674596912875" TEXT="wo/wann wird sie auf die zwei Canvas-Widgets übertragen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1674596865952" ID="ID_451984562" MODIFIED="1674596874746" TEXT="erst in dem Moment, wo tatsächlich gezeichnet wird"/>
|
|
<node CREATED="1674596876759" ID="ID_358515715" MODIFIED="1674596909486" TEXT="im Getter steckt der Aufruf der eigentlichen Neuberechnung"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611486660157" ID="ID_142948287" MODIFIED="1674596527387" TEXT="...und tatsächlich berechnen">
|
|
<arrowlink COLOR="#67b4ea" DESTINATION="ID_1623890878" ENDARROW="Default" ENDINCLINATION="24;-87;" ID="Arrow_ID_809556626" STARTARROW="None" STARTINCLINATION="138;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1560608579463" FOLDED="true" ID="ID_900869986" MODIFIED="1674597032097" TEXT="Layout etablieren">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565282669252" ID="ID_1077695296" MODIFIED="1565282697164" TEXT="horizontal zu zeichnende Spanne">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1672843594185" ID="ID_1806332659" MODIFIED="1672843600804" TEXT="Ausdehnung des Canvas">
|
|
<node CREATED="1672843603784" ID="ID_547988829" MODIFIED="1672843680818" TEXT="initial festlegen">
|
|
<arrowlink COLOR="#4b3d60" DESTINATION="ID_1283622298" ENDARROW="Default" ENDINCLINATION="-940;-885;" ID="Arrow_ID_425073157" STARTARROW="None" STARTINCLINATION="-915;160;"/>
|
|
</node>
|
|
<node CREATED="1672843689370" ID="ID_1279756396" MODIFIED="1672843707230" TEXT="reale Ausdehnung vom ScrolledWindow contentArea_">
|
|
<node COLOR="#435e98" CREATED="1672843720006" ID="ID_1969670799" MODIFIED="1672843870753" TEXT="siehe: Size-Allokation auf GTK Widget">
|
|
<arrowlink COLOR="#536cc0" DESTINATION="ID_1464608958" ENDARROW="Default" ENDINCLINATION="-1020;1248;" ID="Arrow_ID_1013900284" STARTARROW="None" STARTINCLINATION="-2004;139;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#c6ccd6" COLOR="#2c2a74" CREATED="1672843882154" ID="ID_1978068021" MODIFIED="1676045024820" TEXT="Beachte Unterschiede in der Bedeutung der Getter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
get_allocation|width|height  ⟼  aktuell gültiger Wert incl Alignment/Modifikationen
|
|
</li>
|
|
<li>
|
|
get_allocated_size  ⟼  was gesetzt wurde, aber bereits ohne Dekoration
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#727fbb" DESTINATION="ID_464303848" ENDARROW="Default" ENDINCLINATION="-1975;186;" ID="Arrow_ID_1946781864" STARTARROW="None" STARTINCLINATION="-1869;99;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1978068021" ENDARROW="Default" ENDINCLINATION="323;11;" ID="Arrow_ID_920771700" SOURCE="ID_400583877" STARTARROW="None" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1678840039597" ID="ID_1655268668" MODIFIED="1678840689222" TEXT="wird festelegt durch �� bodyCanvas_.signal_size_allocate()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
Empfänger(»Slot«): <font face="Monospaced" color="#552694">TimelineLayout::sizeZoomWindow (Gtk::Allocation&)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5978c6" DESTINATION="ID_1655268668" ENDARROW="Default" ENDINCLINATION="1204;-55;" ID="Arrow_ID_470073487" SOURCE="ID_1658816102" STARTARROW="None" STARTINCLINATION="506;642;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1678840184103" ID="ID_1797129143" MODIFIED="1678840379017" TEXT="siehe 09714cfe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#912929" face="Monospaced">commit 09714cfe28739ceff0b5693447be41166c1cc8d6</font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">Author: Ichthyostega <prg@ichthyostega.de> </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">Date:   Fri Jan 6 03:09:28 2023 +0100 </font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<b>Timeline: draft solution to interconnect ZoomWindow and scrollbar</b>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
After quite some tinkering, instead of extending the DisplayManager interface,
|
|
</p>
|
|
<p>
|
|
I now prefer to treat this connection rather as an intricate implementation detail:
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
The TimelineLayout implementation now provides two translation functions,
|
|
</p>
|
|
<p>
|
|
which are directly wired as slots from the Signals emitted by moving the
|
|
</p>
|
|
<p>
|
|
hand of the scrollbar; the idea is that these functions mutate the ZoomWindow,
|
|
</p>
|
|
<p>
|
|
which then triggers a DisplayEvaltuation, which in turn causes the
|
|
</p>
|
|
<p>
|
|
drawing code to pick up and translate back the new metric and position.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Results look promising, insofar the DisplayEvaluation is now triggered
|
|
</p>
|
|
<p>
|
|
repeatedly, and the actual window width in pixel is propagated;
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678841423804" ID="ID_81531339" MODIFIED="1678916678040" TEXT="⟹ führt sofort zur Kalibrierung des ZoomWindow">
|
|
<arrowlink COLOR="#748598" DESTINATION="ID_833023922" ENDARROW="Default" ENDINCLINATION="-1609;-94;" ID="Arrow_ID_1971623817" STARTARROW="None" STARTINCLINATION="-140;338;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678916699994" ID="ID_868064127" MODIFIED="1678916785049" TEXT="(derzeit bleibt die Timeline auf dem Default von 23sec)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es kommt halt nix Spezifisches aus dem Model, aber es gäbe auch bisher gar keine entsprechenden Diff-Bindings und Model-Properties im GUI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1565282697992" ID="ID_1761874542" MODIFIED="1674597012758" TEXT="vertikal belegter Raum">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1565283074170" ID="ID_1990551085" MODIFIED="1566407001705" TEXT="Trigger/Berechnungsfunktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1565283089529" ID="ID_833580972" MODIFIED="1582931247838" TEXT="ausgelöst durch allgemeine Struktur-Änderungen">
|
|
<arrowlink COLOR="#8db7cd" DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="598;258;" ID="Arrow_ID_1531606207" STARTARROW="None" STARTINCLINATION="455;26;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566407025586" ID="ID_1467953135" MODIFIED="1566407042985" TEXT="sicherstellen, daß vorher der DisplayEvaluationPass gelaufen ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566407006341" ID="ID_375041651" MODIFIED="1566407015727" TEXT="Höhe vom TrackBody beziehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566407055894" ID="ID_982642970" MODIFIED="1566407059861" TEXT="Änderungen erkennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1566407136811" ID="ID_832049284" MODIFIED="1566487620033" TEXT="geänderte Größe wird nicht sichtbar">
|
|
<arrowlink COLOR="#16d17f" DESTINATION="ID_489535600" ENDARROW="Default" ENDINCLINATION="-80;-272;" ID="Arrow_ID_1038229013" STARTARROW="None" STARTINCLINATION="-102;166;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582931260542" ID="ID_43972117" MODIFIED="1674513272422" TEXT="Thema: Koordinieren zwischen Header und Body">
|
|
<linktarget COLOR="#689ba2" DESTINATION="ID_43972117" ENDARROW="Default" ENDINCLINATION="198;928;" ID="Arrow_ID_1080676559" SOURCE="ID_1842930323" STARTARROW="None" STARTINCLINATION="-1589;-3311;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1582931486072" ID="ID_1623890878" MODIFIED="1674513437165" TEXT="Ausdehnung der Tracks">
|
|
<arrowlink COLOR="#fe5b57" DESTINATION="ID_1920766923" ENDARROW="Default" ENDINCLINATION="595;0;" ID="Arrow_ID_1362710635" STARTARROW="Default" STARTINCLINATION="529;0;"/>
|
|
<linktarget COLOR="#67b4ea" DESTINATION="ID_1623890878" ENDARROW="Default" ENDINCLINATION="24;-87;" ID="Arrow_ID_809556626" SOURCE="ID_142948287" STARTARROW="None" STARTINCLINATION="138;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674161380587" ID="ID_1311832889" MODIFIED="1674513429084" TEXT="Platz für Placement-Controlls sinnvoll anordnen">
|
|
<arrowlink COLOR="#5a7c92" DESTINATION="ID_478580800" ENDARROW="Default" ENDINCLINATION="451;41;" ID="Arrow_ID_513449931" STARTARROW="None" STARTINCLINATION="481;-27;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674163294922" FOLDED="true" ID="ID_1332292119" LINK="#ID_1650195806" MODIFIED="1674254403617" TEXT="Probleme mit der vertikalen Koordination bei nested Tracks">
|
|
<arrowlink COLOR="#463cb1" DESTINATION="ID_1762683235" ENDARROW="Default" ENDINCLINATION="624;37;" ID="Arrow_ID_1560223761" STARTARROW="None" STARTINCLINATION="129;-6;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1674174926441" FOLDED="true" ID="ID_896721694" MODIFIED="1674254493101" TEXT="Zweifel an der berechneten Höhe">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1674175196891" ID="ID_390658088" MODIFIED="1674175199729" TEXT="Body?">
|
|
<node CREATED="1674175200596" ID="ID_1235875992" MODIFIED="1674175204768" TEXT="nachmessen per GIMP"/>
|
|
<node CREATED="1674175205694" ID="ID_1007099807" MODIFIED="1674175218093" TEXT="es fehlt der Ruler-Canvas">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1674175219297" ID="ID_873831776" MODIFIED="1674175224981" TEXT="ansonsten sind die Werte exakt">
|
|
<node CREATED="1674175226593" ID="ID_891434672" MODIFIED="1674175293596" TEXT="82 px für Root-Content + Slope-down"/>
|
|
<node CREATED="1674175239335" ID="ID_108512900" MODIFIED="1674175288293" TEXT="164 für Root-content + Child-content + slope down+up"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1674176070056" ID="ID_743840121" MODIFIED="1674176073188" TEXT="Head">
|
|
<node CREATED="1674176074535" ID="ID_39929710" MODIFIED="1674176094582" TEXT="das Gesamt-Grid wird zu groß ermittelt">
|
|
<node CREATED="1674176096077" ID="ID_583910543" MODIFIED="1674176120813" TEXT="angeblich 164">
|
|
<node CREATED="1674176756797" ID="ID_1711694466" MODIFIED="1674176762735" TEXT="berechnet als 14+68+82"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1674177671455" ID="ID_200566627" MODIFIED="1674254483689" TEXT="möglicherweise ist die kombinierte Spalte das Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
|o| cH(line=0) += (14,14)
|
|
</p>
|
|
<p>
|
|
|o| cH(line=1) += (68,12)
|
|
</p>
|
|
<p>
|
|
|o| cH(line=2) += (68,82)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#2b91d0" DESTINATION="ID_1671254452" ENDARROW="Default" ENDINCLINATION="220;0;" ID="Arrow_ID_864210010" STARTARROW="None" STARTINCLINATION="-7;189;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1674177711595" ID="ID_926975812" MODIFIED="1674177719085" TEXT="14 = Höhe Label"/>
|
|
<node CREATED="1674177720641" ID="ID_490298226" MODIFIED="1674177730988" TEXT="12 = Höhe Glühbirne (control)"/>
|
|
<node CREATED="1674177737457" ID="ID_467766336" MODIFIED="1674177745813" TEXT="82 = Höhe nested Track-Head"/>
|
|
<node CREATED="1674177887491" ID="ID_1629142103" MODIFIED="1674177906308" TEXT="68 = 40 + Δ=28"/>
|
|
</node>
|
|
<node CREATED="1674247115438" ID="ID_1557269606" MODIFIED="1674247168418" TEXT="tatsächlich zählen die kombinierten Spalten nur einmal">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1674247332612" ID="ID_421176912" MODIFIED="1674247406408" TEXT="14+12+82 = 108 sieht viel realistischer aus....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das würde auch erklären, warum trotzdem die Zelle mit der Glühbirne (=die direkten Controls) <i>überhaupt nicht aufgespreitzt </i>wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#dbc5b3" COLOR="#ff0000" CREATED="1674247147690" ID="ID_428940289" MODIFIED="1674247211671" TEXT="⟹ der Ansatz mit dem Maximum pro Zeile ist nicht korrekt"/>
|
|
</node>
|
|
<node CREATED="1674176180377" ID="ID_154967424" MODIFIED="1674176210609" TEXT="visuell sehe ich nur 14+94 = 108"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674247231512" ID="ID_704080657" MODIFIED="1674254386095" TEXT="Höhe im TrackHeadWidget korrekt messen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1674247251100" ID="ID_1501775447" MODIFIED="1674247278994" TEXT="nur die 2.Spalte insgesamt summieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1674247260807" ID="ID_1423273480" MODIFIED="1674247276378" TEXT="paßt gut zusammen mit dem End-Ausgleich in der 1.Spalte">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674248099319" ID="ID_1685711239" MODIFIED="1674254383950" TEXT="aber zudem sicherstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1674248116285" ID="ID_1285555258" MODIFIED="1674254382320" TEXT="...daß das wirkliche Maximum gemessen wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ es muß das strukturell korrekte Maximum explizit berechnet werden; würden wir nur die rechte Spalte summieren, bliebe eine bereits bestehende Spreizung in der linken Spalte unberücksichtigt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674248127199" ID="ID_991058401" MODIFIED="1674254380528" TEXT="...daß die Struktur-Spalte auch wirklich auf Anschlag ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ aber auch das umgekehrte Szenario muß berücksichtigt werden: falls die Gesamthöhe von der Summe in der rechten Spalte dominiert wird, genügt es nicht, blindlings nur eine eigentlich kleinere linke Strukturspalte mit dem Δ zu beaufschlagen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674254451385" ID="ID_1671254452" MODIFIED="1674254477841" TEXT="jetzt ist die Berechnung korrekt">
|
|
<linktarget COLOR="#2b91d0" DESTINATION="ID_1671254452" ENDARROW="Default" ENDINCLINATION="220;0;" ID="Arrow_ID_864210010" SOURCE="ID_200566627" STARTARROW="None" STARTINCLINATION="-7;189;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674172473327" ID="ID_1376269414" MODIFIED="1674347900406" TEXT="Beginn der nested-Tracks koordinieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1674172530639" ID="ID_1531517037" MODIFIED="1674172537538" TEXT="sie beginnen typischerweise zu früh"/>
|
|
<node CREATED="1674172548813" ID="ID_53484260" MODIFIED="1674172558839" TEXT="Padding für die Content-Höhe genügt nicht"/>
|
|
<node CREATED="1674345881143" ID="ID_1661063602" MODIFIED="1674345967809" TEXT="TrackBody kann das aber berechnen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar über den contentOffset, der relativ zur Start-Zeile gemessen wird, sowie der direkten ContentHeight, zuzüglich Padding
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674172566487" ID="ID_1608232649" MODIFIED="1674513368872" TEXT="Diskrepanz sinnvoll einbringen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1674172577081" ID="ID_1556472546" MODIFIED="1674254503089" TEXT="Höhe insgesamt ⟼ Struktur-Spalte"/>
|
|
<node COLOR="#435e98" CREATED="1674172577081" ID="ID_902379987" MODIFIED="1674347889053" TEXT="Synchronisation ⟼ padding nach direct content"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674347903812" FOLDED="true" ID="ID_1742313131" MODIFIED="1674513236391" TEXT="Höhenberechnung im TrackBody unvollständig">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1674347924697" FOLDED="true" ID="ID_1440620020" MODIFIED="1674513373146" TEXT="Probleme">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1674347929637" ID="ID_1693517831" MODIFIED="1674347942830" TEXT="der separate Ruler-Canvas wird nicht berücksichtigt">
|
|
<node CREATED="1674350584579" ID="ID_1671695186" MODIFIED="1674350589304" TEXT="wie groß?">
|
|
<node CREATED="1674350590559" ID="ID_1966298653" MODIFIED="1674351114799" TEXT="11px == decoration.topMar">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_354285269" ENDARROW="Default" ENDINCLINATION="70;0;" ID="Arrow_ID_1818076269" STARTARROW="None" STARTINCLINATION="-79;8;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1674354054786" ID="ID_1551678224" MODIFIED="1674354124203" TEXT="aber: er fehlt nur im contentOffset und im Gesamtergebnis (line = res)"/>
|
|
<node CREATED="1674354075442" ID="ID_1951685087" MODIFIED="1674354088196" TEXT="in die Größe werden zumindest die Ruler korrekt mit eingerechnet"/>
|
|
</node>
|
|
<node CREATED="1674347946242" ID="ID_1905901999" MODIFIED="1674347965339" TEXT="der Margin für Prelude / Postlude wird nicht berücksichtigt">
|
|
<node CREATED="1674353995316" ID="ID_1351496959" MODIFIED="1674354004872" TEXT="das ist ein generelles Problem"/>
|
|
<node CREATED="1674354005689" ID="ID_374452100" MODIFIED="1674354012709" TEXT="aber gewissermaßen auch logisch"/>
|
|
<node CREATED="1674354013794" ID="ID_26588386" MODIFIED="1674354028708" TEXT="Prelude wird eben nicht zur Größe des Root-Track gerechnet"/>
|
|
</node>
|
|
<node CREATED="1674347969175" ID="ID_1910872157" MODIFIED="1674347994788" TEXT="die Slope-down/up wird nicht berücksichtigt"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674351098493" FOLDED="true" ID="ID_894959453" MODIFIED="1674513358248" TEXT="Beobachtung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1674350941467" ID="ID_1826693009" MODIFIED="1674350945974" TEXT="decoration">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1674350951914" ID="ID_106173502" MODIFIED="1674350955686" TEXT="content = 42"/>
|
|
<node CREATED="1674350959876" ID="ID_1487607693" MODIFIED="1674350963292" TEXT="ruler = 28"/>
|
|
<node CREATED="1674350967152" ID="ID_354285269" MODIFIED="1674351114799" TEXT="topMar = 11">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_354285269" ENDARROW="Default" ENDINCLINATION="70;0;" ID="Arrow_ID_1818076269" SOURCE="ID_1966298653" STARTARROW="None" STARTINCLINATION="-79;8;"/>
|
|
</node>
|
|
<node CREATED="1674350972480" ID="ID_1303308489" MODIFIED="1674350984992" TEXT="botMar = 11"/>
|
|
<node CREATED="1674350985965" ID="ID_13244002" MODIFIED="1674351218230" TEXT="trackPad = 21">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_13244002" ENDARROW="Default" ENDINCLINATION="66;0;" ID="Arrow_ID_90576593" SOURCE="ID_1917807649" STARTARROW="None" STARTINCLINATION="66;0;"/>
|
|
</node>
|
|
<node CREATED="1674351003803" ID="ID_291429640" MODIFIED="1674351018789" TEXT="borders = [5,5,10,14,17,20]"/>
|
|
</node>
|
|
<node CREATED="1674351179091" ID="ID_1301058819" MODIFIED="1674351189821" TEXT="root-track">
|
|
<node CREATED="1674351117941" ID="ID_546308961" MODIFIED="1674351196739" TEXT="Track content-height: contentHeight + decoration.content = 40+42 = 82"/>
|
|
<node CREATED="1674351205888" ID="ID_1917807649" MODIFIED="1674351218230" TEXT="contentOffset = 21">
|
|
<arrowlink DESTINATION="ID_13244002" ENDARROW="Default" ENDINCLINATION="66;0;" ID="Arrow_ID_90576593" STARTARROW="None" STARTINCLINATION="66;0;"/>
|
|
</node>
|
|
<node CREATED="1674352921149" ID="ID_1580223577" MODIFIED="1674352942925" TEXT="danach: line =169">
|
|
<linktarget COLOR="#30a7c5" DESTINATION="ID_1580223577" ENDARROW="Default" ENDINCLINATION="138;4;" ID="Arrow_ID_352754066" SOURCE="ID_1287712179" STARTARROW="None" STARTINCLINATION="138;4;"/>
|
|
</node>
|
|
<node CREATED="1674353017672" ID="ID_1991251821" MODIFIED="1674353037386" TEXT="+slopeup ⟼ 174"/>
|
|
<node CREATED="1674353017672" ID="ID_1761513033" MODIFIED="1674353075157" TEXT="+coda ⟼ 190"/>
|
|
</node>
|
|
<node CREATED="1674352771789" ID="ID_1103517565" MODIFIED="1674352775750" TEXT="sub-track">
|
|
<node CREATED="1674352788969" ID="ID_961058180" MODIFIED="1674352794647" TEXT="startLine_ = 87"/>
|
|
<node CREATED="1674352777377" ID="ID_1184947760" MODIFIED="1674352781866" TEXT="contentOffset = 21"/>
|
|
<node CREATED="1674352814630" ID="ID_59687" MODIFIED="1674352825233" TEXT="content-heigt: ebenfalls 82"/>
|
|
<node CREATED="1674352856355" ID="ID_1287712179" MODIFIED="1674352947649" TEXT="line (=res) : 82">
|
|
<arrowlink COLOR="#30a7c5" DESTINATION="ID_1580223577" ENDARROW="Default" ENDINCLINATION="138;4;" ID="Arrow_ID_352754066" STARTARROW="None" STARTINCLINATION="138;4;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674348025640" ID="ID_565643095" MODIFIED="1674513234467" TEXT="Komplikationen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1674348030567" ID="ID_493716565" MODIFIED="1674348045940" TEXT="Prelude / Postlude und Ruler-Canvas treten nur beim Root-Track auf">
|
|
<node CREATED="1674348203360" ID="ID_1395576616" MODIFIED="1674348210235" TEXT="aber ein Track weiß nicht, daß er Root ist"/>
|
|
</node>
|
|
<node CREATED="1674348164550" ID="ID_1253760936" MODIFIED="1674348183015" TEXT="Slope-down/up wird im Parent-Track gesteuert">
|
|
<node CREATED="1674348231749" ID="ID_1598827658" MODIFIED="1674348251134" TEXT="dieser Offset kann daher nicht in der Höhe der Kind-Track(s) eingerechnet werden"/>
|
|
<node CREATED="1674348290385" ID="ID_676814617" MODIFIED="1674348324132" TEXT="d.h. bei mehreren Sub-Tracks rutschen wir genau um diesen Betrag nach oben"/>
|
|
<node CREATED="1674353927071" ID="ID_1407468447" MODIFIED="1674353940500" TEXT="und zwar einmal pro rekursiv verschachtelte Ebene">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674354159742" ID="ID_1940678452" MODIFIED="1674513239606" TEXT="Korrekturen bewerkstelligen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1674354169058" ID="ID_533240449" MODIFIED="1674513380571" TEXT="brauche Spezialbehandlung für den Root-Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1674354205168" ID="ID_85048363" MODIFIED="1674354255720" TEXT="Gesamtgröße muß Ruler + prelude berücksichtigen"/>
|
|
<node CREATED="1674354306149" ID="ID_633496997" MODIFIED="1674354320837" TEXT="sub-track-offset muß Ruler + prelude berücksichtigen"/>
|
|
<node COLOR="#435e98" CREATED="1674402568327" ID="ID_219579639" MODIFIED="1674510175705" TEXT="wo ist diese Korrektur logisch sinnvoll angesiedelt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1674402620527" ID="ID_1633544285" MODIFIED="1674402871728" TEXT="sie bricht den strikten Bezug auf Canvas-Koordinaten und jeweils einen Track">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Präludium gehört nicht zum Track, und für alle sonstigen Größenangaben gilt ein unmittelbarer Bezug auf die Canvas-Koordinaten; diese gelten <i>lokal für den Canvas</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1674402875129" ID="ID_1857367288" MODIFIED="1674402942310" TEXT="allerdings: der einzelne Track sollte seine Position im Gesamtgefüge nicht kennen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674403069412" ID="ID_1314616447" MODIFIED="1674510152085" TEXT="was muß den genau korrigiert werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1674403082049" ID="ID_1078734632" MODIFIED="1674403088307" TEXT="es ist mehrerlei...">
|
|
<node CREATED="1674403090200" ID="ID_615803349" MODIFIED="1674403095202" TEXT="Prelude"/>
|
|
<node CREATED="1674403096199" ID="ID_1911972979" MODIFIED="1674403209258" TEXT="Ruler">
|
|
<arrowlink COLOR="#eb4c4e" DESTINATION="ID_515096270" ENDARROW="Default" ENDINCLINATION="-4;-9;" ID="Arrow_ID_1857436745" STARTARROW="None" STARTINCLINATION="9;-2;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1674403142108" ID="ID_515096270" MODIFIED="1674403209258" TEXT="das Auslassen der Ruler stellt einen Bruch des Contract dar">
|
|
<linktarget COLOR="#eb4c4e" DESTINATION="ID_515096270" ENDARROW="Default" ENDINCLINATION="-4;-9;" ID="Arrow_ID_1857436745" SOURCE="ID_1911972979" STARTARROW="None" STARTINCLINATION="9;-2;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674506708137" ID="ID_896668999" MODIFIED="1674510172983" TEXT="das ist ein Dilemma — dann lieber noch direkt im TrackBody">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1674506772895" ID="ID_1636893876" MODIFIED="1674506790641" TEXT="da sind wir noch am Nächsten an den Layout-Berechnungen dran..."/>
|
|
<node CREATED="1674506791397" ID="ID_1813341539" MODIFIED="1674506879645" TEXT="und TrackBody kann durch einen Kniff „erraten“ ob er Root-Track ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dann ist nämlich die startLine = 0;
|
|
</p>
|
|
<p>
|
|
<i>...ja das ist Insider-Wissen, und dann lieber alles da machen, wo die ganzen technischen Details ohnehin stecken...</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674506884449" ID="ID_651254620" MODIFIED="1674510162022">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
demnach <b>ändern</b> wir jetzt den Contrakt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1674506904090" ID="ID_1092162889" MODIFIED="1674506915040" TEXT="die Funktionen heißen jetzt calc*()"/>
|
|
<node CREATED="1674506915836" ID="ID_298260299" MODIFIED="1674506934134" TEXT="und berechnen die Gesamthöhe"/>
|
|
<node CREATED="1674506935082" ID="ID_610623400" MODIFIED="1674506943804" TEXT="einschließlich angrenzender Dekoration"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674354327207" ID="ID_1319790306" MODIFIED="1674513381995" TEXT="sub-track-offset muß slope-down mit einschließen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1674354364930" ID="ID_697232508" MODIFIED="1674354376797" TEXT="und zwar genau einmal, und nur wenn es nested Tracks gibt"/>
|
|
<node CREATED="1674354383601" ID="ID_345455776" MODIFIED="1674354396562" TEXT="slope-up kann uns egal sein (ist in der Gesamtgröße mit dabei)"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1674510180255" ID="ID_226214424" MODIFIED="1674510295170" TEXT="⟹ neuer Satz zusammenwirkender Funktionen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1674510205556" ID="ID_1519623575" MODIFIED="1674510215393" TEXT="nicht mehr auf den contentOffset aufbauen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1674510304079" ID="ID_1164198433" MODIFIED="1674510316521" TEXT="Gesamt-Höhe aus Content + Nested aufbauen"/>
|
|
<node CREATED="1674510319197" ID="ID_1163280327" MODIFIED="1674510344631" TEXT="Content schließt Ruler und slope-down mit ein"/>
|
|
<node CREATED="1674510325404" ID="ID_1324802717" MODIFIED="1674513323111" TEXT="Ruler schließen automatisch das Root-Prelude ein"/>
|
|
<node CREATED="1674510350137" ID="ID_269721067" MODIFIED="1674510480677">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nested enthält <i>Näherung</i> für slope-up
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier können wir nicht exakt rechnen, weil aufsteigende Slopes kombiniert werden — und die Info dazu kennen wir nur beim Konstruieren des Profils. Daher überschätzt diese Höhenangabe die Track-Höhe — bleibt zu sehen, ob das relevant wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1674510487662" ID="ID_1907635652" MODIFIED="1674513336659" TEXT="Vorsicht: übertreibt!">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674513248834" ID="ID_200252521" MODIFIED="1674513270937" TEXT="jetzt sieht das Resultat auf ±1px exakt aus">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1674158539561" ID="ID_1440303749" MODIFIED="1674160219745" TEXT="#1265 define expanding/collapsing of tracks">
|
|
<linktarget COLOR="#c65e7c" DESTINATION="ID_1440303749" ENDARROW="Default" ENDINCLINATION="-1806;-99;" ID="Arrow_ID_537995229" SOURCE="ID_852402445" STARTARROW="None" STARTINCLINATION="-421;38;"/>
|
|
<linktarget COLOR="#926b99" DESTINATION="ID_1440303749" ENDARROW="Default" ENDINCLINATION="-978;62;" ID="Arrow_ID_1979782904" SOURCE="ID_1119649795" STARTARROW="None" STARTINCLINATION="-281;21;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1674160660563" ID="ID_1828648487" MODIFIED="1674161293621" TEXT="#1266 implement scope rulers and group tracks">
|
|
<linktarget COLOR="#8a4d65" DESTINATION="ID_1828648487" ENDARROW="Default" ENDINCLINATION="-2734;159;" ID="Arrow_ID_502951484" SOURCE="ID_1409730860" STARTARROW="None" STARTINCLINATION="-1113;-73;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1674160771852" ID="ID_459820507" MODIFIED="1674161151512" TEXT="Def »scope ruler«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Jeder Track kann 0...N Ruler haben (Ruler = horizontale Scala);
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
einer von diesen ist der »scope ruler«
|
|
</li>
|
|
<li>
|
|
er ersetzt den Track und den gesamten Scope der sub-Tracks in der Präsentation
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1674161152794" ID="ID_1182180069" MODIFIED="1674161238640" TEXT="�� unklar: Model-Repräsentation der Ruler">
|
|
<arrowlink COLOR="#af637b" DESTINATION="ID_1945074845" ENDARROW="Default" ENDINCLINATION="-348;-196;" ID="Arrow_ID_1261991748" STARTARROW="None" STARTINCLINATION="-383;24;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1555084648375" ID="ID_483631091" MODIFIED="1565283046031" TEXT="Thema: Struktur-Profil">
|
|
<arrowlink COLOR="#2e66db" DESTINATION="ID_1659558780" ENDARROW="Default" ENDINCLINATION="-889;0;" ID="Arrow_ID_1691760775" STARTARROW="None" STARTINCLINATION="828;0;"/>
|
|
<linktarget COLOR="#1b36ab" DESTINATION="ID_483631091" ENDARROW="Default" ENDINCLINATION="-88;6;" ID="Arrow_ID_1079857163" SOURCE="ID_19246515" STARTARROW="None" STARTINCLINATION="-26;-28;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1566406980688" FOLDED="true" ID="ID_196847136" MODIFIED="1566406988165" TEXT="Layout-Anpsassungen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1566407065037" ID="ID_548414744" MODIFIED="1672842637926" TEXT="Scrollbar anpassen nach Größenänderung">
|
|
<linktarget COLOR="#795b80" DESTINATION="ID_548414744" ENDARROW="Default" ENDINCLINATION="-897;636;" ID="Arrow_ID_1661740759" SOURCE="ID_679418178" STARTARROW="Default" STARTINCLINATION="-286;-17;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1566407096905" ID="ID_1463503563" MODIFIED="1566487536944" TEXT="reagiert noch nicht...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1566407104280" ID="ID_1989341591" MODIFIED="1566421808796" TEXT="was hab ich seinerzeit beim Gtk-Canvas-Experiment gemacht?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1566421664831" ID="ID_1051378925" MODIFIED="1566421671379" TEXT="exakt das Gleiche"/>
|
|
<node CREATED="1566421672116" ID="ID_343684790" MODIFIED="1576282358057" TEXT="nur noch zusätzlich ein Window->win->invalidate_rect">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alledings nur, nachdem man das drawing ein/ausgeschaltet hat....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  void
|
|
</p>
|
|
<p>
|
|
  Canvas::enableDraw (bool yes)
|
|
</p>
|
|
<p>
|
|
  {
|
|
</p>
|
|
<p>
|
|
    shallDraw_ = yes;
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    // force redrawing of the visible area...
|
|
</p>
|
|
<p>
|
|
    auto win = get_window();
|
|
</p>
|
|
<p>
|
|
    if (win)
|
|
</p>
|
|
<p>
|
|
      {
|
|
</p>
|
|
<p>
|
|
        int w = get_allocation().get_width();
|
|
</p>
|
|
<p>
|
|
        int h = get_allocation().get_height();
|
|
</p>
|
|
<p>
|
|
        Gdk::Rectangle rect{0, 0, w, h};
|
|
</p>
|
|
<p>
|
|
        win->invalidate_rect(rect, false);
|
|
</p>
|
|
<p>
|
|
      }
|
|
</p>
|
|
<p>
|
|
  }
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1566421823243" ID="ID_351645581" MODIFIED="1576282358056" TEXT="doch es funktioniert!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nur stimmen die Zahlenwerte im Moment nicht;
|
|
</p>
|
|
<p>
|
|
wir malen viel mehr auf den Canvas, als seine Größe erlauben würde.
|
|
</p>
|
|
<p>
|
|
Macht trotzdem nix
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1566421888123" ID="ID_1319951362" MODIFIED="1566421905961" TEXT="sogar die Header-Pane scrollt mit">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566407096905" ID="ID_489535600" MODIFIED="1576282358056" TEXT="Problem: rePack- der umschließenden Box">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man PACK_SHRINK setzt, dann weist die umschließende Box initial
|
|
</p>
|
|
<p>
|
|
dem Canvas die Größe 0 zu (weil er zu diesem Zeitpunkt noch nicht realisiert ist).
|
|
</p>
|
|
<p>
|
|
Problem ist aber, daß diese Zuweisung später, nach einem set_size auf dem Canvas nicht revidiert wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#16d17f" DESTINATION="ID_489535600" ENDARROW="Default" ENDINCLINATION="-80;-272;" ID="Arrow_ID_1038229013" SOURCE="ID_832049284" STARTARROW="None" STARTINCLINATION="-102;166;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566487213692" ID="ID_617175720" MODIFIED="1672867705882" TEXT="sollte eigentlich automatisch funktionieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
die Funktionen zum expliziten Setzen und re-Sizing sind deprecated.
|
|
</li>
|
|
<li>
|
|
eigentlich sollte die Box automatisch auf Größenänderungen der Kind-Elemente reagieren gemäß Flow/Fill-Layout
|
|
</li>
|
|
<li>
|
|
für klassische Widgets wie z.B. Button funktioniert das auch
|
|
</li>
|
|
<li>
|
|
aber auf ein set_size() auf dem Canvas reagiert das Layout anscheinend nicht
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1566487282848" ID="ID_771271362" MODIFIED="1672875017148" TEXT="Workaround: jeweils explizit set_size_request">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Anmerkung 1/2023</u>: seinerzeit habe ich die Mechanik der Layout-Zuteilung noch nicht wirklich verstanden
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">commit fc5eaf857c687d769df22d6f98a25e8e359e7c49 </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">Author: Ichthyostega <prg@ichthyostega.de> </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">Date:   Thu Aug 22 17:34:32 2019 +0200 </font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    Timeline: find a workaround to cause the Box to reflow the rulerCanvas </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    seemingly, the Box with PACK_SHRINK allocates a zero height to the rulerCanvas initally, </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    which is correct at that point, since the widgets are not yet realised. </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    However, when we later set_size() on the rulerCanvas, the enclosing Box should reflow. </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    It does indeed if the child widget is a button or something similar, however, </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    somehow this reflowing does not work when we set_size on the canvas. </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    A workaround is to place a new set_size_request(). </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    TODO: do this more precisely, and only on the rulerCanvas. To the contrary, </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    the mainCanvas is placed into a scolling-pane and thus does not need a size-Request. </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    Moreover, the latter automatically communicates with the hadjustment() / vadjustment() of </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    the enclosing scrollbars. </font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">commit 2390385dc50a8504336f5e1fa1a5dc35eca58f2f </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">Author: Ichthyostega <prg@ichthyostega.de> </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">Date:   Wed Aug 21 19:13:55 2019 +0200 </font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    Timeline: implement function to set the drawing canvas size </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    as can be verified with the debugger, it sets the correct sizes now. </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    And it is called only once (unless the content size actually changes). </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    </font>
|
|
</p>
|
|
<p>
|
|
<font color="#4d2a27" face="Monospaced" size="2">    TODO: however, the visible display of the GTK widgets is not adjusted </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566487379550" ID="ID_272047983" MODIFIED="1672875229852" TEXT="aber horizontal nur eine Minimal-Weite (100px)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Eigentlich benötigt wird das »Aufspreizen« nur in der vertikalen Dimension, damit sich die umschließende Box sinngemäß anpaßt; im Grunde würde es sogar genügen, nur das obere (Ruler)-ScrolledWindow zu dimensionieren, aber ich halte es für sicherer, vom eigentlichen innen liegenden Canvas aus aufzuspreizen, schon wegen der ggfs. dynamischen Dekoration für die Scrollbar. Als Kompromiß setze ich jetzt horizontal eine Mindest-Ausdehnung von 100px (das erscheint ohnehin sinnvoll für eine Timeline), aber in vertikaler Richtung setze ich einen size-Request auf die berechnete Canvas-Höhe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672798667029" FOLDED="true" ID="ID_1699842831" MODIFIED="1674603499873" TEXT="Integration ZoomWindow: funktioniert nicht (mehr)">
|
|
<linktarget COLOR="#503fac" DESTINATION="ID_1699842831" ENDARROW="Default" ENDINCLINATION="-1384;79;" ID="Arrow_ID_927325344" SOURCE="ID_133007183" STARTARROW="None" STARTINCLINATION="-1848;-74;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1672798696337" ID="ID_1553490887" MODIFIED="1672798742711" TEXT="greife jetzt ScrolledWindow::get_allocated_width() ab">
|
|
<node CREATED="1672845045702" ID="ID_400583877" MODIFIED="1672845097544" TEXT="das wäre grundsätzlich korrekt">
|
|
<arrowlink DESTINATION="ID_1978068021" ENDARROW="Default" ENDINCLINATION="323;11;" ID="Arrow_ID_920771700" STARTARROW="None" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1672845054021" ID="ID_1400277326" MODIFIED="1672845155612" TEXT="und ist auch konsistent mit dem »horizontal adjustment« des ScrolledWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
per DUMP-Print verifiziert: Maximalwert der Scrollbar (=hadj) ist identisch mit get_allocated_width
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672798745175" ID="ID_399045239" MODIFIED="1672798762372" TEXT="kalibriere damit das ZoomWindow, und beziehe davon dann die Canvas-Größe"/>
|
|
<node CREATED="1672798763432" ID="ID_485578749" MODIFIED="1672798787610" TEXT="horizontale Scrollbar blockt und wird nach rechts beschnitten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672845159233" ID="ID_914079601" MODIFIED="1674597085411" TEXT="(1) Problem ist: keine Invalidierung ⟹ keine Display-Evaluation ⟹ Wert nicht abgerufen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1672847404194" ID="ID_1941365833" MODIFIED="1672847417490" TEXT="unser Layout-Code merkt daher gar nicht, wenn sich etwas ändert"/>
|
|
<node CREATED="1672847418472" ID="ID_411937904" MODIFIED="1672867873212" TEXT="Beobachtung mögliche Aktivierungen">
|
|
<icon BUILTIN="list"/>
|
|
<node CREATED="1672847435934" ID="ID_204065179" MODIFIED="1672847440225" TEXT="on_draw()">
|
|
<node CREATED="1672847448238" ID="ID_1819538437" MODIFIED="1672847457023" TEXT="wird wohl permanent aufgerufen"/>
|
|
<node CREATED="1672847458467" ID="ID_1233413965" MODIFIED="1672847471149" TEXT="sehe jede Änderung des Layout sofort"/>
|
|
</node>
|
|
<node CREATED="1672847440981" ID="ID_828221766" MODIFIED="1672847446416" TEXT="on_size_allocate()">
|
|
<node CREATED="1672847675830" ID="ID_1048944592" MODIFIED="1672847684009" TEXT="nur bei Geometrie-Änderungen"/>
|
|
<node CREATED="1672847684840" ID="ID_272958565" MODIFIED="1672847693224" TEXT="und bei Focus gain/loss"/>
|
|
</node>
|
|
<node CREATED="1672847699754" ID="ID_921332802" MODIFIED="1672867412724" TEXT="Feststellung: Größe "stößt an" an gesetzter Canvas-Größe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
initial wurde Canvas-Größe auf 852px gesetzt (Debugging Code zieht 100px ab)
|
|
</li>
|
|
<li>
|
|
die Allocation für das BodyCanvasWidget wird minimal 852
|
|
</li>
|
|
<li>
|
|
wenn man das Fenster (oder den Teiler der Pane) weiter verkleinert, wird trotzdem 852 geliefert ⟹ nach rechts beschnitten
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672867905486" ID="ID_74954726" MODIFIED="1674597085411" TEXT="(2) Problem ist: Mindestgröße des Ruler-Canvas">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1672867946048" ID="ID_303294117" MODIFIED="1672867967257" TEXT="das kommt von dem Workaround wegen Box-re-Pack"/>
|
|
<node CREATED="1672867974932" ID="ID_1158620825" MODIFIED="1672868021465" TEXT="der Ruler-Canvas liegt nicht in einer scrolled pane und „spreizt“ deshalb">
|
|
<node CREATED="1672869698743" ID="ID_283208573" MODIFIED="1672869708010" TEXT="in vertikaler Richtung ist das ja auch korrekt"/>
|
|
<node CREATED="1672869723476" ID="ID_401276544" MODIFIED="1672869749468" TEXT="Gtk::Layout hat selber V/H-Adjustments und bräuchte theoretisch kein Scrolled Window"/>
|
|
<node CREATED="1672869752647" ID="ID_1600272917" MODIFIED="1672869783428" TEXT="aber in horizontaler Richtung wollen wir ein kleineres Minimum">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1672871169883" ID="ID_923032562" MODIFIED="1672871357241" TEXT="mit dieser Korrektur funktioniert die horizontale Scrollbar (halbwegs) wie erwartet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
zumindest kann man nun das Fenster tatsächlich verkleinern, und dann mit der Scrollbar horizontal den Haupt-Canvas bewegen.
|
|
</li>
|
|
<li>
|
|
aber der Ruler-Canvas scrollt nicht mit
|
|
</li>
|
|
<li>
|
|
und der Anzeige-Zustand der Scrollbar ist bei mouse-over(Scrollbar) nicht richtig synchronisiert; das wird erst korrekt nach einem Focus-loss/gain
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672875251348" ID="ID_850567919" MODIFIED="1672875337286" TEXT="Umbau: auch Ruler-Canvas in ein ScrolledWindow legen; dieses arbeitet als »Slave«">
|
|
<arrowlink COLOR="#6bbdbc" DESTINATION="ID_1904830870" ENDARROW="Default" ENDINCLINATION="693;23;" ID="Arrow_ID_1587189163" STARTARROW="None" STARTINCLINATION="39;-248;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1674603423931" ID="ID_623632021" LINK="#ID_22375243" MODIFIED="1674603474685" TEXT="Clip-Drag aktualisiert manchmal die Position nicht">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672872402655" ID="ID_57784666" MODIFIED="1672872407100" TEXT="dynamische Anzeige">
|
|
<node CREATED="1672872408415" ID="ID_1423497948" MODIFIED="1672872423235" TEXT="Zoom koordinieren"/>
|
|
<node CREATED="1672872424309" ID="ID_1732041124" MODIFIED="1672872432016" TEXT="Scrolling koordinieren">
|
|
<node COLOR="#338800" CREATED="1672872433811" ID="ID_814093517" MODIFIED="1672874787868" TEXT="Header / Patchbay ist an VAdjustment vom Body angekoppelt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672874789195" ID="ID_1285847360" MODIFIED="1672874812664" TEXT="Ruler-Canvas ist an HAdjustment vom Content-Canvas angekoppelt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560618609627" ID="ID_506564995" MODIFIED="1560618618079" TEXT="benötigt ein Struktur-Profil der Spuren">
|
|
<node CREATED="1565282840443" ID="ID_19246515" MODIFIED="1565283046031" TEXT="was ist dieses Struktur-Profil?">
|
|
<arrowlink COLOR="#1b36ab" DESTINATION="ID_483631091" ENDARROW="Default" ENDINCLINATION="-88;6;" ID="Arrow_ID_1079857163" STARTARROW="None" STARTINCLINATION="-26;-28;"/>
|
|
<node CREATED="1565282951687" ID="ID_870458664" MODIFIED="1565282960279" TEXT="ein System verschachtelter Scopes"/>
|
|
<node CREATED="1565282962041" ID="ID_535449128" MODIFIED="1565283000876" TEXT="eine virtuelle Oberfläche zu zeichnen"/>
|
|
<node CREATED="1565283006575" ID="ID_1005063465" MODIFIED="1565283018123" TEXT="Schachtellung durch Vertiefung dargestellt"/>
|
|
<node CREATED="1565283025965" ID="ID_1189129689" MODIFIED="1565283032432" TEXT="eine Folge von Layout-Anweisungen"/>
|
|
</node>
|
|
<node CREATED="1560618654038" ID="ID_1561447255" MODIFIED="1560618660841" TEXT="wie wird es aufgebaut?">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1560618662829" ID="ID_799744277" MODIFIED="1560618668613" TEXT="Rahmen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1560619599886" ID="ID_1652576901" MODIFIED="1560619609798" TEXT="Problem: Fixierte Overview-Ruler">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1560619612613" ID="ID_1255750107" MODIFIED="1560619622751" TEXT="die sind etwas Globales"/>
|
|
<node CREATED="1560619623251" ID="ID_1890187732" MODIFIED="1560619628318" TEXT="aber die Info liegt nur indirekt vor">
|
|
<node CREATED="1560619663110" ID="ID_994568218" MODIFIED="1560619675632" TEXT="die Ruler des top-level-TrackBody"/>
|
|
<node CREATED="1560619676228" ID="ID_1236432450" MODIFIED="1560686343370" TEXT="genauer: die Anzahl dieser Ruler">
|
|
<arrowlink COLOR="#486ebf" DESTINATION="ID_1520503504" ENDARROW="Default" ENDINCLINATION="-1384;0;" ID="Arrow_ID_312917871" STARTARROW="None" STARTINCLINATION="689;0;"/>
|
|
</node>
|
|
<node CREATED="1560685923962" ID="ID_1098705000" MODIFIED="1576282358054" TEXT="Alternativ könnte es...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...im Session-Modell für eine Timeline jeweils ein Property hierfür geben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560618669419" ID="ID_930843555" MODIFIED="1560618693061" TEXT="Inhalt: durch Traversieren...">
|
|
<node CREATED="1560618694269" ID="ID_1133842596" MODIFIED="1560618694932" TEXT="der TrackBody-Struktur"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1560687839463" ID="ID_1827462767" MODIFIED="1561140522795" TEXT="wer bewirkt diesen Aufbau?">
|
|
<arrowlink COLOR="#a394b6" DESTINATION="ID_1098160043" ENDARROW="Default" ENDINCLINATION="-688;15;" ID="Arrow_ID_1886446261" STARTARROW="None" STARTINCLINATION="442;0;"/>
|
|
<arrowlink COLOR="#9a6ea1" DESTINATION="ID_453891028" ENDARROW="Default" ENDINCLINATION="227;0;" ID="Arrow_ID_1574621169" STARTARROW="None" STARTINCLINATION="227;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1560687908668" FOLDED="true" ID="ID_1449365398" MODIFIED="1561140382981" TEXT="spätestens onDraw() muß es da sein...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1560688238047" ID="ID_228690289" MODIFIED="1560698414957" TEXT="Lösung-1 : refresh/rebuild im Aufruf">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1560698339423" ID="ID_920481708" MODIFIED="1560698348162" TEXT="bequemere Lösung"/>
|
|
<node CREATED="1560698348724" ID="ID_867312220" MODIFIED="1576282358054" TEXT="aber löst das Problem überhaupt nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dann nämlich someone(TM)
|
|
</p>
|
|
<p>
|
|
be Struktur-Änderungen von Außen her "aktiv werden" muß.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Irgendjemand muß mal den Müll runtertragen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560618895535" ID="ID_1961154233" MODIFIED="1561140376217" TEXT="Lösung-2 : rebuild bei Strukturänderung">
|
|
<linktarget COLOR="#795ea0" DESTINATION="ID_1961154233" ENDARROW="Default" ENDINCLINATION="-24;56;" ID="Arrow_ID_1097113138" SOURCE="ID_1716935157" STARTARROW="None" STARTINCLINATION="150;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1560698425620" ID="ID_620629162" MODIFIED="1560698443221" TEXT="hierfür fehlt noch komplett die Infrastuktur"/>
|
|
<node CREATED="1560698444169" ID="ID_1929184570" MODIFIED="1560698455499" TEXT="wir bauen bisher nur Sub-Widgets auf"/>
|
|
<node COLOR="#338800" CREATED="1561049066764" ID="ID_1132615828" MODIFIED="1561140354363" TEXT="Aufbau on-demand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561049080043" ID="ID_1865072728" MODIFIED="1561049150441" TEXT="signalStructureChange leert das Profil">
|
|
<arrowlink COLOR="#89adc8" DESTINATION="ID_1799554074" ENDARROW="Default" ENDINCLINATION="340;0;" ID="Arrow_ID_19787354" STARTARROW="None" STARTINCLINATION="1589;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561049195744" ID="ID_795602177" MODIFIED="1561140362229" TEXT="Zugriff der Renderer auf das Profil">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561049205709" ID="ID_87098848" MODIFIED="1561049213673" TEXT="bisher direkte Referenz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561049214764" ID="ID_1962267741" MODIFIED="1561139793452" TEXT="neue Lösung: getter-Funktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1561139816451" FOLDED="true" ID="ID_1820580687" MODIFIED="1561827483834" TEXT="gefällt mir aber noch nicht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1561139829332" ID="ID_730637336" MODIFIED="1561139839310" TEXT="rein logisch gehört das Profil ja schon hier her"/>
|
|
<node CREATED="1561139846988" ID="ID_565918975" MODIFIED="1561139974752" TEXT="aber der ganze Update-Mechanismus ist ein in sich abgekapselter Belang">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und macht sich aber hier im Quellcode über mehrere Funktionen verteilt breit,
|
|
</p>
|
|
<p>
|
|
ohne daß man ihn hier komplett überblicken kann. Dazu kommt, daß die ganze Verdrahterei
|
|
</p>
|
|
<p>
|
|
über zwei Lambdas hinweg auch nicht besonders <i>geradlinig</i> und verständlich ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561139978982" FOLDED="true" ID="ID_1098160043" MODIFIED="1678407265595" TEXT="doch in den Layout-Manager verschieben?">
|
|
<linktarget COLOR="#a394b6" DESTINATION="ID_1098160043" ENDARROW="Default" ENDINCLINATION="-688;15;" ID="Arrow_ID_1886446261" SOURCE="ID_1827462767" STARTARROW="None" STARTINCLINATION="442;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1561140197469" ID="ID_198072463" MODIFIED="1561140213679" TEXT="Nachteil: der muß dann von der TrackBody-Struktur wissen"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1561140221999" FOLDED="true" ID="ID_1143074852" MODIFIED="1561827482930" TEXT="es sei denn...">
|
|
<arrowlink COLOR="#b13064" DESTINATION="ID_1401239177" ENDARROW="Default" ENDINCLINATION="363;61;" ID="Arrow_ID_807164253" STARTARROW="None" STARTINCLINATION="1263;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1561140235537" ID="ID_633845025" MODIFIED="1561140252066" TEXT="daß das gar nicht Aufgabe der TrackBody-Struktur wäre,"/>
|
|
<node CREATED="1561140254165" ID="ID_1265373483" MODIFIED="1561140267869" TEXT="bzw. dies anders aufgehängt und aktualisiert würde"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1560687932949" ID="ID_386666941" MODIFIED="1560687960297" TEXT="...sofern überhaupt ein TrackBody vorliegt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560687986049" ID="ID_1716935157" MODIFIED="1561049018969" TEXT="Struktur-Änderungen berücksichtigen">
|
|
<arrowlink COLOR="#8475af" DESTINATION="ID_1309792012" ENDARROW="Default" ENDINCLINATION="-81;-4;" ID="Arrow_ID_3475019" STARTARROW="None" STARTINCLINATION="42;0;"/>
|
|
<arrowlink COLOR="#795ea0" DESTINATION="ID_1961154233" ENDARROW="Default" ENDINCLINATION="-24;56;" ID="Arrow_ID_1097113138" STARTARROW="None" STARTINCLINATION="150;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1560618715494" ID="ID_453891028" MODIFIED="1561140513713" TEXT="wer verwaltet das TrackProfil?">
|
|
<linktarget COLOR="#9a6ea1" DESTINATION="ID_453891028" ENDARROW="Default" ENDINCLINATION="227;0;" ID="Arrow_ID_1574621169" SOURCE="ID_1827462767" STARTARROW="None" STARTINCLINATION="227;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1560618780573" ID="ID_1295221704" MODIFIED="1568577629019">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
naheliegend: das <b>BodyCanvasWidget</b> selber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1560618821911" ID="ID_1127517536" MODIFIED="1560619559162" TEXT="muß aber irgendwie an die TrackBody-Struktur delegiert werden">
|
|
<linktarget COLOR="#297bdb" DESTINATION="ID_1127517536" ENDARROW="Default" ENDINCLINATION="118;0;" ID="Arrow_ID_1683662279" SOURCE="ID_2106254" STARTARROW="Default" STARTINCLINATION="118;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1560618895535" ID="ID_1309792012" MODIFIED="1560688134101" TEXT="jedes Struktur-Update muß das Profil neu generieren">
|
|
<linktarget COLOR="#8475af" DESTINATION="ID_1309792012" ENDARROW="Default" ENDINCLINATION="-81;-4;" ID="Arrow_ID_3475019" SOURCE="ID_1716935157" STARTARROW="None" STARTINCLINATION="42;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1560618799458" ID="ID_1264363118" MODIFIED="1560618820650" TEXT="führt zu einem Gestrüpp der Abhängigkeiten">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1568577642375" ID="ID_1566841384" MODIFIED="1568577650307" TEXT="naja geht doch"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560619493205" ID="ID_630720873" MODIFIED="1560619542216" TEXT="logisch würde es irgendwie zum Layout passen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1560619504005" ID="ID_342347780" MODIFIED="1560619513182" TEXT="aber das Layout hat nicht die notwendigen Infos"/>
|
|
<node CREATED="1560619513934" ID="ID_2106254" MODIFIED="1560619564904" TEXT="praktisch alle Infos sind in der TrackBody-Struktur">
|
|
<arrowlink COLOR="#297bdb" DESTINATION="ID_1127517536" ENDARROW="Default" ENDINCLINATION="118;0;" ID="Arrow_ID_1683662279" STARTARROW="Default" STARTINCLINATION="118;0;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1560627625383" ID="ID_269248332" MODIFIED="1560627650483" TEXT="noch nicht recht glücklich mit dieser Lösung....">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1560627658092" ID="ID_624999649" MODIFIED="1575131626153" TEXT="wo bleibt der Display Evaluation Pass?">
|
|
<arrowlink COLOR="#921d48" DESTINATION="ID_191170582" ENDARROW="Default" ENDINCLINATION="1620;0;" ID="Arrow_ID_982561049" STARTARROW="None" STARTINCLINATION="299;22;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1540641317386" FOLDED="true" ID="ID_151954769" MODIFIED="1679361575919" TEXT="Canvas">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_151954769" ENDARROW="Default" ENDINCLINATION="263;-88;" ID="Arrow_ID_1923805019" SOURCE="ID_18552766" STARTARROW="None" STARTINCLINATION="93;24;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1554480347233" HGAP="-16" ID="ID_1408962662" MODIFIED="1557498707229" VSHIFT="-10">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>grundsätzlich</u>: <i>es zeichnet der Canvas</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#a07373" STYLE="linear"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1555082815168" ID="ID_1445154694" MODIFIED="1557498707229" TEXT="er entscheidet aber nicht über die Struktur"/>
|
|
<node CREATED="1555082847183" ID="ID_822850985" MODIFIED="1557498707229" TEXT="sondern bekommt Struktur-Info hereingereicht"/>
|
|
</node>
|
|
<node CREATED="1569709553921" ID="ID_578594394" MODIFIED="1569711340989" TEXT="Zugang zum Canvas">
|
|
<linktarget COLOR="#2245a8" DESTINATION="ID_578594394" ENDARROW="Default" ENDINCLINATION="-218;1468;" ID="Arrow_ID_1185551045" SOURCE="ID_892450390" STARTARROW="None" STARTINCLINATION="-1702;0;"/>
|
|
<node CREATED="1569709570975" ID="ID_743741751" MODIFIED="1569709577189" TEXT="strukturelles Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1569709579218" ID="ID_1213846218" MODIFIED="1569709593626" TEXT="der Canvas ist effektiv global (für eine Timeline)"/>
|
|
<node CREATED="1569709599619" ID="ID_195478308" MODIFIED="1569709628435" TEXT="aber die hierarchisch verschachtelten Komponenten sind auf ihn angewiesen"/>
|
|
<node CREATED="1569709651932" ID="ID_1646518205" MODIFIED="1576282358053" TEXT="und es soll nicht...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i><font color="#b4288e">everyone and my grandma does it this way... </font></i>
|
|
</p>
|
|
<p>
|
|
Kein Wunder daß die meisten UIs aus Sicht des Programmierers ein Albtraum sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1569709659444" ID="ID_5126624" MODIFIED="1569709680337" TEXT="eine globale Gott-Klasse die Widgets und Zeichenaktionen zentral fernsteuern"/>
|
|
<node CREATED="1569709681558" ID="ID_1351310565" MODIFIED="1569709748956" TEXT="die Einzelkomponente ihre Position in der Struktur kennen, navigieren und manipulieren"/>
|
|
<node CREATED="1569709700341" ID="ID_150824940" MODIFIED="1569709726454" TEXT="die Einzelkomponente direkt in den (zentralen/globalen) Canvas reingreifen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569711798770" ID="ID_1246108677" MODIFIED="1569712021835">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Abstraktion: <b>ViewHook</b> (->Canvas)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_756780463" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<node CREATED="1569710397111" ID="ID_1086691958" MODIFIED="1569710431481" TEXT="verkörpert die Beziehung zwischen Timeline-Element und Canvas"/>
|
|
<node CREATED="1569710432506" ID="ID_284533518" MODIFIED="1569710437509" TEXT="hat einen Lebenszyklus">
|
|
<node CREATED="1569710516577" ID="ID_674995195" MODIFIED="1569710530825" TEXT="wird durch Anbinden des Elements (z.B. Widget) erstellt"/>
|
|
<node CREATED="1569710531677" ID="ID_1914994523" MODIFIED="1569710563476" TEXT="löst und entfernt am Ende das Element aus der Anzeige"/>
|
|
</node>
|
|
<node CREATED="1569710950218" ID="ID_303793411" MODIFIED="1569710958668" TEXT="kann "nach Hause telefonieren"">
|
|
<node CREATED="1569710965394" ID="ID_208711007" MODIFIED="1569710983588" TEXT="und abstrahiert damit die direkte Verbindung zum Canvas/DisplayManager weg"/>
|
|
<node CREATED="1569710984776" ID="ID_1613132645" MODIFIED="1569711005893" TEXT="kann dadurch weitere Sub-Hooks installieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540951718734" HGAP="69" ID="ID_179159881" MODIFIED="1557498707229" TEXT="TrackBody" VSHIFT="-42">
|
|
<node CREATED="1540951732747" ID="ID_879954288" MODIFIED="1557498707229" TEXT="kein Widget, sondern eine Hilfs-Struktur"/>
|
|
<node CREATED="1540951833141" ID="ID_387631457" MODIFIED="1563143876501" TEXT="steuert für den Canvas das Zeichnen für einen Track"/>
|
|
<node CREATED="1540951862399" ID="ID_708158546" MODIFIED="1557498707229" TEXT="relative Koordinaten (und sowiso nur vertikal)"/>
|
|
<node CREATED="1540951873159" ID="ID_1843757439" MODIFIED="1557498707229" TEXT="kennt aber seine eigene Höhe"/>
|
|
<node CREATED="1540951934151" ID="ID_1702719060" MODIFIED="1557498707229" TEXT="Bestandteile">
|
|
<node CREATED="1540951946493" ID="ID_803471574" MODIFIED="1557498707229" TEXT="overview ruler"/>
|
|
<node CREATED="1540951953036" ID="ID_1163326543" MODIFIED="1557498707229" TEXT="content area"/>
|
|
<node CREATED="1540951987535" ID="ID_1044870207" MODIFIED="1557498707229" TEXT="sub-content"/>
|
|
<node CREATED="1540952017027" ID="ID_1004640509" MODIFIED="1557498707229" TEXT="Sequenz von (nested) sub TrackBody"/>
|
|
</node>
|
|
<node CREATED="1540953620811" ID="ID_421197092" MODIFIED="1557498707229" TEXT="Aufgaben">
|
|
<node CREATED="1540953625171" ID="ID_1987245010" MODIFIED="1557498707229" TEXT="sub-TrackBody verwalten"/>
|
|
<node CREATED="1540953632393" ID="ID_132647407" MODIFIED="1557498707229" TEXT="gesamt-Höhe ermitteln"/>
|
|
<node CREATED="1540953791364" ID="ID_540126417" MODIFIED="1557498707229" TEXT="vertikale Koordinaten zum Platzieren von Content ermitteln"/>
|
|
<node CREATED="1540953642160" ID="ID_1963147841" MODIFIED="1557498707229" TEXT="Hintergrund für eigenen Bereich zeichnen"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1544839283413" FOLDED="true" ID="ID_960193981" MODIFIED="1679360284129" TEXT="Ruler-Tracks bauen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="flag"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544849233126" ID="ID_1576984939" MODIFIED="1557498707229" TEXT="#1193 represent time and overview rulers">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1554995807523" ID="ID_896927472" MODIFIED="1557498707229" TEXT="grundsätzliches Konzept">
|
|
<node CREATED="1554995813195" ID="ID_1158334025" MODIFIED="1557498707229" TEXT="sind Modell-Elemente"/>
|
|
<node CREATED="1554995818270" ID="ID_753876518" MODIFIED="1557498707229" TEXT="werden in den Track injiziert"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1554995829834" ID="ID_1945074845" MODIFIED="1674161238640" TEXT="teilweise noch unklar">
|
|
<linktarget COLOR="#af637b" DESTINATION="ID_1945074845" ENDARROW="Default" ENDINCLINATION="-348;-196;" ID="Arrow_ID_1261991748" SOURCE="ID_1182180069" STARTARROW="None" STARTINCLINATION="-383;24;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1554995834875" ID="ID_1119649795" MODIFIED="1674159488258" TEXT="Zusammenspiel mit Expand/Collapse">
|
|
<arrowlink COLOR="#926b99" DESTINATION="ID_1440303749" ENDARROW="Default" ENDINCLINATION="-978;62;" ID="Arrow_ID_1979782904" STARTARROW="None" STARTINCLINATION="-281;21;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1555020163776" ID="ID_1470546162" MODIFIED="1557498707229" TEXT="collapsed == Scope durch Ruler ersetzt"/>
|
|
<node CREATED="1555020175102" ID="ID_1798602" MODIFIED="1557498707229">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>das </i>ist ein reiner (pesistent) presentation state
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1674159496551" ID="ID_1094568733" MODIFIED="1674159514737" TEXT="Trotzdem muß es in das Timeline-globale Layout einbezogen werden"/>
|
|
</node>
|
|
<node CREATED="1561151742029" ID="ID_857875045" MODIFIED="1561151755207" TEXT="repräsentiert als Ruler des top-level-Track"/>
|
|
<node COLOR="#338800" CREATED="1561151772593" ID="ID_1142063549" MODIFIED="1566406715937" TEXT="aber die Zahl der Präfix-Elemente muß korrekt eingesetzt werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1554995841966" ID="ID_1443277448" MODIFIED="1561151658998" TEXT="genaue Rolle der Session??">
|
|
<linktarget COLOR="#ce7c94" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="509;0;" ID="Arrow_ID_1589685813" SOURCE="ID_725781646" STARTARROW="None" STARTINCLINATION="296;0;"/>
|
|
<linktarget COLOR="#ce7c94" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="509;0;" ID="Arrow_ID_1860575220" SOURCE="ID_790305134" STARTARROW="None" STARTINCLINATION="296;0;"/>
|
|
<linktarget COLOR="#337fe3" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="-2069;0;" ID="Arrow_ID_934863827" SOURCE="ID_1520503504" STARTARROW="Default" STARTINCLINATION="-702;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544839288936" ID="ID_43593052" MODIFIED="1566406817964" TEXT="Ruler-Konfigs in das systematische UI-Modell">
|
|
<arrowlink COLOR="#5f84b0" DESTINATION="ID_1083901292" ENDARROW="Default" ENDINCLINATION="-746;-75;" ID="Arrow_ID_1167484185" STARTARROW="None" STARTINCLINATION="-981;0;"/>
|
|
<linktarget COLOR="#5287c5" DESTINATION="ID_43593052" ENDARROW="Default" ENDINCLINATION="-197;439;" ID="Arrow_ID_350259030" SOURCE="ID_1516897126" STARTARROW="None" STARTINCLINATION="-244;0;"/>
|
|
<node COLOR="#338800" CREATED="1544849869166" ID="ID_1025477379" MODIFIED="1557498707229" TEXT="Frage: wo ansiedeln?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544849875744" ID="ID_27673928" MODIFIED="1557498707229" TEXT="im TrackPresenter">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1553911581890" ID="ID_1856936034" MODIFIED="1557498707229">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das wäre der <i>logisch richtige</i> Ort
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1553911598855" ID="ID_400583625" MODIFIED="1557498707230" TEXT="aber jede konkrete Aktion müßte dann stets durch den Display-Frame durchgreifen"/>
|
|
<node CREATED="1553911621023" ID="ID_403549572" MODIFIED="1557498707230" TEXT="daher ist es besser, nur einmal das Binding nach untern durchgreifen zu lassen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544849880757" ID="ID_1796042436" MODIFIED="1557498707230" TEXT="direkt im TimelineBody">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1560173474830" ID="ID_351544133" MODIFIED="1563143676190" TEXT="wie viele sind es?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#ba568c" CREATED="1560173511341" ID="ID_637775069" MODIFIED="1560173529984" TEXT="Monate später...">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1560173498827" ID="ID_553759798" MODIFIED="1560173508018" TEXT="und was meint hier "Konfig"...?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1563143678330" ID="ID_343908242" MODIFIED="1563143681001" TEXT="Antwort">
|
|
<node CREATED="1563143682350" ID="ID_1332243622" MODIFIED="1563143690248" TEXT="beliebig viele, und verschachtelt"/>
|
|
<node CREATED="1563143691380" ID="ID_1703343523" MODIFIED="1563143697157" TEXT="Jeder Track kann Ruler haben"/>
|
|
<node CREATED="1563143698199" ID="ID_1437895403" MODIFIED="1563143711781" TEXT="die Ruler des top-level-Track werden gePinnt dargestellt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1566406728259" ID="ID_763463375" MODIFIED="1566406748449" TEXT="konkrete Ausgestaltung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563143002107" ID="ID_1177786099" MODIFIED="1566406652163" TEXT="verschiedene Ruler-Arten">
|
|
<linktarget COLOR="#c178a8" DESTINATION="ID_1177786099" ENDARROW="Default" ENDINCLINATION="-1830;0;" ID="Arrow_ID_829837415" SOURCE="ID_104997878" STARTARROW="None" STARTINCLINATION="576;-53;"/>
|
|
<linktarget COLOR="#622e7d" DESTINATION="ID_1177786099" ENDARROW="Default" ENDINCLINATION="556;0;" ID="Arrow_ID_1339566753" SOURCE="ID_1063302647" STARTARROW="Default" STARTINCLINATION="556;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1566406750272" ID="ID_1606625965" MODIFIED="1566406839560" TEXT="Steuerung der konkreten Höhe (gemäß Inhalt)">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1566406763774" ID="ID_764785834" MODIFIED="1566406772229" TEXT="verwende bisher Platzhalter-Konstanten">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1566518895896" ID="ID_1389016008" MODIFIED="1566518921254" TEXT="Achtung: Margin+Padding gemäß Stylesheet mit berücksichtigen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1566406773325" ID="ID_1516897126" MODIFIED="1566406830389" TEXT="soll einmal aus dem systematischen UI-Modell bzw Session-Modell kommen">
|
|
<arrowlink COLOR="#5287c5" DESTINATION="ID_43593052" ENDARROW="Default" ENDINCLINATION="-197;439;" ID="Arrow_ID_350259030" STARTARROW="None" STARTINCLINATION="-244;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541814972977" HGAP="8" ID="ID_1482433902" MODIFIED="1557498707230" TEXT="offen..." VSHIFT="5">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541814988759" ID="ID_327310802" MODIFIED="1557498707230" TEXT="muß der TrackBody seinen Namen kennen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1561047126901" ID="ID_376833399" MODIFIED="1561047145040" TEXT="Ordnung und Entfernen von sub-Track Bodies!!">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566955479862" HGAP="37" ID="ID_933224238" MODIFIED="1566955502545" TEXT="Koordinaten & Position" VSHIFT="-9">
|
|
<node CREATED="1566955505470" ID="ID_1718751102" MODIFIED="1566955652259" TEXT="unterer Canvas muß zusammen mit Header-Pane scrollen">
|
|
<linktarget COLOR="#327dd5" DESTINATION="ID_1718751102" ENDARROW="Default" ENDINCLINATION="-1329;-302;" ID="Arrow_ID_1962173714" SOURCE="ID_1649819002" STARTARROW="None" STARTINCLINATION="650;36;"/>
|
|
<node COLOR="#338800" CREATED="1566955655903" ID="ID_652481986" MODIFIED="1566955664590" TEXT="gemeinsames Adjustment verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1566955668964" ID="ID_125473464" MODIFIED="1568577727577" TEXT="Vorsicht: Koordinaten müssen zusammenpassen">
|
|
<arrowlink COLOR="#b84775" DESTINATION="ID_337498242" ENDARROW="Default" ENDINCLINATION="89;0;" ID="Arrow_ID_1188180583" STARTARROW="None" STARTINCLINATION="159;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566955690993" ID="ID_1222461806" MODIFIED="1576974623765" TEXT="Koordinaten auf dem Canvas">
|
|
<linktarget COLOR="#474293" DESTINATION="ID_1222461806" ENDARROW="Default" ENDINCLINATION="-912;90;" ID="Arrow_ID_890343372" SOURCE="ID_1628336999" STARTARROW="None" STARTINCLINATION="-1540;96;"/>
|
|
<node CREATED="1566955702936" ID="ID_43945835" MODIFIED="1576974756059" TEXT="Idee: gemeinsam normieren">
|
|
<arrowlink COLOR="#744479" DESTINATION="ID_130702763" ENDARROW="Default" ENDINCLINATION="687;939;" ID="Arrow_ID_32276313" STARTARROW="Default" STARTINCLINATION="199;-719;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1566955722421" ID="ID_337498242" MODIFIED="1566955828220" TEXT="Problem: gekoppelte Scrollbar">
|
|
<linktarget COLOR="#b84775" DESTINATION="ID_337498242" ENDARROW="Default" ENDINCLINATION="89;0;" ID="Arrow_ID_1188180583" SOURCE="ID_125473464" STARTARROW="None" STARTINCLINATION="159;0;"/>
|
|
</node>
|
|
<node CREATED="1566955756437" ID="ID_572662558" MODIFIED="1566955768492" TEXT="Problem: steuern der Zeichen-Aktivität"/>
|
|
<node CREATED="1566955769779" ID="ID_1433989024" MODIFIED="1566955904369" TEXT="Vorteil: Positionieren der Widgets">
|
|
<arrowlink COLOR="#524b74" DESTINATION="ID_1316730142" ENDARROW="Default" ENDINCLINATION="530;-50;" ID="Arrow_ID_1561193123" STARTARROW="Default" STARTINCLINATION="424;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566955786323" ID="ID_1411864272" MODIFIED="1582926979997" TEXT="Alternative: jeder sub-Canvas hat seinen eigenen Origin">
|
|
<linktarget COLOR="#5d3885" DESTINATION="ID_1411864272" ENDARROW="Default" ENDINCLINATION="-1041;0;" ID="Arrow_ID_1078761950" SOURCE="ID_309596538" STARTARROW="None" STARTINCLINATION="-660;30;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1568384149932" ID="ID_364410899" MODIFIED="1576974893896" TEXT="inzwischen erscheint mit diese Lösung immer attraktiver...">
|
|
<linktarget COLOR="#efd0af" DESTINATION="ID_364410899" ENDARROW="Default" ENDINCLINATION="1299;64;" ID="Arrow_ID_1373879262" SOURCE="ID_680399486" STARTARROW="None" STARTINCLINATION="477;28;"/>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1568577545755" ID="ID_752815491" MODIFIED="1568577574366">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dann <i>innerhalb </i>des Canvas alles konsistent ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1568577575631" ID="ID_1451371313" MODIFIED="1568577585114" TEXT="..und übersetzt werden muß ohnehin"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1582926994758" ID="ID_392725300" MODIFIED="1582926998672" TEXT="so mach'mas">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1541861473496" FOLDED="true" ID="ID_457526663" MODIFIED="1679078256361" TEXT="draw">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_457526663" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1979848335" SOURCE="ID_416633797" STARTARROW="None" STARTINCLINATION="709;70;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1542309666407" ID="ID_1721729181" MODIFIED="1557498707230" TEXT="initial....">
|
|
<node CREATED="1542309671333" ID="ID_1283622298" MODIFIED="1557498707230" TEXT="Größe des leeren Canvas">
|
|
<arrowlink COLOR="#60749f" DESTINATION="ID_400560063" ENDARROW="Default" ENDINCLINATION="-46;0;" ID="Arrow_ID_449772156" STARTARROW="None" STARTINCLINATION="-13;18;"/>
|
|
<linktarget COLOR="#4b3d60" DESTINATION="ID_1283622298" ENDARROW="Default" ENDINCLINATION="-940;-885;" ID="Arrow_ID_425073157" SOURCE="ID_547988829" STARTARROW="None" STARTINCLINATION="-915;160;"/>
|
|
<node CREATED="1542309689328" ID="ID_679418178" MODIFIED="1672842637926" TEXT="verwende size-Allocation des ScrolledWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...in dem der Timeline body-canvas nämlich liegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#795b80" DESTINATION="ID_548414744" ENDARROW="Default" ENDINCLINATION="-897;636;" ID="Arrow_ID_1661740759" STARTARROW="Default" STARTINCLINATION="-286;-17;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1678924505204" ID="ID_25210334" MODIFIED="1678924536707" TEXT="Pixel-Breite daraus ⟹ Kalibrieren des ZoomWindow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541861481967" ID="ID_1316730142" MODIFIED="1566955904369" TEXT="Feststellen der Canvas-Position">
|
|
<arrowlink COLOR="#2a79c1" DESTINATION="ID_1038931568" ENDARROW="Default" ENDINCLINATION="-511;19;" ID="Arrow_ID_1052516165" STARTARROW="None" STARTINCLINATION="-253;-12;"/>
|
|
<linktarget COLOR="#524b74" DESTINATION="ID_1316730142" ENDARROW="Default" ENDINCLINATION="530;-50;" ID="Arrow_ID_1561193123" SOURCE="ID_1433989024" STARTARROW="Default" STARTINCLINATION="424;0;"/>
|
|
<node CREATED="1541862243012" ID="ID_400560063" MODIFIED="1557498707230" TEXT="Canvas kennt seine eigene Ausdehnung (in Pixeln)">
|
|
<linktarget COLOR="#60749f" DESTINATION="ID_400560063" ENDARROW="Default" ENDINCLINATION="-46;0;" ID="Arrow_ID_449772156" SOURCE="ID_1283622298" STARTARROW="None" STARTINCLINATION="-13;18;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1554418097774" ID="ID_49602168" MODIFIED="1557498707230" STYLE="fork" TEXT="TODO in welcher Form?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541861743088" ID="ID_1696653468" MODIFIED="1557498707230" TEXT="Display-Manager">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1541861768818" ID="ID_1031864478" MODIFIED="1557498707230" TEXT="Zugriff wie?">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541862804070" ID="ID_430268635" MODIFIED="1678407301724" TEXT="DisplayManager ≙ Abstraktion">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541862816104" ID="ID_1545586243" MODIFIED="1561827465279" TEXT="lokal injiziert beim Aufbau">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1554475687257" ID="ID_908192712" MODIFIED="1554475728633" TEXT="das heißt: separates Thema">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1554475711445" ID="ID_1049987785" MODIFIED="1666450945197" TEXT="im Moment (4/19) egal">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1666450919276" ID="ID_395455214" LINK="#ID_1964864197" MODIFIED="1666450990761" TEXT="indirekt per CanvasHook">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1666451033226" ID="ID_1458699981" MODIFIED="1666451041469" TEXT="wird in die Struktur der Widgets eingewoben"/>
|
|
<node CREATED="1666451042697" ID="ID_163976806" MODIFIED="1666451056971" TEXT="hat Parent-Verkettung (alles inline)"/>
|
|
<node CREATED="1666451059223" ID="ID_169987790" MODIFIED="1666451088837" TEXT="darüber Zugriff auf die zuständige DisplayManager-Impl"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541862265474" ID="ID_1967442368" MODIFIED="1557498707230" TEXT="Grundfunktion: translate window"/>
|
|
<node CREATED="1541862852155" ID="ID_1628726016" MODIFIED="1557498707230" TEXT="Anfragen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1541862862450" ID="ID_1333221051" MODIFIED="1557498707230" TEXT="was ist meine Position und Extension?">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1555024009413" ID="ID_1600874732" MODIFIED="1557498707230" TEXT="welches Pixel-Window muß dargestellt werden">
|
|
<linktarget COLOR="#3d4476" DESTINATION="ID_1600874732" ENDARROW="Default" ENDINCLINATION="561;0;" ID="Arrow_ID_1463649935" SOURCE="ID_1781062229" STARTARROW="None" STARTINCLINATION="550;27;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1555027076942" HGAP="38" ID="ID_479062556" MODIFIED="1557498707230" TEXT="wie bekomme ich das heraus?" VSHIFT="39">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1555027102243" HGAP="40" ID="ID_855793949" MODIFIED="1557498707230" TEXT="Idee" VSHIFT="5">
|
|
<node CREATED="1555027114837" ID="ID_727253754" MODIFIED="1557498707230" TEXT="den TimelineController fragen..?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541861495569" ID="ID_1828075998" MODIFIED="1557498707230" TEXT="Thema: ZoomWindow">
|
|
<arrowlink COLOR="#5b5ca1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="-599;-1344;" ID="Arrow_ID_842684168" STARTARROW="None" STARTINCLINATION="426;56;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612027709754" ID="ID_694928494" MODIFIED="1612027847880" TEXT="Kann u.U. Clips aus der Anzeige ausblenden">
|
|
<arrowlink COLOR="#654e8d" DESTINATION="ID_1027750978" ENDARROW="Default" ENDINCLINATION="-33;-18;" ID="Arrow_ID_1904178479" STARTARROW="None" STARTINCLINATION="-254;16;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612027750832" ID="ID_422490582" MODIFIED="1612027764227" TEXT="wenn die Clips zu weit vom sichtbaren Bereich entfernt wären"/>
|
|
<node CREATED="1612027765032" ID="ID_1742732980" MODIFIED="1612027777304" TEXT="und dadurch der Canvas zu extrem ausgedehnt würde"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542383648143" FOLDED="true" HGAP="41" ID="ID_718536842" MODIFIED="1557498707230" VSHIFT="-6">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>nicht alles</b> wird gezeichnet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1542383666724" ID="ID_1850932291" MODIFIED="1557498707230" TEXT="Clipping-Region">
|
|
<node COLOR="#435e98" CREATED="1542383689152" ID="ID_1534655843" MODIFIED="1557498707230" TEXT="wird der on_draw() mitgegeben">
|
|
<arrowlink COLOR="#5e86ca" DESTINATION="ID_577859258" ENDARROW="Default" ENDINCLINATION="-1494;46;" ID="Arrow_ID_1966515866" STARTARROW="None" STARTINCLINATION="-1797;81;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1555021726291" ID="ID_529262560" MODIFIED="1557498707230" TEXT="Entnehmen und Aufbereiten">
|
|
<node CREATED="1555021755898" ID="ID_968519712" MODIFIED="1557498707230" TEXT="Cairo liefert double-Koordinaten"/>
|
|
<node CREATED="1555021772375" ID="ID_860582416" MODIFIED="1557498707230" TEXT="gdk_cairo_get_clip_rectangle() als Vorlage"/>
|
|
</node>
|
|
<node CREATED="1555021797428" ID="ID_1566025774" MODIFIED="1557498707230" TEXT="Problem: Fallback">
|
|
<node CREATED="1555021809578" ID="ID_1964178964" MODIFIED="1576282358052" TEXT="was wenn die Clip-Region nicht gesetzt ist?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir können nicht von 0 bis MAXINT zeichnen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1555023959073" ID="ID_118083348" MODIFIED="1557498707230" TEXT="auf Pixel-Window zurückfallen">
|
|
<arrowlink COLOR="#677e9a" DESTINATION="ID_1781062229" ENDARROW="Default" ENDINCLINATION="230;6;" ID="Arrow_ID_733563643" STARTARROW="None" STARTINCLINATION="296;77;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542383722599" ID="ID_1927110373" MODIFIED="1557498707230" TEXT="Optimierungs-Potential">
|
|
<node CREATED="1542383737043" ID="ID_1858424140" MODIFIED="1557498707230" TEXT="später">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1542383740622" ID="ID_1742615218" MODIFIED="1557498707230" TEXT="z.B. für Content-Rendering"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542383813145" ID="ID_1027750978" MODIFIED="1557498707230" TEXT="Lumiera display strategy">
|
|
<linktarget COLOR="#654e8d" DESTINATION="ID_1027750978" ENDARROW="Default" ENDINCLINATION="-33;-18;" ID="Arrow_ID_1904178479" SOURCE="ID_694928494" STARTARROW="None" STARTINCLINATION="-254;16;"/>
|
|
<node CREATED="1542383825895" ID="ID_47938908" MODIFIED="1557498707230" TEXT="zweistufige Übersetzung in ein Pixel-Fenster">
|
|
<node CREATED="1542383840687" ID="ID_1981380274" MODIFIED="1557498707230" TEXT="Stufe-1 == Timespan der Timeline"/>
|
|
<node CREATED="1542383859851" ID="ID_892953664" MODIFIED="1557498707230" TEXT="Stufe-2 == gegenwärtig relevanter Ausschnitt">
|
|
<arrowlink COLOR="#6f83c4" DESTINATION="ID_557373288" ENDARROW="Default" ENDINCLINATION="84;-18;" ID="Arrow_ID_391816329" STARTARROW="None" STARTINCLINATION="-125;2;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542383915849" ID="ID_557373288" MODIFIED="1557498707230" TEXT="relevantTimeWindow">
|
|
<linktarget COLOR="#6f83c4" DESTINATION="ID_557373288" ENDARROW="Default" ENDINCLINATION="84;-18;" ID="Arrow_ID_391816329" SOURCE="ID_892953664" STARTARROW="None" STARTINCLINATION="-125;2;"/>
|
|
<node CREATED="1542384024260" ID="ID_1781062229" MODIFIED="1557498707230" TEXT="festgelegt im DisplayManager">
|
|
<arrowlink COLOR="#3d4476" DESTINATION="ID_1600874732" ENDARROW="Default" ENDINCLINATION="561;0;" ID="Arrow_ID_1463649935" STARTARROW="None" STARTINCLINATION="550;27;"/>
|
|
<linktarget COLOR="#677e9a" DESTINATION="ID_1781062229" ENDARROW="Default" ENDINCLINATION="230;6;" ID="Arrow_ID_733563643" SOURCE="ID_118083348" STARTARROW="None" STARTINCLINATION="296;77;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612027859654" ID="ID_1866609580" MODIFIED="1612027898972">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b><font color="#6d2828">Konvention</font></b>: Clips mit start==Time::NEVER werden verborgen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566394354106" FOLDED="true" HGAP="46" ID="ID_1805397888" MODIFIED="1566394373770" TEXT="Zeichen-Strategie" VSHIFT="-10">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1566394375643" ID="ID_597592953" MODIFIED="1566394385458" TEXT="was soll bewirkt werden?">
|
|
<node CREATED="1566394398396" ID="ID_235154852" MODIFIED="1566394410975" TEXT="Bereiche / Zonen sollen erkennbar getrennt sein"/>
|
|
<node CREATED="1566394429448" ID="ID_1545751655" MODIFIED="1566394461896" TEXT="zueinander gehörige Elemente sollen deutlich werden"/>
|
|
<node CREATED="1566394412259" ID="ID_1529404821" MODIFIED="1566394427263" TEXT="System verschachtelter Scopes soll sich unmittelbar mitteilen"/>
|
|
</node>
|
|
<node CREATED="1566394484401" ID="ID_45833911" MODIFIED="1566394488525" TEXT="Darstellungs-Ansatz">
|
|
<node CREATED="1566394489985" ID="ID_130800194" MODIFIED="1566394503171" TEXT="durch ein 3D-Profil darstellen">
|
|
<node CREATED="1566394504879" ID="ID_106666528" MODIFIED="1566394519122" TEXT="Diskussion 90er-Look vs flat design"/>
|
|
<node CREATED="1566394541001" ID="ID_878559119" MODIFIED="1566394556367">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>manchmal</i> ist die alte Lösung besser
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1566394596499" ID="ID_1873797848" MODIFIED="1566394621437" TEXT="Fortschritts-Prozeß vs. Erfassen einer Idee"/>
|
|
<node CREATED="1566394624791" ID="ID_328891828" MODIFIED="1576282358052" TEXT="das gilt auch für graphische Oberflächen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Idee einer graphischen Benutzeroberfläche hat sich über die 60er / 70er-Jahre herausgebildet.
|
|
</p>
|
|
<p>
|
|
Nachdem die Idee einmal gefaßt ist, gibt es nur noch Oberflächendifferenzierung.
|
|
</p>
|
|
<p>
|
|
Und letztere neigt stets zur "Verschlimmbesserung"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566395139227" ID="ID_744743691" MODIFIED="1566395149200" TEXT="grundsätzliche Eigenschaften einer 3D-Schattierung">
|
|
<node CREATED="1566395154793" ID="ID_1344119568" MODIFIED="1566395168947" TEXT="sie benötigt eine vergleichsweise einfache Struktur"/>
|
|
<node CREATED="1566395170922" ID="ID_953629359" MODIFIED="1566395187520" TEXT="sie arbeitet am Besten im mittleren Helligkeitsbereich"/>
|
|
<node CREATED="1566395188597" ID="ID_1901821236" MODIFIED="1566395201759" TEXT="Tiefenstaffelung wirkt stets nur lokal"/>
|
|
</node>
|
|
<node CREATED="1566395244949" ID="ID_1286928751" MODIFIED="1566395284757" TEXT="Ziel ist daher: lokal ein Gefälle zu vermitteln">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1566395269617" ID="ID_214269730" MODIFIED="1566395275117" TEXT=""hier ist eine Barriere""/>
|
|
<node CREATED="1566395276021" ID="ID_890095997" MODIFIED="1566395280113" TEXT=""hier geh'ts rein""/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566395368540" ID="ID_901032552" MODIFIED="1566395373199" TEXT="Konsequenz">
|
|
<node CREATED="1566395374251" ID="ID_770036633" MODIFIED="1566395383792" TEXT="wir arbeiten ein Profil ab"/>
|
|
<node CREATED="1566395384746" ID="ID_869767169" MODIFIED="1566395414266" TEXT="wir zeichnen nicht einen Stapel"/>
|
|
<node CREATED="1566395415590" ID="ID_719677480" MODIFIED="1576282358051" TEXT="warum? Weil unsere Strukturen für letzteres zu komplex sind">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gestapelte Strukturen dieser Komplexität lassen sich nicht durch Schattierung vermitteln.
|
|
</p>
|
|
<p>
|
|
Wohl aber lassen sich lokale Nachbarschafts-Beziehungen (höhe / tiefer) durch Schattierung hervorheben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1566395532950" ID="ID_9111832" MODIFIED="1576282358051" TEXT="die CSS-Effekten spielen daher nur eine begrenzte Rolle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar im Wesentliche zur Schattierung der Flanken.
|
|
</p>
|
|
<p>
|
|
Die Inhalts-Flächen selber sind zu groß und zu strukturiert, um sie per Schattierung zu verdeutlichen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1554480402297" ID="ID_1456965488" MODIFIED="1557498707230" TEXT="wie?">
|
|
<node CREATED="1542388995969" ID="ID_343346390" MODIFIED="1557498707230" TEXT="Ablauf-Plan">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1542389054873" ID="ID_1270989660" MODIFIED="1557498707230" TEXT="Auslöser: draw-Signal an Canvas">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1542389117416" ID="ID_688086253" MODIFIED="1557498707230" TEXT="Canvas an Display-Manager: Draw-Evaluation">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1542389301246" ID="ID_244922384" MODIFIED="1557498707230" TEXT="(ggfs) ZoomWindow neu etablieren">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1554480448693" FOLDED="true" ID="ID_1659558780" MODIFIED="1679078204479" STYLE="fork" TEXT="Struktur-Profil">
|
|
<linktarget COLOR="#2e66db" DESTINATION="ID_1659558780" ENDARROW="Default" ENDINCLINATION="-889;0;" ID="Arrow_ID_1691760775" SOURCE="ID_483631091" STARTARROW="None" STARTINCLINATION="828;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1554480470481" ID="ID_936706731" MODIFIED="1557498707230" TEXT="Canvas bezieht vom Root-Body eine Verb-Sequenz"/>
|
|
<node CREATED="1554516114006" ID="ID_1074831376" MODIFIED="1557498707230" TEXT="diese Verb-Sequenz wird rekursiv aufgebaut"/>
|
|
<node CREATED="1554516233179" ID="ID_659430585" MODIFIED="1557498707230" TEXT="der draw()-Code interpretiert sie"/>
|
|
<node CREATED="1554516127873" FOLDED="true" ID="ID_134859232" MODIFIED="1557498707230" TEXT="heap-allozierte Liste">
|
|
<node CREATED="1554516153981" ID="ID_683878349" MODIFIED="1557498707230" TEXT="Lazy">
|
|
<node CREATED="1554516163980" ID="ID_151765359" MODIFIED="1557498707230" TEXT="neu bauen wenn leer"/>
|
|
<node CREATED="1554516172112" ID="ID_1550870826" MODIFIED="1557498707230" TEXT="leeren zum Invalidieren"/>
|
|
</node>
|
|
<node CREATED="1554516191248" ID="ID_379475221" MODIFIED="1557498707230" TEXT="on_draw() ist häufiger als Strukturänderungen"/>
|
|
<node CREATED="1554567390096" ID="ID_611611667" MODIFIED="1557498707230" TEXT="Liste nicht verbergen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1554567399523" ID="ID_139156989" MODIFIED="1557498707230" TEXT="der draw-Code darf durchaus die Liste sehen"/>
|
|
<node CREATED="1554567408804" ID="ID_1274839361" MODIFIED="1576282358050" TEXT="ggfs muß er nämlich den Kontext beachten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...zum Beispiel um einen "Wall" auch expressiv zu schattieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1554516243633" ID="ID_386714682" MODIFIED="1557498707230" TEXT="Verben">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1554516247416" ID="ID_711078188" MODIFIED="1557498707230" TEXT="ruler">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516251688" ID="ID_24688004" MODIFIED="1557498707230" TEXT="gap">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516257065" ID="ID_389097560" MODIFIED="1557498707230" TEXT="content">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516438055" ID="ID_1490793853" MODIFIED="1557498707230" TEXT="open / close">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554567321239" ID="ID_1638157583" MODIFIED="1561827465279" TEXT="prelude / coda">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1554567338981" ID="ID_1124816442" MODIFIED="1554567365787" TEXT="damit der Display-Code da was Spezielles machen kann..."/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561898271161" FOLDED="true" ID="ID_30064777" MODIFIED="1678407327044" TEXT="Problem: Verhältnis num globalen Style">
|
|
<linktarget COLOR="#80738f" DESTINATION="ID_30064777" ENDARROW="Default" ENDINCLINATION="-6;190;" ID="Arrow_ID_970836248" SOURCE="ID_959729268" STARTARROW="None" STARTINCLINATION="-914;34;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1561898579784" ID="ID_663380786" MODIFIED="1561898583005" TEXT="Richtlinien">
|
|
<node CREATED="1561898591844" ID="ID_1774942533" MODIFIED="1561898603170" TEXT="Styling darf kein Fremdkörber sein"/>
|
|
<node CREATED="1561898532955" ID="ID_1068573244" MODIFIED="1561899021391" TEXT="Styling muß im globalen Layout-Manager verankert sein">
|
|
<arrowlink COLOR="#555080" DESTINATION="ID_44229333" ENDARROW="Default" ENDINCLINATION="-1124;49;" ID="Arrow_ID_1040482296" STARTARROW="None" STARTINCLINATION="808;-134;"/>
|
|
</node>
|
|
<node CREATED="1561898553085" ID="ID_253449798" MODIFIED="1561899085407" TEXT="Styling muß mit dem Timeline-Layout-Manager zusammenspielen">
|
|
<arrowlink COLOR="#6557a4" DESTINATION="ID_1536703120" ENDARROW="Default" ENDINCLINATION="-715;74;" ID="Arrow_ID_1260120879" STARTARROW="None" STARTINCLINATION="-1565;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561899203009" ID="ID_334562125" MODIFIED="1561899206564" TEXT="Schwierigkeiten">
|
|
<node CREATED="1561899209829" ID="ID_28458938" MODIFIED="1561899219881" TEXT="muß mit bestehenden Themes zusammenspielen"/>
|
|
<node CREATED="1561899220790" ID="ID_1118436310" MODIFIED="1561899235944" TEXT="sollte für einen (GTK)-Designer verständlich sein"/>
|
|
<node CREATED="1561899237388" ID="ID_726202845" MODIFIED="1561899252295" TEXT="sollte einfache Abkürzungen für (Power)-User bieten"/>
|
|
<node CREATED="1561899286918" ID="ID_431566437" MODIFIED="1561899295830" TEXT="sollte organisch mitwachsen, kein Fremdkörper sein"/>
|
|
</node>
|
|
<node CREATED="1562236265485" FOLDED="true" HGAP="244" ID="ID_995671989" MODIFIED="1564954871840" TEXT="Lösungsansätze" VSHIFT="-23">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1562236280397" ID="ID_1519016774" MODIFIED="1562236318490" TEXT="per Extension-Konvention">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1562236391401" ID="ID_1909236407" MODIFIED="1562236396114" TEXT="Ansatz">
|
|
<node CREATED="1562236323478" ID="ID_1116798122" MODIFIED="1562236334808" TEXT="wir definieren neue Properties per Konvention"/>
|
|
<node CREATED="1562236335828" ID="ID_185933728" MODIFIED="1562236350237" TEXT="der User muß diese explizit stylen"/>
|
|
<node CREATED="1562236351178" ID="ID_340701173" MODIFIED="1562236389823" TEXT="das lumiera.css definiert diese">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und dient damit als Vorlage für Theme-Autoren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562236402521" ID="ID_1932561545" MODIFIED="1562236485937" TEXT="pro">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1562236492000" ID="ID_1686665413" MODIFIED="1562236497122" TEXT="unbegrenzte Möglichkeiten"/>
|
|
<node CREATED="1562236498272" ID="ID_151681009" MODIFIED="1562236504355" TEXT="beliebig ausbaufähig"/>
|
|
<node CREATED="1562236745160" ID="ID_407233261" MODIFIED="1562236753255" TEXT="kann sogar UI-Verhalten steuern"/>
|
|
</node>
|
|
<node CREATED="1562236404795" ID="ID_670259832" MODIFIED="1562236439317" TEXT="con">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1562236526763" ID="ID_123632531" MODIFIED="1562236533326" TEXT="eng mit dem Code verzahnt"/>
|
|
<node CREATED="1562236568582" ID="ID_1608152079" MODIFIED="1562236578278" TEXT="für nicht-Coder ist das "Druiden-Wissen""/>
|
|
<node CREATED="1562236625158" ID="ID_1570550357" MODIFIED="1562236636481" TEXT="look-and-feel ist im Code festgelegt">
|
|
<node CREATED="1562236644532" ID="ID_283204755" MODIFIED="1562236647952" TEXT="implizit"/>
|
|
<node CREATED="1562236649139" ID="ID_1938689754" MODIFIED="1562236664485" TEXT="kann vom Theme-Autor nicht geändert werden"/>
|
|
</node>
|
|
<node CREATED="1562236671969" ID="ID_528043086" MODIFIED="1562236726811" TEXT="ein "ganz anderes Theme" ist nicht möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...jedenfalls nicht ohne Code-Änderung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562236309007" ID="ID_1061023264" MODIFIED="1564954864849" TEXT="Abgreifen vom Theme">
|
|
<linktarget COLOR="#3276c7" DESTINATION="ID_1061023264" ENDARROW="Default" ENDINCLINATION="-113;-2;" ID="Arrow_ID_1703748427" SOURCE="ID_495487458" STARTARROW="None" STARTINCLINATION="-147;-77;"/>
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1562236758656" ID="ID_828079574" MODIFIED="1562236760937" TEXT="Ansatz">
|
|
<node CREATED="1562236767057" ID="ID_1496902826" MODIFIED="1562236775911" TEXT="Code verwendet nur wenige Zeichen-Primitive"/>
|
|
<node CREATED="1562236776876" ID="ID_1339077118" MODIFIED="1562236788875" TEXT="und deren Ausprägung greift er sich aus dem bestehenden Theme"/>
|
|
<node CREATED="1562236801137" ID="ID_1900227252" MODIFIED="1562236836324" TEXT="lumiera.css ist eigentlich nur ein normales Theme">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welches aber lokal auf die Anwendung angewendet wird, mit höherer Priorität
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562236839544" ID="ID_1376635418" MODIFIED="1562236846612" TEXT="pro">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1562236869512" ID="ID_1830540742" MODIFIED="1562236882164" TEXT="fügt sich organisch in das bestehende Styling ein"/>
|
|
<node CREATED="1562236883119" ID="ID_1197279369" MODIFIED="1562236928296" TEXT="übernimmt innovatives Styling/Theming, ohne daß der Theme-Autor davon wissen muß"/>
|
|
</node>
|
|
<node CREATED="1562236842651" ID="ID_1846813911" MODIFIED="1562236849260" TEXT="con">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1562236937084" ID="ID_1575317646" MODIFIED="1562236949362" TEXT="sehr limitierte Ausdrucksmöglichkeiten"/>
|
|
<node CREATED="1562236950422" ID="ID_762660822" MODIFIED="1562236968346" TEXT="zwingt den Code zum "kreativen" Einsatz bestehender Stilmittel"/>
|
|
<node CREATED="1562236989798" ID="ID_1021517173" MODIFIED="1562237012780" TEXT="Zusammenspiel mit dem Theme ist anspruchsvoll zu implementieren für den UI-Programmierer"/>
|
|
<node CREATED="1562237017187" ID="ID_1371977786" MODIFIED="1562237034064" TEXT=""kreative" Themes können zu unerwarteten Nebenwirkungen in Lumiera führen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562237068798" HGAP="216" ID="ID_302021075" MODIFIED="1564954986291" TEXT="Bewertung" VSHIFT="-5">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1562237082842" ID="ID_495487458" MODIFIED="1564954869369" TEXT="zweiter Ansatz ist erstrebenswert">
|
|
<arrowlink COLOR="#3276c7" DESTINATION="ID_1061023264" ENDARROW="Default" ENDINCLINATION="-113;-2;" ID="Arrow_ID_1703748427" STARTARROW="None" STARTINCLINATION="-147;-77;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562237103004" FOLDED="true" ID="ID_1408123827" MODIFIED="1564954726646" TEXT="technische Umsetzbarkeit per Prototyp bestätigt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1562237177115" ID="ID_1110019027" MODIFIED="1562237182470" TEXT="Problembereiche">
|
|
<node CREATED="1562237195711" ID="ID_728761836" MODIFIED="1562237202580" TEXT="slopes / bevels"/>
|
|
<node CREATED="1562237283110" ID="ID_1694914035" MODIFIED="1562237287310" TEXT="Text-Styling">
|
|
<node CREATED="1562237288789" ID="ID_1832038343" MODIFIED="1562237293633" TEXT="spezielle Arten von Text">
|
|
<node CREATED="1562237295338" ID="ID_1514397997" MODIFIED="1562237298920" TEXT="Fehlermeldungen"/>
|
|
<node CREATED="1562237302136" ID="ID_63004669" MODIFIED="1562237310051" TEXT="Displays (z.B. Zeit)"/>
|
|
<node CREATED="1562237321557" ID="ID_1199302482" MODIFIED="1562237326637" TEXT="Syntax-Highlighting"/>
|
|
</node>
|
|
<node CREATED="1562237339927" ID="ID_1217582772" MODIFIED="1562237350772" TEXT="komplexe Labels und mouse-over"/>
|
|
</node>
|
|
<node CREATED="1562237234612" ID="ID_1937806970" MODIFIED="1562237248228" TEXT="Akzente durch Gradienten+Transparenz">
|
|
<node CREATED="1562237258593" ID="ID_204987469" MODIFIED="1562237264780" TEXT=""Glas"-Elemente"/>
|
|
<node CREATED="1562237265912" ID="ID_1827698275" MODIFIED="1562237275771" TEXT=""leuchtende" Elemente"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562237357741" FOLDED="true" ID="ID_836338266" MODIFIED="1564954730183" TEXT="Prototyp / Evaluierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1562238962640" ID="ID_1949200690" MODIFIED="1678462240856" TEXT="#1201 Prototype: custom styled timeline profile">
|
|
<linktarget COLOR="#40a5bc" DESTINATION="ID_1949200690" ENDARROW="Default" ENDINCLINATION="-2003;-104;" ID="Arrow_ID_398104912" SOURCE="ID_1275966904" STARTARROW="None" STARTINCLINATION="2327;166;"/>
|
|
<linktarget COLOR="#3a84dd" DESTINATION="ID_1949200690" ENDARROW="Default" ENDINCLINATION="-483;0;" ID="Arrow_ID_16837481" SOURCE="ID_424517976" STARTARROW="None" STARTINCLINATION="615;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1562238991603" ID="ID_1946428740" MODIFIED="1562238993781" TEXT="Idee">
|
|
<node CREATED="1562239018982" ID="ID_1133508339" MODIFIED="1562239031262" TEXT="Inset / Outset - Frame nutzen"/>
|
|
<node CREATED="1562239032324" ID="ID_1334895694" MODIFIED="1562239043294" TEXT="jeweils den Rest übermalen"/>
|
|
<node CREATED="1562239047914" ID="ID_323531964" MODIFIED="1562239058132" TEXT="Richtung und Dicke programmatisch steuern"/>
|
|
</node>
|
|
<node CREATED="1562239064619" ID="ID_170738372" MODIFIED="1562239068627" TEXT="Ansatzpunkte">
|
|
<node CREATED="1562843944226" ID="ID_873415681" MODIFIED="1562843971532" TEXT="den StyleContext verwenden">
|
|
<arrowlink COLOR="#7c8da1" DESTINATION="ID_73927449" ENDARROW="Default" ENDINCLINATION="207;0;" ID="Arrow_ID_679820364" STARTARROW="None" STARTINCLINATION="-325;70;"/>
|
|
<node CREATED="1562843975693" ID="ID_317751446" MODIFIED="1562843975693">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widget->get_style_context();
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1562843984716" ID="ID_307424732" MODIFIED="1562843987923" TEXT="dieser bietet">
|
|
<node CREATED="1562844021015" ID="ID_1207023648" LINK="https://developer.gnome.org/gtk3/stable/GtkStyleContext.html#gtk-render-background" MODIFIED="1562844091117" TEXT="Hintergrund füllen: gtk-render-background">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1562844067476" ID="ID_1648423736" LINK="https://developer.gnome.org/gtk3/stable/GtkStyleContext.html#gtk-render-frame" MODIFIED="1562844085887" TEXT="Rahmen zeichnen: gtk-render-frame">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562844175946" FOLDED="true" HGAP="53" ID="ID_770758065" MODIFIED="1563033494619" TEXT="dedizierten StyleContext konstruieren" VSHIFT="4">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1562844888515" ID="ID_121593395" MODIFIED="1678460384399" TEXT="Proof-of-Concept für #1171 (widget path)">
|
|
<linktarget COLOR="#2a7734" DESTINATION="ID_121593395" ENDARROW="Default" ENDINCLINATION="1608;-100;" ID="Arrow_ID_1114940878" SOURCE="ID_1465497201" STARTARROW="None" STARTINCLINATION="1991;114;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1678460386966" HGAP="88" ID="ID_301794907" MODIFIED="1678460414188" TEXT="erfolgreich: erfüllt den Zweck" VSHIFT="13">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1562845117699" ID="ID_1145993487" MODIFIED="1563556963512" TEXT="kann man einen WidgetPath künstlich konstruieren?">
|
|
<arrowlink COLOR="#3766bc" DESTINATION="ID_293762905" ENDARROW="Default" ENDINCLINATION="-654;0;" ID="Arrow_ID_711737555" STARTARROW="None" STARTINCLINATION="-2487;0;"/>
|
|
<node CREATED="1562845842871" ID="ID_119822604" MODIFIED="1562845853198" TEXT="widget->get_path()"/>
|
|
<node CREATED="1562854489102" ID="ID_1789577981" MODIFIED="1562854522386" TEXT="der erzeugte WidgetPath ist bereits eine Kopie">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ruft den Konstruktor WidgetPath(gobject, make_copy=true) auf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1562854560779" ID="ID_1139882401" MODIFIED="1562854560779" TEXT="gobject_ ((make_a_copy && gobject) ? gtk_widget_path_copy(gobject) : gobject)"/>
|
|
<node CREATED="1562854618581" ID="ID_1356580321" MODIFIED="1562854656348" TEXT="gtk_widget_path_copy (const GtkWidgetPath *path)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
erzeugt einen neuen leeren GtkWidgetPath
|
|
</li>
|
|
<li>
|
|
kopiert alle Pfad-Elemente
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562854695808" ID="ID_928822856" MODIFIED="1562854704117" TEXT="GTKmm-default-ctor">
|
|
<node CREATED="1562854705417" ID="ID_77172765" MODIFIED="1562854710564" TEXT="Gtk::WidgetPath()"/>
|
|
<node CREATED="1562854711819" ID="ID_1032164346" MODIFIED="1562854723266" TEXT="gobject_ (gtk_widget_path_new())"/>
|
|
</node>
|
|
<node CREATED="1562854781263" ID="ID_1413777843" MODIFIED="1562854790129" TEXT="WidgetPath ist ein boxed GTK-Object">
|
|
<node CREATED="1562854793482" ID="ID_1394514386" MODIFIED="1562854825949" TEXT="d.h. eigentlich nur ein GObj-*-Feld"/>
|
|
<node CREATED="1562854835241" ID="ID_766058517" MODIFIED="1562854840584" TEXT="mit geeignetem Refcounting">
|
|
<node CREATED="1562854871923" ID="ID_332819323" MODIFIED="1562854888696" TEXT="~WidgetPath()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
WidgetPath::~WidgetPath() noexcept
|
|
</p>
|
|
<p>
|
|
{
|
|
</p>
|
|
<p>
|
|
  if(gobject_)
|
|
</p>
|
|
<p>
|
|
    gtk_widget_path_free(gobject_);
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1562947149512" ID="ID_1788757764" MODIFIED="1563033443796" TEXT="was/wie kann man an den Pfad anhängen?">
|
|
<node CREATED="1562947206390" ID="ID_858425792" MODIFIED="1562947209292" TEXT="WidgetPath::path_append_type(GType)"/>
|
|
<node CREATED="1562947226168" ID="ID_1423368720" MODIFIED="1562947248239" TEXT="wie kann ich einen GType konstruieren, wenn es das Widget garnicht gibt??">
|
|
<node CREATED="1562948746502" ID="ID_1583179714" MODIFIED="1562968161548" TEXT="statische Typ-Funktion des jeweiligen Widget nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1562948800171" ID="ID_191911870" MODIFIED="1562968152931" TEXT="static GType 	get_type ()">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562947895737" ID="ID_1560270353" MODIFIED="1562947901380" TEXT="zur Referenz...">
|
|
<node CREATED="1562947912197" ID="ID_613381518" MODIFIED="1562948067345" TEXT="gtk_widget_path_append_type() -- gtkwidgetpath.c, 410">
|
|
<node CREATED="1562947977945" ID="ID_612431307" MODIFIED="1562947981836" TEXT="macht eine GtkCssNodeDeclaration"/>
|
|
<node CREATED="1562947983729" ID="ID_608086934" MODIFIED="1562947991697" TEXT="setzt in dieser den gegebenen GType"/>
|
|
<node CREATED="1562947992640" ID="ID_1261874584" MODIFIED="1562948009009" TEXT="hängt sie an das Path-Array an"/>
|
|
</node>
|
|
<node CREATED="1562948055919" ID="ID_282921775" MODIFIED="1562948098526" TEXT="gtk_widget_path_append_for_widget -- gtkwidget.c, 16413">
|
|
<node CREATED="1562948290392" ID="ID_1190594021" MODIFIED="1562948299890" TEXT="macht append_type(GType)"/>
|
|
<node CREATED="1562948303278" ID="ID_859838875" MODIFIED="1562948308633" TEXT="set object name">
|
|
<node CREATED="1562948491524" ID="ID_405796973" MODIFIED="1562948504665" TEXT="überschreibt den Typ beim CSS-Match"/>
|
|
</node>
|
|
<node CREATED="1562948312341" ID="ID_707638809" MODIFIED="1562948314536" TEXT="set name"/>
|
|
<node CREATED="1562948324645" ID="ID_1760607712" MODIFIED="1562948327590" TEXT="set state"/>
|
|
<node CREATED="1562948334875" ID="ID_1415018307" MODIFIED="1562948338037" TEXT="add classes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562972564394" ID="ID_47205096" MODIFIED="1563033473194" TEXT="scheint zu funktionieren...">
|
|
<arrowlink DESTINATION="ID_1632267547" ENDARROW="Default" ENDINCLINATION="502;0;" ID="Arrow_ID_211374997" STARTARROW="None" STARTINCLINATION="255;50;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1562972574838" ID="ID_425700528" MODIFIED="1562972585258" TEXT="bekomme den Pfad: "paned:dir-ltr.horizontal box:dir-ltr.vertical TrackScope.timeline""/>
|
|
<node CREATED="1562972605077" ID="ID_1232397111" MODIFIED="1562972636996" TEXT="das wäre das TimelineWidget, dann der BodyCanvas, und die neue virtuelle CSS-Node"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562969880923" ID="ID_1675178851" MODIFIED="1562969892966" TEXT="damit einen Gtk::StyleContext konfigurieren">
|
|
<node COLOR="#338800" CREATED="1562969894183" ID="ID_1066073394" MODIFIED="1563033488691" TEXT="StyleContext per Factory erzeugen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
StyleContext::create()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562970409637" ID="ID_156221819" MODIFIED="1563033490587" TEXT="ihm den Pfad zuweisen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
 void set_path(const WidgetPath& path);
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
As a consequence, the style will be regenerated to match the new given path.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562878898257" ID="ID_79779793" MODIFIED="1564954691576" TEXT="Implementierungs-Themen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1562878930347" ID="ID_886529991" MODIFIED="1562878932485" TEXT="Fragen">
|
|
<node CREATED="1562878933594" ID="ID_309429528" MODIFIED="1562878946223" TEXT="wer definiert sinnvollerweise die Layout-Pfade?"/>
|
|
<node CREATED="1562878948640" ID="ID_1131723159" MODIFIED="1562878968203" TEXT="wer erstellt den zugehörigen StyleContext, und wann?"/>
|
|
<node CREATED="1562878977278" ID="ID_115944776" MODIFIED="1562878981971" TEXT="was genau wird übergeben"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1562878987389" FOLDED="true" ID="ID_1874620900" MODIFIED="1563033512000" TEXT="Idee: das Advice-System nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1562879000849" ID="ID_1256390103" MODIFIED="1562879051816" TEXT="sieht nach einem perfekten Anwendungsfall aus">
|
|
<node CREATED="1562879123963" ID="ID_1855893476" MODIFIED="1562879144620" TEXT=""irgendjemand" fragt nach einem symbolisch identifizierten StyleContext"/>
|
|
<node CREATED="1562879145808" ID="ID_976028350" MODIFIED="1562879168101" TEXT=""irgendjemand" weiß tatsächlich über diesen Kontext bescheid"/>
|
|
</node>
|
|
<node CREATED="1562879052788" ID="ID_274365723" MODIFIED="1562879060487" TEXT="Einschränkungen / Problem">
|
|
<node CREATED="1562879061774" ID="ID_1583694008" MODIFIED="1562879069166" TEXT="Advice hat value semantics"/>
|
|
<node CREATED="1562879070975" ID="ID_1883840095" MODIFIED="1562879077355" TEXT="Advice überlebt den Advisor">
|
|
<node CREATED="1562879081192" ID="ID_1551119036" MODIFIED="1562879088424" TEXT="GUI shutdown!">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1562938871344" ID="ID_730423218" MODIFIED="1562938909266" TEXT="Nutzen überwiegt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1562938894799" ID="ID_1935049291" MODIFIED="1562938907617" TEXT="die Einschränkungen stellen kein wirkliches Problem da">
|
|
<node CREATED="1562939007056" ID="ID_1320839503" MODIFIED="1562939011755" TEXT="das UI läuft synchron"/>
|
|
<node CREATED="1562939012631" ID="ID_1894196506" MODIFIED="1562939017443" TEXT="alle Nutzer sind auch im UI"/>
|
|
<node CREATED="1562939018494" ID="ID_490682688" MODIFIED="1562939038240" TEXT="der Advice wird initial im UI-Start festgelegt"/>
|
|
<node CREATED="1562939040420" ID="ID_1741857652" MODIFIED="1562939051541" TEXT="wir speichern ohnehin einen Glib::ref_ptr"/>
|
|
</node>
|
|
<node CREATED="1562938911245" ID="ID_634438250" MODIFIED="1562938945340" TEXT="Alternative wäre, den UiStyle manager als Service zu verdrahten"/>
|
|
<node CREATED="1562938951189" ID="ID_674477866" MODIFIED="1562938984055" TEXT="hier geht es so eindeutig um "bessere" globale Variable..."/>
|
|
<node CREATED="1562938985427" ID="ID_1430350400" MODIFIED="1562939000802" TEXT="und das Advice-System bietet hierfür die adäquate Infrastruktur"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1562972719033" FOLDED="true" ID="ID_1528071219" MODIFIED="1563143772159" TEXT="klären: ist der Style-Pfad sinnvoll / korrekt?">
|
|
<linktarget COLOR="#46558a" DESTINATION="ID_1528071219" ENDARROW="Default" ENDINCLINATION="-297;0;" ID="Arrow_ID_1602346272" SOURCE="ID_678877446" STARTARROW="None" STARTINCLINATION="646;20;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1562972764593" ID="ID_315266947" MODIFIED="1563033166705" TEXT="warum beginnt der Pfad mit dem Timeline-Widget?">
|
|
<node CREATED="1562972783861" ID="ID_284818197" MODIFIED="1562972793575" TEXT="ist das nicht korrekt veranktert?"/>
|
|
<node CREATED="1562972794679" ID="ID_522042066" MODIFIED="1562972802573" TEXT="liegt das an der lib GDL?"/>
|
|
<node CREATED="1562972821550" ID="ID_440374994" MODIFIED="1563033154868" TEXT="oder liegt das am Zeitpunkt des Aufrufs?">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563033192867" ID="ID_243229354" MODIFIED="1563033251713" TEXT="besser erst dann aufrufen, wenn das TimelineWidget schon eingehängt ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. dann aus dem InteractionDirector heraus
|
|
</p>
|
|
<p>
|
|
-- <i>ja dann </i>kann man auch gleich direkt an den UiManager delegieren!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563033292565" ID="ID_1632267547" MODIFIED="1563033473194" TEXT="aktuell ist der Pfad schon sinnvoll (aber noch nicht ideal)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
window:backdrop:dir-ltr.background box:backdrop:dir-ltr.vertical box:backdrop:dir-ltr[2/3].horizontal widget:backdrop:dir-ltr[2/2] widget:backdrop:dir-ltr paned:backdrop:dir-ltr.vertical widget:backdrop:dir-ltr box:backdrop:dir-ltr.vertical notebook:backdrop:dir-ltr[1/1].frame paned:backdrop:dir-ltr.horizontal box:backdrop:dir-ltr.vertical fork.timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1632267547" ENDARROW="Default" ENDINCLINATION="502;0;" ID="Arrow_ID_211374997" SOURCE="ID_47205096" STARTARROW="None" STARTINCLINATION="255;50;"/>
|
|
<node COLOR="#435e98" CREATED="1563035526845" ID="ID_1747578312" MODIFIED="1563037376560" TEXT="warum haben die alle die Pseudo-Klasse :backdrop?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"Widget is in a background toplevel window"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8aafdb" DESTINATION="ID_422408673" ENDARROW="Default" ENDINCLINATION="-430;209;" ID="Arrow_ID_384398411" STARTARROW="None" STARTINCLINATION="-1700;-117;"/>
|
|
<node CREATED="1563035800955" ID="ID_1644301957" MODIFIED="1563035821169" TEXT="vmt. wegen dem Zeitpunkt, an dem der Pfad konstruiert wird"/>
|
|
<node CREATED="1563035791620" ID="ID_1471340967" MODIFIED="1563035834509" TEXT="unschön, aber nicht relevant">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur der letzte Node wird gegen pseudo-Klassen gematcht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563037328957" ID="ID_1150753033" MODIFIED="1563039434820" TEXT="man kann es aber (zurück)setzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
    for (uint i=0; i<pos; ++i)
|
|
</p>
|
|
<p>
|
|
      gtk_widget_path_iter_set_state(path.gobj(), i, GTK_STATE_FLAG_NORMAL);
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563043712231" ID="ID_680778611" MODIFIED="1563043724620" TEXT="überarbeitete Version">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
window.background box.vertical box[2/3].horizontal widget[2/2] widget paned.vertical widget box.vertical notebook[1/1].frame paned.horizontal.timeline-page box.vertical.timeline.timeline-body fork.timeline
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1562972742894" ID="ID_340313615" MODIFIED="1563043738908" TEXT="man sollte die custom-widgets explizit benennen">
|
|
<arrowlink COLOR="#3f4a94" DESTINATION="ID_50010456" ENDARROW="Default" ENDINCLINATION="-1046;66;" ID="Arrow_ID_1862548348" STARTARROW="None" STARTINCLINATION="-1895;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563043742703" ID="ID_1008105312" MODIFIED="1563043747776" TEXT="soweit es überhaupt ging"/>
|
|
<node CREATED="1563043748625" ID="ID_1963576119" MODIFIED="1563043767189" TEXT="C++ Custom-Widgets können nicht ihren CSS-Node-Namen ändern">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1665955930245" ID="ID_886604417" MODIFIED="1665956909622" TEXT="zumindest Glib::ObjectBase-ctor kann man setzen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damit kann man zwar einen Klassennamen für ein Custom-Widget setzen, also z.B.  'gtkmm__CustomObject_xyz' (wobei man xyz an den ctor übergeben hat). Aber das hat keinen Einfluß auf den Tag-Namen, wie er für den CSS-Selector relevant ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563117424492" ID="ID_356525175" MODIFIED="1564954670831" TEXT="Anwendung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563117450249" ID="ID_36783315" MODIFIED="1563117529819">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
spezielle Regel gesetzt auf: <b>.timeline-page > .timeline-body fork.timeline</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563117430347" ID="ID_374547857" MODIFIED="1563117529819" TEXT="bekomme die Hintergrundfarbe aus dem CSS">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563117439402" ID="ID_368389111" MODIFIED="1563117529819" TEXT="bekomme den Margin">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563117502706" ID="ID_935663855" MODIFIED="1563117529819" TEXT="funzt">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564954672366" ID="ID_1355634851" MODIFIED="1564954686984" TEXT="Steuern von Variationen aus dem Code durch zusätzliche Klassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1562237138185" ID="ID_677602530" MODIFIED="1678463636297" TEXT="Fazit">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1564954888128" ID="ID_1198563437" MODIFIED="1564954899795" TEXT="praktisch alles Styling selber kann in das CSS verlagert werden"/>
|
|
<node CREATED="1564954902727" ID="ID_1378854579" MODIFIED="1564954915545" TEXT="es bedarf aber einer ergänzenden Konvention">
|
|
<node CREATED="1564954916804" ID="ID_1454227915" MODIFIED="1564954923583" TEXT="was die einzelnen Nodes dort bedeuten"/>
|
|
<node CREATED="1564954924429" ID="ID_240337663" MODIFIED="1564954936710" TEXT="welche speziellen Klassen herangezogen werden"/>
|
|
</node>
|
|
<node CREATED="1564954940681" ID="ID_974800071" MODIFIED="1564954969233" TEXT="ggfs ergäntzt um einige custom-Properties im Stylesheet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563019888259" HGAP="51" ID="ID_678877446" MODIFIED="1563143772159" TEXT="systematischen CSS-Pfad bereitstellen" VSHIFT="12">
|
|
<arrowlink COLOR="#46558a" DESTINATION="ID_1528071219" ENDARROW="Default" ENDINCLINATION="-297;0;" ID="Arrow_ID_1602346272" STARTARROW="None" STARTINCLINATION="646;20;"/>
|
|
<linktarget COLOR="#4b31cd" DESTINATION="ID_678877446" ENDARROW="Default" ENDINCLINATION="-711;38;" ID="Arrow_ID_643305825" SOURCE="ID_331912016" STARTARROW="Default" STARTINCLINATION="-237;18;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516547904" FOLDED="true" ID="ID_229346999" MODIFIED="1679078281966" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1554516552951" ID="ID_600745992" MODIFIED="1557498707230" TEXT="Festlegungen">
|
|
<node CREATED="1554516555943" ID="ID_1554446719" MODIFIED="1557498707230" TEXT="Argument = vertikal in Pixeln"/>
|
|
<node CREATED="1554516578588" ID="ID_520338948" MODIFIED="1576282358050" TEXT="Spannen inklusive Dekoration">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
weil sonst der TrackBody um die Dekoration wissen müßte,
|
|
</p>
|
|
<p>
|
|
wenn er mit der HeaderPane den benötigten Platz aushandelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1554516626163" ID="ID_1427792739" MODIFIED="1557498707230" TEXT="d.h. der Zeichencode muß seine Dekoration innen einfügen"/>
|
|
<node CREATED="1554516850759" ID="ID_361309913" MODIFIED="1557498707230" TEXT="content muß mit ausreichend Padding platziert werden"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516928332" ID="ID_874621550" MODIFIED="1557498707230" TEXT="Verben definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554571992025" FOLDED="true" ID="ID_1074099376" MODIFIED="1566517833423" TEXT="Anwendung der Verben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566517815129" ID="ID_914599141" MODIFIED="1566517824939" TEXT="Funktionsaufruf via VTable"/>
|
|
<node CREATED="1566517825863" ID="ID_1111586723" MODIFIED="1566517831729" TEXT="Argumente aus embedded Tuple"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516938851" ID="ID_1733864099" MODIFIED="1557498707230" TEXT="Verb-Sequenz speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554516951713" FOLDED="true" ID="ID_318462518" MODIFIED="1679078184057" TEXT="Verben (rekursiv) generieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1554516977204" ID="ID_305770947" MODIFIED="1557498707230" TEXT="Ruler"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561150468059" ID="ID_790305134" MODIFIED="1561151468663" TEXT="fixed Overview Ruler steuern">
|
|
<arrowlink COLOR="#ce7c94" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="509;0;" ID="Arrow_ID_1860575220" STARTARROW="None" STARTINCLINATION="296;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1554516979454" ID="ID_508239889" MODIFIED="1557498707230" TEXT="Gaps handhaben"/>
|
|
<node CREATED="1554516984485" ID="ID_351302473" MODIFIED="1557498707230" TEXT="Content">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1554990830581" ID="ID_1043247821" MODIFIED="1557498707230" TEXT="vorläufig Konstante addiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1554990844745" ID="ID_1673637596" MODIFIED="1557498707230" TEXT="brauche hier Abstimmung mit Layout">
|
|
<linktarget COLOR="#833462" DESTINATION="ID_1673637596" ENDARROW="Default" ENDINCLINATION="363;27;" ID="Arrow_ID_1860808311" SOURCE="ID_857274090" STARTARROW="None" STARTINCLINATION="743;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554990786369" ID="ID_97624142" MODIFIED="1557498707230" TEXT="sub-Tracks">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554990802429" ID="ID_785342074" MODIFIED="1557498707230" TEXT="sub-Track-Slopes zusammensetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554517013770" FOLDED="true" ID="ID_1565362810" MODIFIED="1557498707230" TEXT="Verb-Sequenz konsolidieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566517520897" ID="ID_1585833997" MODIFIED="1566517533715" TEXT="nur beim abschließenden Slope"/>
|
|
<node CREATED="1566517544022" ID="ID_1083102048" MODIFIED="1576282358049" TEXT="fügt dem jeweils letzten hinzu">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...anstatt für jeden schließenden nested scope noch ein weiteres Verb hinzuzufügen.
|
|
</p>
|
|
<p>
|
|
Damit werden effektiv die "schließenden Klammern" in eine einzige zusammengefaßt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1554517023983" ID="ID_582840262" MODIFIED="1679078175801" TEXT="Verb-Sequenz interpretieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1554517097141" ID="ID_1017084418" MODIFIED="1563118296821" TEXT="Übersichts-Ruler handhaben">
|
|
<linktarget COLOR="#44437f" DESTINATION="ID_1017084418" ENDARROW="Default" ENDINCLINATION="1682;-201;" ID="Arrow_ID_187242024" SOURCE="ID_1267787629" STARTARROW="None" STARTINCLINATION="1913;158;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563117568795" ID="ID_1179051544" MODIFIED="1563117587278" TEXT="Unterscheidung realisieren">
|
|
<linktarget COLOR="#ac6889" DESTINATION="ID_1179051544" ENDARROW="Default" ENDINCLINATION="156;56;" ID="Arrow_ID_1100428264" SOURCE="ID_857274090" STARTARROW="None" STARTINCLINATION="592;-47;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1563117596397" ID="ID_925319859" MODIFIED="1563141882354" TEXT="pinned-elements...">
|
|
<node COLOR="#338800" CREATED="1563117655125" FOLDED="true" ID="ID_764471994" MODIFIED="1563141879178" TEXT="in das Profil speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563117603629" ID="ID_760190185" MODIFIED="1563141837891" TEXT="war im prelude()-Verb">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1563117613147" ID="ID_1413963999" MODIFIED="1563141844997" TEXT="keine Gute Idee">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563117630103" ID="ID_251975498" MODIFIED="1563141856315" TEXT="sollte in ein Objekt-Feld im Profil"/>
|
|
</node>
|
|
<node CREATED="1563118014245" ID="ID_336436751" MODIFIED="1563118086917" TEXT="ja...nein...ja...??">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1563118023721" ID="ID_189142395" MODIFIED="1563141663430" TEXT="hatte da vor 1 Monat schon mal darüber nachgedacht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und seinerzeit beschlossen, es vorerst im prelude() zu belassen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#304ed9" DESTINATION="ID_4285270" ENDARROW="None" ENDINCLINATION="751;409;" ID="Arrow_ID_1197384474" STARTARROW="Default" STARTINCLINATION="603;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563118092858" ID="ID_1331508927" MODIFIED="1563141685957" TEXT="jetzt doch ein separates, Feld -- ist doch sauberer">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563117670147" ID="ID_1912884721" MODIFIED="1563141879178" TEXT="Filter realisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1563117686001" ID="ID_698759785" MODIFIED="1563141879178" TEXT="prefix-Filter implementiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563117696328" ID="ID_1599825097" MODIFIED="1576282358048" TEXT="Konzeptioneller Fehler beim Zählen gefixt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nicht nur die Ruler, auch das Prelude selber ist ein solches gePinntes Element (selbst wenn es leer ist)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#25e58e" DESTINATION="ID_337327442" ENDARROW="Default" ENDINCLINATION="523;0;" ID="Arrow_ID_376180455" STARTARROW="Default" STARTINCLINATION="1063;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563143002107" ID="ID_1063302647" MODIFIED="1566406652162" TEXT="verschiedene Ruler-Arten">
|
|
<arrowlink COLOR="#622e7d" DESTINATION="ID_1177786099" ENDARROW="Default" ENDINCLINATION="556;0;" ID="Arrow_ID_1339566753" STARTARROW="Default" STARTINCLINATION="556;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563143025272" FOLDED="true" ID="ID_31825370" MODIFIED="1567112213024" TEXT="Anzeige-Höhe steuern">
|
|
<linktarget COLOR="#a37084" DESTINATION="ID_31825370" ENDARROW="Default" ENDINCLINATION="145;324;" ID="Arrow_ID_1599930326" SOURCE="ID_261041772" STARTARROW="Default" STARTINCLINATION="-943;-105;"/>
|
|
<linktarget COLOR="#564b7e" DESTINATION="ID_31825370" ENDARROW="Default" ENDINCLINATION="178;986;" ID="Arrow_ID_1663311989" SOURCE="ID_1608124774" STARTARROW="None" STARTINCLINATION="-248;-11;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563143033085" ID="ID_149529437" MODIFIED="1567112222516" TEXT="woher kommt die Info?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1563144390094" ID="ID_1352488414" MODIFIED="1563144414266" TEXT="Quelle-1: zusammen mit dem Track-Head "ausgehandelt""/>
|
|
<node CREATED="1563144448477" ID="ID_545543746" MODIFIED="1563144464040" TEXT="Quelle-2: man kann die TrackBody-Struktur (rekursiv) fragen"/>
|
|
<node CREATED="1563144415950" ID="ID_264748187" MODIFIED="1563144447096" TEXT="Quelle-3: wenn der Zeichen-Code fertig ist, weiß man was rauskommt">
|
|
<node CREATED="1563144486739" ID="ID_933628775" MODIFIED="1563144505714" TEXT="die line_ wird hochgezählt"/>
|
|
<node CREATED="1563144507398" ID="ID_231636632" MODIFIED="1563144515788" TEXT="der Renderer könnte die zurückgeben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567112237035" ID="ID_1427979726" MODIFIED="1567112282407" TEXT="Quelle-4: beim Aufstellen des TrackProfile">
|
|
<arrowlink COLOR="#19b37d" DESTINATION="ID_1564197871" ENDARROW="Default" ENDINCLINATION="-60;-64;" ID="Arrow_ID_1251305334" STARTARROW="None" STARTINCLINATION="-169;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563144536346" ID="ID_681708047" MODIFIED="1563144548269" TEXT="wo muß sie gesetzt werden?">
|
|
<node CREATED="1563144549497" ID="ID_1704331189" MODIFIED="1563144560069" TEXT="jeweils in jedem der beiden Canvas-Widgets">
|
|
<node CREATED="1563144627773" ID="ID_215614628" MODIFIED="1563144635638" TEXT="siehe gtk-canvas-experiment.cpp"/>
|
|
<node CREATED="1563144650777" ID="ID_1603192919" MODIFIED="1563144652311" TEXT="Canvas::determineExtension()"/>
|
|
<node CREATED="1563144669172" ID="ID_1489838072" MODIFIED="1563144675523" TEXT="Gtk::Layout::set_size(w,h)"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563144591112" ID="ID_1777300285" MODIFIED="1567112136542" TEXT="muß das vor dem Zeichnen passieren?">
|
|
<node CREATED="1563144864662" ID="ID_1195404065" MODIFIED="1576282358048" TEXT="vermutlich nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
meine Einschätzung, basiert auf dem gtk-canvas-experiment.cpp
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
zeichnen kann man "irgendwie" auf dem Canvas.
|
|
</li>
|
|
<li>
|
|
außerdem hat das Gtk::Layout ein hadjustment() / vadjustment()
|
|
</li>
|
|
<li>
|
|
diese können (optional) an eine Scrolled-Pane angekoppelt sein
|
|
</li>
|
|
<li>
|
|
die tatsächliche size-Allocation ist ein davon unabhängiges Thema
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563145010348" ID="ID_1404407551" MODIFIED="1576282358047">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>rein gefühlsmäßig</i> wäre aber vorher wohl geschickter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn was passiert, wenn sich durch das Setzen einer neuen Größe der sichtbare Bereich ändert? Löst das dann nicht erneut einen draw()-Aufruf aus??
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566401468573" ID="ID_636590903" MODIFIED="1566401510213" TEXT="Beschluß: direkt nach dem Display-Evaluation-Pass">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1566401506391" ID="ID_116486175" MODIFIED="1566401506391" TEXT="BodyCanvasWidget::maybeRebuildLayout()"/>
|
|
<node COLOR="#338800" CREATED="1566401515511" ID="ID_1551253495" MODIFIED="1566406332332" TEXT="neue Funktion hierfür">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566517643320" ID="ID_30150585" MODIFIED="1566517660194" TEXT="fragt den TrackBody"/>
|
|
<node CREATED="1566517661707" ID="ID_1225415802" MODIFIED="1576282358047" TEXT="dieser summiert im Moment einfach nochmal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist ineffizient, aber der Code ist so klarer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1566517682169" ID="ID_1110086285" MODIFIED="1566517691543" TEXT="...so oft wird das nicht gebraucht">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567112155198" ID="ID_1564197871" MODIFIED="1567112274356" TEXT="Lösung: bei der Track-Profil-berechnung auch die Höhen mit berechnen">
|
|
<linktarget COLOR="#19b37d" DESTINATION="ID_1564197871" ENDARROW="Default" ENDINCLINATION="-60;-64;" ID="Arrow_ID_1251305334" SOURCE="ID_1427979726" STARTARROW="None" STARTINCLINATION="-169;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1567112179157" ID="ID_1902444378" MODIFIED="1567112191717" TEXT="weil man dann automatisch die korrekte Rechen-Struktur bekommt"/>
|
|
<node CREATED="1567112192681" ID="ID_1279312303" MODIFIED="1567112207325" TEXT="besonders kniffelig waren die variablen kombinierten up-Slopes">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1554517044045" ID="ID_520113686" MODIFIED="1557498707230" TEXT="Farben bereitstellen">
|
|
<node COLOR="#5b280f" CREATED="1561412290895" FOLDED="true" ID="ID_433241551" MODIFIED="1679077944552" TEXT="Frage/Problem: Farbformat">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1561412301303" ID="ID_813337683" MODIFIED="1561412307145" TEXT="wie werden Farben definiert?"/>
|
|
<node CREATED="1561412312496" ID="ID_1285620209" MODIFIED="1561412338113" TEXT="Anscheinend will Cairo Werte (red, green, blue)"/>
|
|
<node CREATED="1561737420041" ID="ID_620483728" MODIFIED="1562843377740" TEXT="Recherche...">
|
|
<node CREATED="1561413519712" ID="ID_1263142656" LINK="https://stackoverflow.com/a/29000648" MODIFIED="1564505543120" TEXT="Hinweis auf Stackoverflow">
|
|
<linktarget COLOR="#4587d6" DESTINATION="ID_1263142656" ENDARROW="Default" ENDINCLINATION="-80;5;" ID="Arrow_ID_1541352493" SOURCE="ID_1417021403" STARTARROW="None" STARTINCLINATION="-203;0;"/>
|
|
<node CREATED="1561734458294" ID="ID_73927449" MODIFIED="1562843967076">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man sollte den <b>GtkStyleContext</b> nutzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#3d73d3" DESTINATION="ID_161652920" ENDARROW="Default" ENDINCLINATION="-1637;0;" ID="Arrow_ID_990523511" STARTARROW="None" STARTINCLINATION="-2361;0;"/>
|
|
<linktarget COLOR="#7c8da1" DESTINATION="ID_73927449" ENDARROW="Default" ENDINCLINATION="207;0;" ID="Arrow_ID_679820364" SOURCE="ID_873415681" STARTARROW="None" STARTINCLINATION="-325;70;"/>
|
|
</node>
|
|
<node CREATED="1561734477840" ID="ID_608213389" MODIFIED="1562843750948" TEXT="man kann anscheinend Gtk-Farben direkt setzen">
|
|
<arrowlink COLOR="#7890ac" DESTINATION="ID_1404441515" ENDARROW="Default" ENDINCLINATION="1;-116;" ID="Arrow_ID_1920767689" STARTARROW="None" STARTINCLINATION="256;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1561737452937" ID="ID_699098078" MODIFIED="1576282358046">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
speziell die Antwort von <b>ebassi</b> beachten...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Core-Entwickler von GTK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1561740889255" ID="ID_388774572" LINK="https://developer.gnome.org/gtk3/stable/GtkStyleContext.html#gtk-render-background" MODIFIED="1561740901097" TEXT="gtk-render-background()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561412911257" FOLDED="true" ID="ID_1322665426" MODIFIED="1619107323206" TEXT="siehe Cairo-Konzepte">
|
|
<arrowlink COLOR="#5579dd" DESTINATION="ID_1173541827" ENDARROW="Default" ENDINCLINATION="-2465;188;" ID="Arrow_ID_1216025940" STARTARROW="None" STARTINCLINATION="-2437;323;"/>
|
|
<node CREATED="1561412945044" FOLDED="true" ID="ID_475888521" MODIFIED="1561827469138" TEXT="Source">
|
|
<node CREATED="1561412970112" ID="ID_1991984042" MODIFIED="1561412984826" TEXT="Colour"/>
|
|
<node CREATED="1561412985423" ID="ID_108728469" MODIFIED="1561412991540" TEXT="Gradient"/>
|
|
<node CREATED="1561412992114" ID="ID_1558296708" MODIFIED="1561412994561" TEXT="Image"/>
|
|
</node>
|
|
<node CREATED="1561412948428" FOLDED="true" ID="ID_1910080580" MODIFIED="1561827469138" TEXT="Mask">
|
|
<node CREATED="1561412996428" ID="ID_414991349" MODIFIED="1561413006567" TEXT="stroke, fill, text, set_mask()"/>
|
|
<node CREATED="1561413034863" ID="ID_580910330" MODIFIED="1561413051569" TEXT="die Source wird durch die Mask durch "gestempelt""/>
|
|
</node>
|
|
<node CREATED="1561412961226" FOLDED="true" ID="ID_1284012969" MODIFIED="1561827469138" TEXT="Destination">
|
|
<node CREATED="1561413010338" ID="ID_1707967544" MODIFIED="1561413014990" TEXT="Ausgabeformat"/>
|
|
<node CREATED="1561413017945" ID="ID_1938576222" MODIFIED="1561413025642" TEXT="auf dieses wird "gestempelt""/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561414516226" ID="ID_824931972" LINK="https://stackoverflow.com/a/28004070" MODIFIED="1561414534852" TEXT="Hexagonale Cusotm_Buttons zeichen (Python-Beispiel)"/>
|
|
</node>
|
|
<node CREATED="1583677804927" ID="ID_1480149664" MODIFIED="1583677861984" TEXT="könnte letztlich irrelevant sein...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1583677816617" ID="ID_995138607" MODIFIED="1583677832057" TEXT="wenn wir es schaffen, komplett via CSS zu steuern"/>
|
|
<node CREATED="1583677833436" ID="ID_270618428" MODIFIED="1583677990008" TEXT="und das Abgreifen von Style-Infos sieht vielversprechend aus (2/2020)">
|
|
<arrowlink COLOR="#3078ce" DESTINATION="ID_593477946" ENDARROW="Default" ENDINCLINATION="-684;-128;" ID="Arrow_ID_845284570" STARTARROW="None" STARTINCLINATION="-389;16;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1679077911072" ID="ID_1736340765" MODIFIED="1679077929867" TEXT="2023: sieht danach aus daß dem so ist und wir alles per CSS machen können">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561733542012" FOLDED="true" ID="ID_1875127303" MODIFIED="1562843685232" TEXT="ist unsere GTK-Platform veraltet?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1561733673915" ID="ID_1417021403" MODIFIED="1562843774314" TEXT="im Beispiel auf SO werden weitere Farb-Funktionen genutzt">
|
|
<arrowlink COLOR="#4587d6" DESTINATION="ID_1263142656" ENDARROW="Default" ENDINCLINATION="-80;5;" ID="Arrow_ID_1541352493" STARTARROW="None" STARTINCLINATION="-203;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1561733976451" ID="ID_1475316639" MODIFIED="1561733976451" TEXT="Gdk::Cairo::set_source_rgba(cr, cxStyle->get_background_color(Gtk::STATE_FLAG_SELECTED));"/>
|
|
<node CREATED="1561733989084" ID="ID_1024689549" MODIFIED="1561734031800" TEXT="dagegen in Cairomm 1.0 finde ich nur cx->set_source_rgba(r,g,b,a)"/>
|
|
<node COLOR="#435e98" CREATED="1561734414515" ID="ID_1685147022" MODIFIED="1561737091054" TEXT="ist das ein C/C++ - Poblem oder eine veraltete Lib?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561737065424" ID="ID_840108079" MODIFIED="1562843694504">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Nein. Es ist ein G<b>D</b>K-Wrapper/Adapter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561737180408" ID="ID_1186274034" MODIFIED="1561737202377" TEXT="gtkmm3.0-3.22.2/gdk/gdkmm/general.cc"/>
|
|
<node CREATED="1561737220687" ID="ID_1404441515" MODIFIED="1562843746132" TEXT="void set_source_color(Cairo::RefPtr<Cairo::Context> const&, Gdk::Color const&)">
|
|
<linktarget COLOR="#7890ac" DESTINATION="ID_1404441515" ENDARROW="Default" ENDINCLINATION="1;-116;" ID="Arrow_ID_1920767689" SOURCE="ID_608213389" STARTARROW="None" STARTINCLINATION="256;0;"/>
|
|
<linktarget COLOR="#1f8ff9" DESTINATION="ID_1404441515" ENDARROW="Default" ENDINCLINATION="-57;55;" ID="Arrow_ID_401362992" SOURCE="ID_248226991" STARTARROW="None" STARTINCLINATION="421;-12;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561733608450" FOLDED="true" ID="ID_1920301340" MODIFIED="1561827482930" TEXT="wir folgen Debian/Stretch">
|
|
<arrowlink COLOR="#355ad5" DESTINATION="ID_1295139073" ENDARROW="Default" ENDINCLINATION="-816;0;" ID="Arrow_ID_1376879556" STARTARROW="None" STARTINCLINATION="-753;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1561734640481" FOLDED="true" ID="ID_589799153" MODIFIED="1561827469158" TEXT="Cairo/Cairomm">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1561734632551" ID="ID_1292331476" MODIFIED="1561734639059" TEXT=""cairomm wraps all relevant parts of the cairo API and is API/ABI-stable""/>
|
|
<node CREATED="1561734657577" ID="ID_164314300" MODIFIED="1561734661824" TEXT=""cairomm is used by gtkmm since 2.10""/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561737105602" ID="ID_501529157" MODIFIED="1561737117373" TEXT="die Versions-Unterschiede sind minimal"/>
|
|
<node CREATED="1561737119367" ID="ID_1825114442" MODIFIED="1561737128323" TEXT="die Versionen sind adäquat aufeinander abgestimmt"/>
|
|
<node COLOR="#338800" CREATED="1561737129343" ID="ID_248226991" MODIFIED="1561737337666" TEXT="...und wir haben die benötigte Funktion">
|
|
<arrowlink COLOR="#1f8ff9" DESTINATION="ID_1404441515" ENDARROW="Default" ENDINCLINATION="-57;55;" ID="Arrow_ID_401362992" STARTARROW="None" STARTINCLINATION="421;-12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561737350346" ID="ID_1269415740" MODIFIED="1561737360393" TEXT="alles OK">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1554517048572" ID="ID_389539875" MODIFIED="1561742193735" TEXT="zeichnen">
|
|
<node COLOR="#435e98" CREATED="1561742210044" FOLDED="true" HGAP="29" ID="ID_968367319" MODIFIED="1679077895231" TEXT="Konzeptionelles Problem" VSHIFT="-32">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1561742242469" ID="ID_1152083515" MODIFIED="1561742261654" TEXT=""selber zeichnen" vs. CSS / Theme interpretieren"/>
|
|
<node CREATED="1561742304133" FOLDED="true" ID="ID_1162348323" MODIFIED="1561827482930" TEXT="Gtk::StyleContext (== bestehender Style) bietet nur wenige Bausteine">
|
|
<node CREATED="1561742343334" ID="ID_76647765" MODIFIED="1561742348741" TEXT="den Hintergrund"/>
|
|
<node CREATED="1561742349263" ID="ID_1861730113" MODIFIED="1561742351634" TEXT="einen Rahmen"/>
|
|
<node CREATED="1561742352103" ID="ID_761263708" MODIFIED="1561742365888" TEXT="Slider, Checkbox,..."/>
|
|
</node>
|
|
<node CREATED="1561743739850" FOLDED="true" ID="ID_1430099206" MODIFIED="1561827482930" TEXT="ich brauche Zeichen-Primitive einen Level unter dieser Abstraktion">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1561743762966" ID="ID_997992666" MODIFIED="1561743767066" TEXT="Abstraktion: Rahmen"/>
|
|
<node CREATED="1561743767638" ID="ID_262382460" MODIFIED="1561743782584" TEXT="ich brauche: Rampe auf, ab, Rille"/>
|
|
</node>
|
|
<node CREATED="1561743807830" FOLDED="true" ID="ID_1147743931" MODIFIED="1561827482930" TEXT="Lösungsansätze">
|
|
<node CREATED="1561743816367" FOLDED="true" ID="ID_291609711" MODIFIED="1561827469158" TEXT="bestehende Zeichen-Bausteine auswerten">
|
|
<node CREATED="1561743834491" ID="ID_799331387" MODIFIED="1561743841288" TEXT="nur teilweise nutzen"/>
|
|
<node CREATED="1561743841780" ID="ID_281114964" MODIFIED="1561743847831" TEXT="zeichnen und Ergebnis nutzen"/>
|
|
</node>
|
|
<node CREATED="1561743852490" FOLDED="true" ID="ID_1271505058" MODIFIED="1561827469158" TEXT="eigene Zeichen-Bausteine via CSS definieren">
|
|
<node CREATED="1561743872956" FOLDED="true" ID="ID_448887346" MODIFIED="1561827469139" TEXT="in GTK+CSS kann man">
|
|
<node CREATED="1561743897633" ID="ID_1380771561" MODIFIED="1561743898456" TEXT="Gradienten definieren"/>
|
|
<node CREATED="1561743899110" FOLDED="true" ID="ID_1781758898" MODIFIED="1561827465279" TEXT="Farben systematisch konstruieren">
|
|
<node CREATED="1561743908806" ID="ID_1841841538" MODIFIED="1561743913542" TEXT="aufhellen, abdunkeln"/>
|
|
<node CREATED="1561743914853" ID="ID_1774289925" MODIFIED="1561743917877" TEXT="überlagern"/>
|
|
<node CREATED="1561743920577" ID="ID_886231148" MODIFIED="1561743924809" TEXT="mischen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561742210044" FOLDED="true" HGAP="29" ID="ID_561705172" MODIFIED="1679077885971" TEXT="Problem: woher stammt der Style?" VSHIFT="-32">
|
|
<linktarget COLOR="#8b7ea0" DESTINATION="ID_561705172" ENDARROW="Default" ENDINCLINATION="-2256;70;" ID="Arrow_ID_57895594" SOURCE="ID_1803180287" STARTARROW="None" STARTINCLINATION="465;29;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1561898385345" ID="ID_959729268" MODIFIED="1678463415639" TEXT="allgemeines Problem">
|
|
<arrowlink COLOR="#80738f" DESTINATION="ID_30064777" ENDARROW="Default" ENDINCLINATION="-6;190;" ID="Arrow_ID_970836248" STARTARROW="None" STARTINCLINATION="-914;34;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1562238962640" ID="ID_424517976" MODIFIED="1678463379146" TEXT="#1201 Prototype: custom styled timeline profile">
|
|
<arrowlink COLOR="#3a84dd" DESTINATION="ID_1949200690" ENDARROW="Default" ENDINCLINATION="-483;0;" ID="Arrow_ID_16837481" STARTARROW="None" STARTINCLINATION="615;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678576309372" ID="ID_1568473205" MODIFIED="1679011586488" TEXT="konkrete CSS-Styles dokumentieren">
|
|
<arrowlink COLOR="#5f7783" DESTINATION="ID_1232986902" ENDARROW="Default" ENDINCLINATION="2218;-176;" ID="Arrow_ID_1708948555" STARTARROW="None" STARTINCLINATION="4285;319;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1678925372624" ID="ID_348250165" MODIFIED="1678925428123">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TiddlyWiki + <font face="Monospaced" color="#a63077">doc/technical/stage/style/Timeline.txt</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678462308282" ID="ID_1157002655" MODIFIED="1679011586549" TEXT="Lösung: virtueller widget-Path „fischt“ im gegebenen CSS-Kontext">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wir erzeugen künstlich einen widget-Path und verankern ihn sinngemäß an der logisch richtigen Stelle (wobei aber die im Pfad aufgeführten Widgets gar nicht existieren, sondern logische Platzhalter sind). Über diesen Widget-Path greifen wir in einen CSS-Scope hinein, der typischerweise alle seine Styles von umschließenden Scopes erbt; indirekt ist damit aber auch die Möglichkeit geschaffen, diesen speziellen Scope gezielt mit CSS-Regeln zu addressieren — wodurch der Designer direkt auf das Erscheinungbild von Lumiera Einfluß nehmen kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561743807830" ID="ID_593477946" MODIFIED="1561898346705" TEXT="Lösungsansätze">
|
|
<linktarget COLOR="#3078ce" DESTINATION="ID_593477946" ENDARROW="Default" ENDINCLINATION="-684;-128;" ID="Arrow_ID_845284570" SOURCE="ID_270618428" STARTARROW="None" STARTINCLINATION="-389;16;"/>
|
|
<node CREATED="1561743816367" ID="ID_169640206" MODIFIED="1562843547638" TEXT="bestehende Zeichen-Bausteine auswerten">
|
|
<node CREATED="1561743834491" ID="ID_1092817023" MODIFIED="1561743841288" TEXT="nur teilweise nutzen"/>
|
|
<node CREATED="1561743841780" ID="ID_1591551906" MODIFIED="1561743847831" TEXT="zeichnen und Ergebnis nutzen"/>
|
|
</node>
|
|
<node CREATED="1561743852490" FOLDED="true" ID="ID_46761090" MODIFIED="1562843465779" TEXT="eigene Zeichen-Bausteine via CSS definieren">
|
|
<node CREATED="1561743872956" ID="ID_618825350" MODIFIED="1562843458860" TEXT="in GTK+CSS kann man">
|
|
<node CREATED="1561743897633" ID="ID_191212429" MODIFIED="1561743898456" TEXT="Gradienten definieren"/>
|
|
<node CREATED="1561743899110" ID="ID_1314782414" MODIFIED="1562843462296" TEXT="Farben systematisch konstruieren">
|
|
<node CREATED="1561743908806" ID="ID_1349278286" MODIFIED="1561743913542" TEXT="aufhellen, abdunkeln"/>
|
|
<node CREATED="1561743914853" ID="ID_1058920738" MODIFIED="1561743917877" TEXT="überlagern"/>
|
|
<node CREATED="1561743920577" ID="ID_481915878" MODIFIED="1561743924809" TEXT="mischen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563019837771" ID="ID_331912016" MODIFIED="1563021396900" TEXT="generiere und publiziere einen CSS-Pfad">
|
|
<arrowlink COLOR="#4b31cd" DESTINATION="ID_678877446" ENDARROW="Default" ENDINCLINATION="-711;38;" ID="Arrow_ID_643305825" STARTARROW="Default" STARTINCLINATION="-237;18;"/>
|
|
<arrowlink COLOR="#4b31cd" DESTINATION="ID_1755242650" ENDARROW="Default" ENDINCLINATION="-1211;105;" ID="Arrow_ID_847790641" STARTARROW="Default" STARTINCLINATION="-1782;0;"/>
|
|
<node CREATED="1563019856854" ID="ID_1799510436" MODIFIED="1563019861202" TEXT="Gtk::WidgetPath"/>
|
|
<node CREATED="1563019863670" ID="ID_1584577599" MODIFIED="1563019868785" TEXT="Gtk::StyleContext">
|
|
<node CREATED="1563110305840" ID="ID_1669038361" MODIFIED="1563110358754" TEXT="kann Backround füllen">
|
|
<linktarget COLOR="#6295d1" DESTINATION="ID_1669038361" ENDARROW="Default" ENDINCLINATION="-474;0;" ID="Arrow_ID_715907117" SOURCE="ID_1436336037" STARTARROW="None" STARTINCLINATION="52;5;"/>
|
|
</node>
|
|
<node CREATED="1563110313699" ID="ID_667969256" MODIFIED="1563110318169" TEXT="kann Rahmen zeichnen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561742196428" FOLDED="true" ID="ID_1908345164" MODIFIED="1679077873580" TEXT="Flächen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563110329558" ID="ID_1436336037" MODIFIED="1563110365807" TEXT="definiere diese als Background">
|
|
<arrowlink COLOR="#6295d1" DESTINATION="ID_1669038361" ENDARROW="Default" ENDINCLINATION="-474;0;" ID="Arrow_ID_715907117" STARTARROW="None" STARTINCLINATION="52;5;"/>
|
|
</node>
|
|
<node CREATED="1563112603781" ID="ID_774804464" MODIFIED="1563112609310" TEXT="brauche aber auch Abstände">
|
|
<node CREATED="1563112611511" ID="ID_1116374684" MODIFIED="1563112636155" TEXT="man kann sich Margin/Padding besorgen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566518952575" ID="ID_183446100" MODIFIED="1582931361646" TEXT="muß die sinngemäß mit den vom TrackBody verwalteten Spannen verrechnen">
|
|
<arrowlink COLOR="#779be7" DESTINATION="ID_35592741" ENDARROW="Default" ENDINCLINATION="109;-329;" ID="Arrow_ID_66200016" STARTARROW="None" STARTINCLINATION="539;20;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563636831797" ID="ID_506277754" MODIFIED="1679077855045" TEXT="Rahmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1563636836517" FOLDED="true" ID="ID_391875364" MODIFIED="1564932610681" TEXT="Problem: Rahmen werden solid gezeichnet">
|
|
<arrowlink COLOR="#2e96d1" DESTINATION="ID_543934966" ENDARROW="Default" ENDINCLINATION="-135;0;" ID="Arrow_ID_1613504887" STARTARROW="None" STARTINCLINATION="44;-40;"/>
|
|
<linktarget COLOR="#4daab7" DESTINATION="ID_391875364" ENDARROW="Default" ENDINCLINATION="-88;45;" ID="Arrow_ID_1840813206" SOURCE="ID_362681600" STARTARROW="None" STARTINCLINATION="-335;-6;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1564495382717" FOLDED="true" HGAP="86" ID="ID_543934966" MODIFIED="1678407388305" TEXT="weiteres Problem: CSS-Effekte" VSHIFT="-9">
|
|
<linktarget COLOR="#2e96d1" DESTINATION="ID_543934966" ENDARROW="Default" ENDINCLINATION="-135;0;" ID="Arrow_ID_1613504887" SOURCE="ID_391875364" STARTARROW="None" STARTINCLINATION="44;-40;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1564495427327" ID="ID_406875347" MODIFIED="1564495439363" TEXT="die werden von den Designern zunehmend genutzt"/>
|
|
<node CREATED="1564495440430" ID="ID_1276162602" MODIFIED="1564495463606" TEXT="..oft mit dem Ziel, einen "3D-Look" zu vermeiden. Einfach nur noch krank"/>
|
|
<node CREATED="1564495472129" ID="ID_515864254" MODIFIED="1564495483412" TEXT="speziell box-shadow wird extrem viel verwendet"/>
|
|
<node CREATED="1564495485155" ID="ID_1813223564" MODIFIED="1564495495979" TEXT="Problem: der wird auf die Umgebung gezeichnet">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1564495497382" ID="ID_1356685969" MODIFIED="1564495509046" TEXT="paßt das mit meinem Zeichen-Konzept zusammen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1564495532593" ID="ID_352639036" MODIFIED="1564495537476" TEXT="gtkrenderbackround.c">
|
|
<node CREATED="1564495545861" ID="ID_627648239" MODIFIED="1564495549842" TEXT="gtk_css_style_render_background()">
|
|
<node CREATED="1564495616991" ID="ID_1929404948" MODIFIED="1564495626248" TEXT="zeichnet zuerst die outset-shadows"/>
|
|
<node CREATED="1564495628068" ID="ID_1140731188" MODIFIED="1564495634422" TEXT="dann den HIntergrund"/>
|
|
<node CREATED="1564495635347" ID="ID_155287620" MODIFIED="1564495641294" TEXT="dann die inset-shadows"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564495699205" ID="ID_266196506" MODIFIED="1564495717300" TEXT="Problem: das ist im Widerspruch zu dem abschnittsweisen zeichnen"/>
|
|
</node>
|
|
<node CREATED="1564932181697" ID="ID_266632545" MODIFIED="1564932191323" TEXT="läßt sich aber integrieren">
|
|
<node CREATED="1564932194424" ID="ID_1904122891" MODIFIED="1576282358046" TEXT="die Nützlichkeit des box-shadow ist ohnehin beschränkt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
falls inset, wird er nur <i>innerhalb </i>der border und über den Hintergrund gezeichnet
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
nicht über die border selber
|
|
</li>
|
|
<li>
|
|
nicht über den Content
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#9a85e1" DESTINATION="ID_321264842" ENDARROW="Default" ENDINCLINATION="-618;56;" ID="Arrow_ID_852851809" STARTARROW="None" STARTINCLINATION="-805;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1564932357258" ID="ID_273302886" MODIFIED="1564932385170" TEXT="aber immerhin wird er automatisch mitgezeichnet bei render_background()">
|
|
<node CREATED="1564932387045" ID="ID_188179971" MODIFIED="1564932396736" TEXT="und zwar auch außerhalb der definierten Box"/>
|
|
<node CREATED="1564932397556" ID="ID_380412267" MODIFIED="1576282358045" TEXT="und oberhalb von allem was schon gezeichnet wurde">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der GTK-Zeichencode achtet sogar explizit darauf, einen CSS-Effekt mit dem korrekten Mischmodus über den bereits auf den CairoCanvas gezeichneten Content zu legen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564932484393" ID="ID_1092949064" MODIFIED="1566519094002">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar für bestimmte Elemente (<b>Konvention</b>)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#02ab84" DESTINATION="ID_840104433" ENDARROW="Default" ENDINCLINATION="1035;-107;" ID="Arrow_ID_77023730" STARTARROW="Default" STARTINCLINATION="106;39;"/>
|
|
<linktarget COLOR="#2b75cc" DESTINATION="ID_1092949064" ENDARROW="Default" ENDINCLINATION="286;83;" ID="Arrow_ID_1686979270" SOURCE="ID_57629359" STARTARROW="None" STARTINCLINATION="572;0;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1566401020977" ID="ID_1373829097" MODIFIED="1566401070383" TEXT="siehe Definition im TiddlyWiki ("#GuiTimelineDraw")"/>
|
|
<node CREATED="1566401126813" ID="ID_651523098" MODIFIED="1566401134027" TEXT="Ruler">
|
|
<node CREATED="1566401134943" ID="ID_432602619" MODIFIED="1566401141050" TEXT="box-shadow ist nutzbar">
|
|
<node CREATED="1566401142268" ID="ID_1379290604" MODIFIED="1576282358045" TEXT="outset nur im Rahmen des Margin">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil über alles andere darübergezeichnet wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1566401161862" ID="ID_1835446713" MODIFIED="1566401166385" TEXT="inset voll nutzbar"/>
|
|
</node>
|
|
<node CREATED="1566401169187" ID="ID_268392618" MODIFIED="1566401182383" TEXT="hier kommt der Background zum Tragen"/>
|
|
</node>
|
|
<node CREATED="1566401187384" ID="ID_270883580" MODIFIED="1566401194797" TEXT="Track-Content">
|
|
<node CREATED="1566401195834" ID="ID_929024694" MODIFIED="1566401218274" TEXT="hier wird der generelle "fork"-Style angewendet"/>
|
|
<node CREATED="1566401219318" ID="ID_1029868633" MODIFIED="1566401230601" TEXT="box-shadow nur inset nutzbar"/>
|
|
</node>
|
|
<node CREATED="1566401236332" ID="ID_457183290" MODIFIED="1566401252542" TEXT="die Borders/Slopes werden nur per Gradient/Shading realisiert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563637202035" ID="ID_681324395" MODIFIED="1563637205854" TEXT="Auswege?">
|
|
<node CREATED="1563637219445" FOLDED="true" ID="ID_1413699114" MODIFIED="1576282358044" TEXT="Reverse-Engineering">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den Zeichenvorgang für ein normales Frame-Widget analysieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563736122461" ID="ID_1095800644" MODIFIED="1563736127792" TEXT="Gtk::Frame">
|
|
<node CREATED="1563736130164" ID="ID_276564599" MODIFIED="1563736139623" TEXT="erbt von Bin, dieses von Container..."/>
|
|
<node CREATED="1563736141579" ID="ID_1238316490" MODIFIED="1563736165824" TEXT="gtk_frame_draw() (gtkframe.c, 716)">
|
|
<node CREATED="1563736411493" ID="ID_959872815" MODIFIED="1563736413201" TEXT="gtk_frame_draw">
|
|
<node CREATED="1563736675878" ID="ID_1380030936" MODIFIED="1563736675878" TEXT="gtk_css_gadget_draw">
|
|
<node CREATED="1563736680910" ID="ID_1193299161" MODIFIED="1563736686803" TEXT="bekommt einen Cairo-Context"/>
|
|
<node CREATED="1563736687680" ID="ID_476120936" MODIFIED="1563736720837" TEXT="setzt zusätzlich eine genau passende size-Allocation vorraus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Kommentar sagt: it is your responsibility that these two coordinates match
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563736622722" HGAP="54" ID="ID_1395291863" MODIFIED="1564493283947" TEXT="gtk_css_style_render_border" VSHIFT="20">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1563737125953" ID="ID_1641342904" MODIFIED="1563737128853" TEXT="Taddaa!"/>
|
|
<node CREATED="1563737130259" ID="ID_64703621" MODIFIED="1563737146677" TEXT="die wird auch von styleContxt->render_border() aufgerufen"/>
|
|
<node CREATED="1563737169230" ID="ID_1548155605" MODIFIED="1563737173151" TEXT="Fallunterscheidung">
|
|
<node CREATED="1563737174965" ID="ID_1060512211" MODIFIED="1563737176769" TEXT="if (gtk_border_image_init (&border_image, style))">
|
|
<node CREATED="1564493480688" ID="ID_55682569" MODIFIED="1564493486989" TEXT="gtk_border_image_render">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563737180869" ID="ID_1595726725" MODIFIED="1563737186103" TEXT="sonst: solid zeichnen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563831385422" ID="ID_1366222565" MODIFIED="1563831397212" TEXT="in vivo beobachten">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1563831400868" ID="ID_99440407" MODIFIED="1563831412589" TEXT="was liefert das Theme?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1563831414186" ID="ID_1993035073" MODIFIED="1563831443895" TEXT="wo?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
/home/hiv/.local/share/themes/PanRosewoodHIV/gtk-3.0/gtk-contained.css
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563831422209" ID="ID_79374511" MODIFIED="1563831422209" TEXT="/home/hiv/.local/share/themes/PanRosewoodHIV/gtk-3.0/gtk-contained.css"/>
|
|
<node CREATED="1563831443895" ID="ID_1181589291" MODIFIED="1563831674186" TEXT="frames: werden flach gezeichnet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
frame > border,
|
|
</p>
|
|
<p>
|
|
.frame {
|
|
</p>
|
|
<p>
|
|
  box-shadow: none;
|
|
</p>
|
|
<p>
|
|
  margin: 0;
|
|
</p>
|
|
<p>
|
|
  padding: 0;
|
|
</p>
|
|
<p>
|
|
  border-radius: 0;
|
|
</p>
|
|
<p>
|
|
  border: 1px solid @borders; }
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563831978878" ID="ID_1798339852" MODIFIED="1563832006629" TEXT="buttons: verwenden box-shadow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
  box-shadow: inset 0px 0px 0px 1px shade (@theme_bg_color, 1.15), 0px 1px 2px rgba(0, 0, 0, 0.1); }
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563832107140" ID="ID_132078838" MODIFIED="1563832115635" TEXT=""outset" wird überhaupt nicht verwendet"/>
|
|
<node CREATED="1563832501752" ID="ID_804764675" MODIFIED="1563832525842" TEXT="box-shadow == CSS3 special FX overlay rendering">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1563832552048" ID="ID_1098912429" MODIFIED="1563832581748" TEXT="kann man das via Gtk::StyleContext überhaupt bekommen?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1563832588867" ID="ID_1957263564" MODIFIED="1563832601172" TEXT="ggfs. box-shadow: inset"/>
|
|
<node CREATED="1563832602381" ID="ID_1407285230" MODIFIED="1563832622838" TEXT="könnte auf den background wirken">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563832147919" ID="ID_219847738" MODIFIED="1563832160686" TEXT="brauche zunächst Referenzpunkt">
|
|
<node CREATED="1563832161893" ID="ID_1492294459" MODIFIED="1563832182991" TEXT="etwas, was regulär wie gewünscht gezeichnet wird"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564495803795" FOLDED="true" ID="ID_936454608" MODIFIED="1564932165356">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
herausfinden, <i>warum </i>er solid gezeichnet wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1564496514126" ID="ID_1346070750" MODIFIED="1564496520743" TEXT="suche nach "outline"">
|
|
<node CREATED="1564496521875" ID="ID_1983337712" MODIFIED="1564496542962" TEXT="Treffer in den GTK-Tests">
|
|
<node CREATED="1564496527957" ID="ID_1175363915" MODIFIED="1564496537133" TEXT="da werden CSS-Files geparst">
|
|
<node CREATED="1564496635695" ID="ID_118189793" MODIFIED="1564496644342" TEXT="outline-style: outset">
|
|
<node CREATED="1564497490473" ID="ID_758595365" MODIFIED="1564497508338" TEXT="outline ist ein zusätzlicher Rahmen, der keinen Platz einnimmt"/>
|
|
<node CREATED="1564497509220" ID="ID_44303071" MODIFIED="1564497575901" TEXT="typischerweise wird er verwendet für Zugriff via TAB-Key auf Links oder Form-Controls"/>
|
|
<node CREATED="1564497583437" ID="ID_351582783" MODIFIED="1564497684260" TEXT="viele Designer setzten die Outline irrtümlicherwesise auf 0">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
irrtümlich, denn
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
per default ist outline:none
|
|
</li>
|
|
<li>
|
|
outline wird nur gesetzt, wenn ein Element fokus bekommt
|
|
</li>
|
|
<li>
|
|
Outline liegt um die Border, nimmt aber selber <i>keinen</i> Platz ein (sondern ist ein overlay)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1564497610951" ID="ID_1607000015" MODIFIED="1564497691853" TEXT="flat-style Wahn">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564496645266" ID="ID_1195524517" MODIFIED="1564496648014" TEXT="aber">
|
|
<node CREATED="1564496671939" ID="ID_447845332" MODIFIED="1564496677574">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
g {
|
|
</p>
|
|
<p>
|
|
  border-bottom-style: outset;
|
|
</p>
|
|
<p>
|
|
  border-left-style: outset;
|
|
</p>
|
|
<p>
|
|
  border-right-style: outset;
|
|
</p>
|
|
<p>
|
|
  border-top-style: outset;
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564498530277" ID="ID_58219828" MODIFIED="1564498535936" TEXT="gtkrenderborder.c">
|
|
<node CREATED="1564498554598" ID="ID_956944933" MODIFIED="1564498559099" TEXT="render_border()"/>
|
|
<node CREATED="1564498579543" ID="ID_1385373992" MODIFIED="1564498592608" TEXT="hart getcodete Logik, ziemlich brachial"/>
|
|
<node CREATED="1564498560001" ID="ID_621726316" MODIFIED="1564498730015" TEXT="macht bei outset/inset jewils 2 Seiten um den Faktor 1.8 heller">
|
|
<arrowlink COLOR="#2ee773" DESTINATION="ID_1183787016" ENDARROW="Default" ENDINCLINATION="120;7;" ID="Arrow_ID_1051090636" STARTARROW="None" STARTINCLINATION="-30;75;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564497891485" ID="ID_1183787016" MODIFIED="1564932176101" TEXT="Ha! man muß irgendwo eine Farbe angeben">
|
|
<linktarget COLOR="#2ee773" DESTINATION="ID_1183787016" ENDARROW="Default" ENDINCLINATION="120;7;" ID="Arrow_ID_1051090636" SOURCE="ID_621726316" STARTARROW="None" STARTINCLINATION="-30;75;"/>
|
|
<linktarget COLOR="#2ee773" DESTINATION="ID_1183787016" ENDARROW="Default" ENDINCLINATION="278;16;" ID="Arrow_ID_1462879108" SOURCE="ID_1801143265" STARTARROW="None" STARTINCLINATION="344;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1564497939401" ID="ID_1944950668" MODIFIED="1564497957953" TEXT="...dann wird das outset/inset durchaus sichtbar"/>
|
|
</node>
|
|
<node CREATED="1563637262355" ID="ID_1832765583" MODIFIED="1563637269566" TEXT="mehrere Rahmen zeichnen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1563637271393" ID="ID_1653388358" MODIFIED="1563637278534" TEXT="bringt nix und ist zweifelhaft"/>
|
|
<node CREATED="1563637280568" ID="ID_1565457661" MODIFIED="1563637293442" TEXT="denn die sind trotzedem solid"/>
|
|
</node>
|
|
<node CREATED="1563637301028" ID="ID_1115957778" MODIFIED="1564610481386" TEXT="dann doch komplett selber zeichnen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1563637334256" ID="ID_366744106" MODIFIED="1576282358044" TEXT="CSS kann dann aber den Slope-Stil nicht mehr steuern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil er dann mehr oder weniger hartverdrahtet ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563734827469" ID="ID_1948656771" MODIFIED="1563734843479" TEXT="man könnte allerdings das Verhalten von GTK im eigenen Code nachahmen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561742203636" FOLDED="true" ID="ID_1959492243" MODIFIED="1679077867724" TEXT="Rampen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563112435603" ID="ID_957636184" MODIFIED="1563112566794" TEXT="Idee-1">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1563112441737" ID="ID_900587446" MODIFIED="1563112449250" TEXT="Rahmen zeichnen und Richtung umkehren"/>
|
|
<node CREATED="1563112451973" ID="ID_1878103890" MODIFIED="1563112459772" TEXT="Rahmen muß dazu inset/outset sein"/>
|
|
</node>
|
|
<node CREATED="1563112464141" ID="ID_497314735" MODIFIED="1563112572591" TEXT="Idee-2">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1563112482359" ID="ID_100127081" MODIFIED="1563112487856" TEXT="Rahmen mit Gap zeichnen"/>
|
|
<node CREATED="1563112489001" ID="ID_1802227725" MODIFIED="1563112511333" TEXT="...und dadurch die Oberseite verdecken"/>
|
|
<node COLOR="#435e98" CREATED="1563636755968" ID="ID_145032855" MODIFIED="1674159053972" TEXT="funktioniert... aber zwei Probleme">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1563636787971" ID="ID_362681600" MODIFIED="1564932601661" TEXT="Rahmen wird solid gezeichnet, nicht outset">
|
|
<arrowlink COLOR="#4daab7" DESTINATION="ID_391875364" ENDARROW="Default" ENDINCLINATION="-88;45;" ID="Arrow_ID_1840813206" STARTARROW="None" STARTINCLINATION="-335;-6;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1564498321121" ID="ID_277450056" MODIFIED="1564498326722" TEXT="stimmt gar nicht">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1564498328208" ID="ID_1801143265" MODIFIED="1564932176101" TEXT="man muß nur eine Farbe setzen">
|
|
<arrowlink COLOR="#2ee773" DESTINATION="ID_1183787016" ENDARROW="Default" ENDINCLINATION="278;16;" ID="Arrow_ID_1462879108" STARTARROW="None" STARTINCLINATION="344;0;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1563636771101" ID="ID_273130535" MODIFIED="1566518058000" TEXT="kann die Rahmenstärke nicht manipulieren">
|
|
<arrowlink COLOR="#cb487a" DESTINATION="ID_155787836" ENDARROW="Default" ENDINCLINATION="86;-182;" ID="Arrow_ID_1682426231" STARTARROW="None" STARTINCLINATION="187;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566517976980" ID="ID_1144490151" MODIFIED="1566518051558" TEXT="Lösung: CSS-Klassen verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1566517991290" ID="ID_139839934" MODIFIED="1566518025089" TEXT="eine fixe Anzahl">
|
|
<node CREATED="1566518027596" ID="ID_1002340632" MODIFIED="1566518034807" TEXT="eins zwei drei vier viele"/>
|
|
</node>
|
|
<node CREATED="1566518038233" ID="ID_160319279" MODIFIED="1566518048501" TEXT="auf der letzten Klasse stehenbleiben"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563112523511" ID="ID_1881724639" MODIFIED="1563112555503" TEXT="Idee-3">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1563112528094" ID="ID_1162030446" MODIFIED="1563112536377" TEXT="zu zeichnende Rahmen in einem Stack sammeln"/>
|
|
<node CREATED="1563112537602" ID="ID_1896039320" MODIFIED="1563112551944" TEXT="...und dann am Ende auf einmal alle zeichnen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564610290631" HGAP="17" ID="ID_1710961419" MODIFIED="1679077861213" TEXT="Probleme bei der Umsetzung" VSHIFT="12">
|
|
<icon BUILTIN="go"/>
|
|
<node COLOR="#338800" CREATED="1564610350719" FOLDED="true" ID="ID_1592146108" MODIFIED="1564932136148" TEXT="brauche Lösung zum Steuern der Rahmenstärke">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1564610376639" ID="ID_1472226314" MODIFIED="1564610394741" TEXT="...weil sich diese dynamisch aus der Tiefe der Verschachtelung ergibt"/>
|
|
<node CREATED="1564610401372" ID="ID_155787836" MODIFIED="1564840644957" TEXT="geht nicht unmittelbar">
|
|
<linktarget COLOR="#cb487a" DESTINATION="ID_155787836" ENDARROW="Default" ENDINCLINATION="86;-182;" ID="Arrow_ID_1682426231" SOURCE="ID_273130535" STARTARROW="None" STARTINCLINATION="187;-5;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1564499265111" ID="ID_1439210086" MODIFIED="1564499270258" TEXT="ist wohl nicht vorgesehen">
|
|
<node CREATED="1564499271812" ID="ID_287796510" MODIFIED="1564499291455" TEXT="getBorder() macht eine Kopie des Rect"/>
|
|
<node CREATED="1564500049627" ID="ID_422878118" MODIFIED="1564500092094" TEXT="auch die unterliegenden CssValues sind immutable">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und mehrfach gekapselt.
|
|
</p>
|
|
<p>
|
|
Schaut alles so aus, als sollte man da nicht rumpfuschen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1564499293683" ID="ID_1091998085" MODIFIED="1564499307564" TEXT="vmtl. sollte man einen CssProvider hinzufügen">
|
|
<node CREATED="1564499312280" ID="ID_596172178" MODIFIED="1564499349741" TEXT="StyleContext::add_provider"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564500098305" ID="ID_1609602378" MODIFIED="1564500104383" TEXT="sehe 2 Lösungen">
|
|
<node CREATED="1564500107072" ID="ID_1324066228" MODIFIED="1564500523208" TEXT="CssProvider on-the-fly hinzufügen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1564500128300" ID="ID_1227815048" MODIFIED="1564500135869" TEXT="mit berechneter border-size"/>
|
|
</node>
|
|
<node CREATED="1564500138401" ID="ID_1779259370" MODIFIED="1564500527159" TEXT="spezielle Klassen definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1564500156340" ID="ID_813184011" MODIFIED="1564500184980" TEXT="track-slope-deep2"/>
|
|
<node CREATED="1564500156340" ID="ID_901585189" MODIFIED="1564500203009" TEXT="track-slope-deep3"/>
|
|
<node CREATED="1564500156340" ID="ID_1965249671" MODIFIED="1564500208577" TEXT="track-slope-deep4"/>
|
|
<node CREATED="1564500220303" ID="ID_1305054039" MODIFIED="1564500229334" TEXT="track-slope-verydeep"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1564500530497" ID="ID_552810958" MODIFIED="1564929446246" TEXT="die 2.Lösung erscheint mir angemessener">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1564500542648" ID="ID_1923715160" MODIFIED="1564500554477" TEXT="weil damit der Designer freie Hand hat"/>
|
|
<node CREATED="1564500576627" ID="ID_979278974" MODIFIED="1564500613622" TEXT="weil das Hinzufügen von Klassen eine vorgesehene Operation ist"/>
|
|
<node CREATED="1564500614693" ID="ID_178343581" MODIFIED="1564500683747" TEXT="Hinzufügen eines CssProvider ist eine aufwendige Sache">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da wird ggfs eine neue CSS-Kaskade erstellt, oder die bestehende Kaskade erweitert.
|
|
</p>
|
|
<p>
|
|
Hierfür werden Einträge in Arrays verschoben.
|
|
</p>
|
|
<p>
|
|
Schließlich wird über die ganze Kaskade iteriert, und die Werte werden aufgesammelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564610513626" FOLDED="true" ID="ID_387755678" MODIFIED="1564932134058" TEXT="Verhalten des Gtk::StyleContext">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1564610523846" ID="ID_1167026908" MODIFIED="1564929420074" TEXT="verhält sich komisch, und anders als dokumentiert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564610549788" ID="ID_1115307821" MODIFIED="1564929404069" TEXT="Fokussierte Untersuchung (Research)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1564838802098" ID="ID_529304410" MODIFIED="1564838822103" TEXT="gtk-canvas-eperiment kopiert und zusammengedampft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1564838825559" ID="ID_325876038" MODIFIED="1564838846585" TEXT="greife aber hier einen StyleContext von einem real existierenden Widget ab!">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1564838864770" ID="ID_1455456623" MODIFIED="1564838879910" TEXT="Erkenntnis: es war ein Cascading-Problem">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1564838892422" ID="ID_1063402707" MODIFIED="1564838910760" TEXT="Expliziter Selektor wiegt mehr als generischer Selektor"/>
|
|
<node CREATED="1564838932673" ID="ID_1845439133" MODIFIED="1564839843544" TEXT="Einsicht nebeinbei: sehe schon, warum die Designer immer CSS vergewaltigen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Idee mit dem Cascading funktioniert nämlich nur, wenn man die Oberfläche <i>explizit</i> und <i>bewußt</i>
|
|
</p>
|
|
<p>
|
|
nach einem Struktur-Schema aufbaut. Dies erfordert eine gewisse zusätzliche geistige Spannkraft.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Typisches Beispiel für mich ist eine Barocke Fassade (mit denen ich mich
|
|
</p>
|
|
<p>
|
|
in einem anderen Projekt grade beschäftige): Auf den ersten Blick sehen die überbordend
|
|
</p>
|
|
<p>
|
|
und überwuchert aus, aber wenn man genau hinschaut, ist jedes kleinste Detail
|
|
</p>
|
|
<p>
|
|
aus einem System abgeleitet -- genau wie es dem damaligen Zeitgeist der Aufklärung entspricht.
|
|
</p>
|
|
<p>
|
|
Ein barocker Baumeister würde niemals an einem einzelnen Fenster herum-tweaken, weil es sich irgendwie besser anfühlt.
|
|
</p>
|
|
<p>
|
|
Wenn etwas nicht ausgewogen rauskommt, dann wird eben das gesamte System nachjustiert.
|
|
</p>
|
|
<p>
|
|
Und genau das ist es, was die geistige Spannweite erfordert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Der Pragmatiger sagt, dann mach halt das verfickte Klofenster hinten links breiter und gut is.
|
|
</p>
|
|
<p>
|
|
Das würde zwar ein lokales Problem praktisch lösen, wäre aber unorganisch,
|
|
</p>
|
|
<p>
|
|
weil es nicht mehr aus dem Fluß des Systems im Ganzen folgt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und mit CSS-Selektoren und dem Cascading verhält es sich genau entsprechend.
|
|
</p>
|
|
<p>
|
|
Wenn man einmal anfängt, an irgend einem Detail herumzufummeln, weil es sich irgendewie so anfühlt,
|
|
</p>
|
|
<p>
|
|
oder der Kunde es so will, dann ist man ganz schnell an dem Punk, wo Selektoren nicht mehr greifen,
|
|
</p>
|
|
<p>
|
|
und nur noch !important hilft. Und an der Stelle kommt dann der Praktiker, und pflastert eben
|
|
</p>
|
|
<p>
|
|
jedes Element mit einem eigenen Selektor zu, so daß man ungestraft überall herumfummeln kan.
|
|
</p>
|
|
<p>
|
|
Und der Oberpragmatiker generiert den ganzen Müllhaufen dann per SASS order SCSS
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564841527588" ID="ID_1377435126" MODIFIED="1564924272221" TEXT="Untersuchung context_save() auf einem kopierten / frei konstruierten StyleContext">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1564868166273" ID="ID_945377761" MODIFIED="1564868267923" TEXT="kann das problematische Verhalten reproduzieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wenn man einen neuen Gtk::StyleContext erzeugt,
|
|
</p>
|
|
<p>
|
|
und (wie in der Doku beschrieben) den path und den screen manuell setzt,
|
|
</p>
|
|
<p>
|
|
dann führt ein context_save() dazu, daß plötzlich die CSS-Werte auf Defaults zurückspringen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1564868280687" ID="ID_593595518" MODIFIED="1564871156101" TEXT="es hilft nichts, wenn man den Screen (nochmal) setzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und ja, den Screen sollte man generell setzten.<br />Steht auch so in der Doku.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings hat es bisher auch ohne das bei mir funktioniert.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1564868338325" ID="ID_1826179725" MODIFIED="1564871159899" TEXT="es hilft nichts, wenn man den Pfad erneut setzt">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1564868348236" ID="ID_1509661918" MODIFIED="1564871163619" TEXT="es hilft nichts, wenn man den Context invalidiert">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1564871053125" HGAP="30" ID="ID_1611854805" LINK="https://stackoverflow.com/q/57342478/444796" MODIFIED="1564871092888" TEXT="habe auf Stackoverflow gefragt" VSHIFT="16">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564841584180" ID="ID_1444331441" MODIFIED="1564928490168" TEXT="Untersuchung wie box-shadow gerendert wird">
|
|
<linktarget COLOR="#5590d5" DESTINATION="ID_1444331441" ENDARROW="Default" ENDINCLINATION="-449;0;" ID="Arrow_ID_1759102712" SOURCE="ID_840104433" STARTARROW="None" STARTINCLINATION="98;-3;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1564926637294" ID="ID_1488276378" MODIFIED="1564926753815" TEXT="box-shadow Definitionen / Varianten">
|
|
<arrowlink COLOR="#405ecf" DESTINATION="ID_240623877" ENDARROW="Default" ENDINCLINATION="-838;0;" ID="Arrow_ID_1124667032" STARTARROW="None" STARTINCLINATION="-522;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564927139265" ID="ID_1929004588" MODIFIED="1564927154012" TEXT="Hintergrund zusätzlich auf den Canvas rendern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564927155326" ID="ID_678866276" MODIFIED="1564928463921" TEXT="box-shadow im Test-CSS definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564840511187" ID="ID_1756129968" MODIFIED="1564840563824" TEXT="Fazit-1">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1564840516803" ID="ID_1696178790" MODIFIED="1564840530729" TEXT="Steuerung der Rahmenbreite über klassen funktioniert durchaus"/>
|
|
<node CREATED="1564840531905" ID="ID_1757725296" MODIFIED="1564840552442" TEXT="man muß nur die Klassen sinnvoll strukturieren, so daß der Selektor greift"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1564840587025" ID="ID_1659624942" MODIFIED="1564840662973" TEXT="style->context_save() funktioneriert dennoch nicht">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1564840675682" ID="ID_1503353101" MODIFIED="1564840686319" TEXT="border-width == 0"/>
|
|
<node CREATED="1564840688620" ID="ID_1175662942" MODIFIED="1564840695486" TEXT="Rahmen wird nicht mehr gezeichnet"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564840511187" ID="ID_1777041743" MODIFIED="1564928522581" TEXT="Fazit-2">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1564928528971" ID="ID_1722803144" MODIFIED="1564928579769" TEXT="CSS3-Effekte werden angewendet bei render_background"/>
|
|
<node CREATED="1564928584153" ID="ID_495635427" MODIFIED="1564928597882" TEXT="und zwar alle Effekte. Und nicht in render_frame">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1564928904423" ID="ID_1736699496" MODIFIED="1564929052148" TEXT="das ist mäßig prickelnd....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Gut ist es insofern, daß man mit einem render_background bereits alles bekommt
|
|
</li>
|
|
<li>
|
|
allerdings muß der Rahmen dann ganz genau passend darüber gezeichnet werden
|
|
</li>
|
|
<li>
|
|
man kann damit weder den Rahmen schattieren, noch den enthaltenen Content
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
allerdings verhält sich das normale Zeichnen ganz genauso; das sind allgemeine Einschränkungen (von CSS? GTK?)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564928617821" ID="ID_1534709178" MODIFIED="1564928886905" TEXT="des Genaueren">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1564928649329" ID="ID_1625957291" MODIFIED="1564928810213" TEXT="box-shadow (normal) wird außerhalb des angegebenen Rechtecks gezeichnet">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1564928674942" ID="ID_75369854" MODIFIED="1564928812685" TEXT="angegebenes Rechteck wird mit der Hintergrundfarbe gefüllt">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1564928700616" ID="ID_835151696" MODIFIED="1564928815890">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
box-shadow (inset) innerhalb des Rechteckss, <i>und innerhalb</i> der (gedachten) border
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564610302597" ID="ID_840104433" MODIFIED="1679071406814" TEXT="sollte so zeichnen, daß CSS3-Effekte wie box-shadow nutzbar sind">
|
|
<arrowlink COLOR="#5590d5" DESTINATION="ID_1444331441" ENDARROW="Default" ENDINCLINATION="-449;0;" ID="Arrow_ID_1759102712" STARTARROW="None" STARTINCLINATION="98;-3;"/>
|
|
<linktarget COLOR="#02ab84" DESTINATION="ID_840104433" ENDARROW="Default" ENDINCLINATION="1035;-107;" ID="Arrow_ID_77023730" SOURCE="ID_1092949064" STARTARROW="Default" STARTINCLINATION="106;39;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1564932712545" ID="ID_756463948" MODIFIED="1679078002475" TEXT="korrekt zeichnen gemäß Konzept">
|
|
<linktarget COLOR="#556dd4" DESTINATION="ID_756463948" ENDARROW="Default" ENDINCLINATION="-507;0;" ID="Arrow_ID_1335568264" SOURCE="ID_909641864" STARTARROW="None" STARTINCLINATION="582;34;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1564932652482" ID="ID_1330271110" MODIFIED="1566525299678" TEXT="alle render_background mit vollständigem Rechteck versorgen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1565268879772" ID="ID_261041772" MODIFIED="1566956248932" TEXT="brauche berechnete Höhe(n)">
|
|
<arrowlink COLOR="#a37084" DESTINATION="ID_31825370" ENDARROW="Default" ENDINCLINATION="145;324;" ID="Arrow_ID_1599930326" STARTARROW="Default" STARTINCLINATION="-943;-105;"/>
|
|
<linktarget COLOR="#555580" DESTINATION="ID_261041772" ENDARROW="Default" ENDINCLINATION="-490;-44;" ID="Arrow_ID_462162449" SOURCE="ID_1608124774" STARTARROW="None" STARTINCLINATION="332;39;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1566401334135" ID="ID_688081615" MODIFIED="1576282358043" TEXT="doch nicht so schlimm">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil die CSS-box-shadow-Effekte zum Zeichnen komplexerer Strukturen nur bedingt nützlich sind.
|
|
</p>
|
|
<p>
|
|
Daher verzichte ich global (für die Slopes) darauf, wende sie aber <b>lokal</b>  an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566401295806" ID="ID_1604746709" MODIFIED="1566401306583" TEXT="es genügt die lokale Höhe">
|
|
<node CREATED="1566401307715" ID="ID_927850679" MODIFIED="1566401323333" TEXT="für den Track-Content"/>
|
|
<node CREATED="1566401324073" ID="ID_1089116245" MODIFIED="1566401328764" TEXT="für die Track-Ruler"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564932680606" ID="ID_695299880" MODIFIED="1567684005651" TEXT="Rahmen paßgenau einsetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567683988131" ID="ID_290005683" MODIFIED="1679071358308" TEXT="Margin und Padding berücksichtigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564955071015" ID="ID_773991524" MODIFIED="1679071382855" TEXT="(vorerst) nicht zu viel Aufwand hier investieren">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1564955099331" ID="ID_1171928927" MODIFIED="1679071353747" TEXT="Wechselspiel mit der Größen-Steuerung beachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564955112027" ID="ID_1010819780" MODIFIED="1679071355691" TEXT="Integration in Zeichenvorgang insgesamt beachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566518983355" FOLDED="true" ID="ID_35592741" MODIFIED="1679077804599" TEXT="Zusammenspiel zw. Höhe und CSS">
|
|
<linktarget COLOR="#779be7" DESTINATION="ID_35592741" ENDARROW="Default" ENDINCLINATION="109;-329;" ID="Arrow_ID_66200016" SOURCE="ID_183446100" STARTARROW="None" STARTINCLINATION="539;20;"/>
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_35592741" ENDARROW="Default" ENDINCLINATION="-366;30;" ID="Arrow_ID_949004312" SOURCE="ID_430878592" STARTARROW="None" STARTINCLINATION="-2163;252;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566518998190" ID="ID_284079883" MODIFIED="1566519017050" TEXT="Stylesheet bestimmt zusätzlichen Margin + Padding"/>
|
|
<node CREATED="1566519017878" ID="ID_30554429" MODIFIED="1566519029065" TEXT="diese müssen mit den Werten im TrackBody verrechnet werden">
|
|
<node COLOR="#338800" CREATED="1566522092555" FOLDED="true" ID="ID_293262823" MODIFIED="1566524848312" TEXT="Konsequenz: TrackBody muß auch den Style abfragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1566524821779" ID="ID_447136717" MODIFIED="1566524894982" TEXT="Lösung: via statische Funktion setzen"/>
|
|
<node CREATED="1566524850167" ID="ID_1119976379" MODIFIED="1576282358043" TEXT="kann dann aus body-canvas-widget.cpp passieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wo parktischerweise der Style-Advice in einer lokalen statischen Variablen liegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#006699" CREATED="1566524901403" FOLDED="true" ID="ID_950799052" MODIFIED="1566689174782" TEXT="prüfen ... stimmen die Werte">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1566685513662" ID="ID_1558375892" MODIFIED="1566685638105" TEXT="stimmt mit dem Diff aus DummySessionConnection überein">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1566685609906" ID="ID_474487470" MODIFIED="1566685621646" TEXT="unter der Annahme, daß jeder Track eine Content-Area bekommt"/>
|
|
<node CREATED="1566685622613" ID="ID_231064198" MODIFIED="1566685632616" TEXT="...und man noch nichts ein/ausklappen kann"/>
|
|
</node>
|
|
<node CREATED="1566685563043" ID="ID_1475468086" MODIFIED="1566685580320" TEXT="(Anmerkung: das Diff ist anders als das Beispiel im TiddlyWiki)"/>
|
|
<node COLOR="#338800" CREATED="1566689127609" ID="ID_479226069" MODIFIED="1566689147622" TEXT="Fehler in der Platzierung im Track-Head behoben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1566519037996" ID="ID_57629359" MODIFIED="1566519094001" TEXT="der zusätzliche Platz wird u.A. für den box-shadow benötigt">
|
|
<arrowlink COLOR="#2b75cc" DESTINATION="ID_1092949064" ENDARROW="Default" ENDINCLINATION="286;83;" ID="Arrow_ID_1686979270" STARTARROW="None" STARTINCLINATION="572;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566524922429" ID="ID_1618879281" MODIFIED="1679076538527" TEXT="für den Overlay-Pass genau analoge Berechnungen machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1679076542708" ID="ID_1589253410" MODIFIED="1679076553251" TEXT="alle Verb-Implementierungen durchgegangen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1679076554411" ID="ID_603964662" MODIFIED="1679076580595" TEXT="die Berechnung der »water level« line ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679076581607" ID="ID_808858680" MODIFIED="1679076628793" TEXT="derzeit wird hier keinerlei Overlay gezeichnet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber das wird sich ganz gewiß ändern ⟶ Stichwort Bereichsmarkierungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566956214907" ID="ID_1608124774" MODIFIED="1679073476147" TEXT="Größen-Berechnung">
|
|
<arrowlink COLOR="#564b7e" DESTINATION="ID_31825370" ENDARROW="Default" ENDINCLINATION="178;986;" ID="Arrow_ID_1663311989" STARTARROW="None" STARTINCLINATION="-248;-11;"/>
|
|
<arrowlink COLOR="#555580" DESTINATION="ID_261041772" ENDARROW="Default" ENDINCLINATION="-490;-44;" ID="Arrow_ID_462162449" STARTARROW="None" STARTINCLINATION="332;39;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1566956340002" FOLDED="true" ID="ID_1472575231" MODIFIED="1612643628908" TEXT="stimmen die Werte?">
|
|
<node CREATED="1566957803903" ID="ID_474929251" MODIFIED="1566957807116" TEXT="beobachtet">
|
|
<node CREATED="1566957808335" ID="ID_1187167099" MODIFIED="1566957813234" TEXT="Größenberechnung">
|
|
<node CREATED="1566957814421" ID="ID_600013220" MODIFIED="1566957837743" TEXT="total 860"/>
|
|
<node CREATED="1566957818757" ID="ID_425842490" MODIFIED="1566957843334" TEXT="ruler 120"/>
|
|
<node CREATED="1566957823804" ID="ID_491575402" MODIFIED="1566957855700" TEXT="delta 740"/>
|
|
</node>
|
|
<node CREATED="1566957857592" ID="ID_1807195803" MODIFIED="1566957863234" TEXT="Line nach Zeichnen">
|
|
<node CREATED="1566957864220" ID="ID_661651528" MODIFIED="1566957880817" TEXT="Body: 785">
|
|
<node CREATED="1566957882024" ID="ID_405967084" MODIFIED="1566957886807" TEXT="das ist ohne">
|
|
<node CREATED="1566957887930" ID="ID_1485316992" MODIFIED="1566957890959" TEXT="prelude"/>
|
|
<node CREATED="1566957891764" ID="ID_1384744243" MODIFIED="1566957895151" TEXT="zwei Ruler"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566958520767" ID="ID_350091895" MODIFIED="1576282358042" TEXT="diagnostisches Hilfs-drawing sollte Canvas-Größe als Bezug verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....für den Kreis
|
|
</p>
|
|
<p>
|
|
Und nicht die sichtbare Größe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1566957944718" ID="ID_629892163" MODIFIED="1567112025398" TEXT="Befund: der reale Zeichencode verbraucht zusätzlichen Platz">
|
|
<arrowlink COLOR="#ce2c4f" DESTINATION="ID_1587873335" ENDARROW="Default" ENDINCLINATION="-43;-72;" ID="Arrow_ID_1930337724" STARTARROW="None" STARTINCLINATION="40;43;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1566958287015" ID="ID_1587873335" MODIFIED="1567112048235" TEXT="Verdacht: es fehlen die Slope-Borders">
|
|
<linktarget COLOR="#ce2c4f" DESTINATION="ID_1587873335" ENDARROW="Default" ENDINCLINATION="-43;-72;" ID="Arrow_ID_1930337724" SOURCE="ID_629892163" STARTARROW="None" STARTINCLINATION="40;43;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1566958323689" ID="ID_604642616" MODIFIED="1566958330665" TEXT="TrackBody::calcHeight()"/>
|
|
<node CREATED="1566958579858" ID="ID_1841811096" MODIFIED="1566958601472" TEXT="diese hängen nämlich von der Schachtelungstiefe ab"/>
|
|
<node CREATED="1566958602561" ID="ID_106882219" MODIFIED="1566958625572" TEXT="Diskrepanz (45 Pixel) sieht plausibel aus"/>
|
|
<node CREATED="1566958775500" ID="ID_754575723" MODIFIED="1566958796157" TEXT="kommt aber auch nicht genau hin: (5+10+14)*2">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1567085396760" ID="ID_13253702" MODIFIED="1567085405481" TEXT="da stimmt eine Menge nicht">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
<node CREATED="1567085409503" ID="ID_1398765924" MODIFIED="1567085420521" TEXT="Differenzierung der Slopes"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1567085421366" ID="ID_1248743095" MODIFIED="1679072598371" TEXT="Slopes können auch zwischendurch zusammengefaßt werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1567085476174" ID="ID_745197382" MODIFIED="1567085485153" TEXT="Prelude und Coda fehlen ebenfalls"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1567085499035" ID="ID_1732362754" MODIFIED="1567112061359" TEXT="Beschluß: wir brauchen Einzel-Offsets für jeden Track">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1567085512476" ID="ID_1140063837" MODIFIED="1567085514964" TEXT="warum?"/>
|
|
<node CREATED="1567085515823" ID="ID_224781783" MODIFIED="1576282358042" TEXT="weil wir später Clips in den Track platzieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wir müssen...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Clips bündig in einen Track legen können
|
|
</li>
|
|
<li>
|
|
feststellen, ob ein Mausklick in einen bestimmten Track fällt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5595df" DESTINATION="ID_224781783" ENDARROW="Default" ENDINCLINATION="-573;42;" ID="Arrow_ID_1285897355" SOURCE="ID_675568693" STARTARROW="None" STARTINCLINATION="47;-43;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085534629" FOLDED="true" ID="ID_543607936" MODIFIED="1582926440570" TEXT="Einzel-Offsets pro Track">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1567085546180" ID="ID_675568693" MODIFIED="1567112084781" TEXT="später benötigt">
|
|
<arrowlink COLOR="#5595df" DESTINATION="ID_224781783" ENDARROW="Default" ENDINCLINATION="-573;42;" ID="Arrow_ID_1285897355" STARTARROW="None" STARTINCLINATION="47;-43;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085637546" ID="ID_682932701" MODIFIED="1567876361526" TEXT="sind im TrackBody zu speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1567870083327" ID="ID_400610372" MODIFIED="1567876360311" TEXT="dieses auch testen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#437b98" CREATED="1567876021748" ID="ID_1701413392" MODIFIED="1575131552362" TEXT="generischer Test-Code, um eine Nachricht via UI-Bus zu senden">
|
|
<arrowlink COLOR="#54bbd6" DESTINATION="ID_1341115014" ENDARROW="Default" ENDINCLINATION="-3095;0;" ID="Arrow_ID_547692411" STARTARROW="None" STARTINCLINATION="1167;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567876260420" ID="ID_1982958415" MODIFIED="1567876360311" TEXT="quick-n-dirty auf Tab-2 vom TestControl eingehängt ">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1567876314629" ID="ID_1352878688" MODIFIED="1582926440570" TEXT="Labels erscheinen, aber noch nicht an der korrekten Position">
|
|
<arrowlink COLOR="#d66a46" DESTINATION="ID_764240247" ENDARROW="Default" ENDINCLINATION="220;12;" ID="Arrow_ID_748970743" STARTARROW="None" STARTINCLINATION="64;28;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1567876291814" ID="ID_764240247" MODIFIED="1611439767693" TEXT="Thema: Offsets und Koordinaten auf dem Canvas">
|
|
<arrowlink COLOR="#5c5dc2" DESTINATION="ID_1434222749" ENDARROW="Default" ENDINCLINATION="-123;0;" ID="Arrow_ID_1862539064" STARTARROW="None" STARTINCLINATION="-876;0;"/>
|
|
<linktarget COLOR="#d66a46" DESTINATION="ID_764240247" ENDARROW="Default" ENDINCLINATION="220;12;" ID="Arrow_ID_748970743" SOURCE="ID_1352878688" STARTARROW="None" STARTINCLINATION="64;28;"/>
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085650636" ID="ID_394868232" MODIFIED="1567088360350" TEXT="brauche elaboriertere Storage für Dekorationen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1567876052888" ID="ID_1307787525" MODIFIED="1611439578331" TEXT="struct Decoration"/>
|
|
<node CREATED="1611439579513" ID="ID_893582298" MODIFIED="1611439590531" TEXT="im TrackBody definiert"/>
|
|
<node CREATED="1611439591431" ID="ID_703791949" MODIFIED="1611439599394" TEXT="im BodyCanvasWidget genutzt"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085662725" ID="ID_1234980335" MODIFIED="1567111947683" TEXT="beim Profile-building pass mit berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1567085681514" ID="ID_1776230312" MODIFIED="1567111949735" TEXT="line-Variable rekursiv mitführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085696585" ID="ID_104428046" MODIFIED="1567111943463" TEXT="Hilfsfunktion für Border-width">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567085713758" ID="ID_1794483413" MODIFIED="1567111945368" TEXT="Profil: vorausgehende border abfragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567112357515" FOLDED="true" ID="ID_921918885" MODIFIED="1576282358041" TEXT="man könnte noch einen Margin pro Track einarbeiten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
bisher verwende ich den nur im Prolog/Coda.
|
|
</li>
|
|
<li>
|
|
könnte sinnvoll sein, um direkt benachbarte Spuren leicht voneinander abzusetzen
|
|
</li>
|
|
<li>
|
|
muß allerdings wirklich <i>außerhalb</i> der (inset) slopes eingebaut werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1567684868730" ID="ID_1174805630" MODIFIED="1567747074910" TEXT="drei Modelle denkbar">
|
|
<node CREATED="1567684881240" ID="ID_1903584153" MODIFIED="1567747074910" TEXT="Modell-1">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1567685108272" ID="ID_152637722" MODIFIED="1567747074910" TEXT="um den track-content legen"/>
|
|
<node CREATED="1567685355920" ID="ID_1515797651" MODIFIED="1567747074910" STYLE="fork" TEXT="ganz einfach zu implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1567685388541" ID="ID_1586460223" MODIFIED="1567747074910">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
macht ggfs <i>ganz natürlich</i> einen box-shadow sichtbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1567685491918" ID="ID_1425797539" MODIFIED="1567747074910" TEXT="Ruler sind nicht eingeschlossen">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1567685534377" ID="ID_312263870" MODIFIED="1567747074910" TEXT="zwischen zwei einfachen Tracks stoßen margin-bottom und -top zusammen">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1567685577387" ID="ID_1532038020" MODIFIED="1567747074910" TEXT="margin-bottom liegt zwischen content und nested slope">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567685154244" ID="ID_1373037444" MODIFIED="1567747074910" TEXT="Modell-2">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1567685158411" ID="ID_1980021492" MODIFIED="1567747074910" TEXT="um die nested slopes legen"/>
|
|
<node CREATED="1567685637512" ID="ID_1953351205" MODIFIED="1567747074910" TEXT="vergleichsweise einfach zu implementieren"/>
|
|
<node CREATED="1567685682643" ID="ID_1706892095" MODIFIED="1567747074910" TEXT="ohne Kentnis des Codes erscheint dieses Modell nicht logisch">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1567685731534" ID="ID_1106992346" MODIFIED="1567747074910" TEXT="ganz am Ende stoßen zwei margin-bottom zusammen">
|
|
<node CREATED="1567685769667" ID="ID_862016071" MODIFIED="1567747074910" TEXT="es sei denn, man läßt den margin aus der Coda weg"/>
|
|
<node CREATED="1567685784107" ID="ID_1885651108" MODIFIED="1567747074910" TEXT="dann ist aber der margin im prelude irgendwie unlogisch"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567685252758" ID="ID_1605614339" MODIFIED="1567747074910" TEXT="Model-3">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1567685258966" ID="ID_1030733863" MODIFIED="1567747074910" TEXT="außen herum legen">
|
|
<node CREATED="1567685272913" ID="ID_1989912863" MODIFIED="1567747074910" TEXT="vor den ersten Ruler"/>
|
|
<node CREATED="1567685289794" ID="ID_739347906" MODIFIED="1567747074910" TEXT="hinter den closing slope"/>
|
|
</node>
|
|
<node CREATED="1567685824058" ID="ID_162145047" MODIFIED="1567747074910" TEXT="ehr aufwendig zu implementieren">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1567685842827" ID="ID_181167044" MODIFIED="1567747074910" TEXT="das TrackProfile muß helfen"/>
|
|
<node CREATED="1567685860069" ID="ID_795679603" MODIFIED="1567747074911" TEXT="zusätzliches Argument withTopMargin"/>
|
|
</node>
|
|
<node CREATED="1567687928863" ID="ID_1146414337" MODIFIED="1567747074911" TEXT="aus Nutzer-Sicht formal die am meisten logische Variante"/>
|
|
<node CREATED="1567687943708" ID="ID_1755668453" MODIFIED="1567747074911" TEXT="bringt aber nichts im Hinblick auf einen box-shadow">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1567687981599" ID="ID_1859353136" MODIFIED="1567747074911" TEXT="im Gegenzug müßte der Margin aus Prelude/Coda raus"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567688151519" ID="ID_1115827550" MODIFIED="1567747074911" TEXT="Beschluß: er wirkt auf den Content-Bereich">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1567688183723" ID="ID_571433100" MODIFIED="1567747074911" TEXT="damit wird ein box-shadow auch hier voll nutzbar"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611486837421" ID="ID_392294660" MODIFIED="1679072585362" TEXT="alle Clips im Track berücksichtigen">
|
|
<arrowlink COLOR="#786096" DESTINATION="ID_62818590" ENDARROW="Default" ENDINCLINATION="-1193;64;" ID="Arrow_ID_1779091384" STARTARROW="None" STARTINCLINATION="817;64;"/>
|
|
<linktarget COLOR="#dc91e4" DESTINATION="ID_392294660" ENDARROW="Default" ENDINCLINATION="648;52;" ID="Arrow_ID_1413556921" SOURCE="ID_137005272" STARTARROW="None" STARTINCLINATION="843;52;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679072150446" HGAP="99" ID="ID_1559178425" MODIFIED="1679072189402" VSHIFT="2">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sollte <i>theoretisch</i> funktionieren....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1679072212336" ID="ID_1532012219" MODIFIED="1679072219846" TEXT="generische Implementierung vorgesehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1679072221005" ID="ID_744686625" MODIFIED="1679072247211">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">ClipPresenter::determineRequiredVerticalExtension()</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1679072259248" ID="ID_1755439893" MODIFIED="1679072273200" TEXT="angelegt als »template method«">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679072354021" ID="ID_939752505" MODIFIED="1679072446356" TEXT="widget_->calcRequiredHeight()">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679072363668" ID="ID_698148454" MODIFIED="1679072579065" TEXT="widget_->getVerticalOffset()">
|
|
<arrowlink COLOR="#ff4275" DESTINATION="ID_1508246286" ENDARROW="Default" ENDINCLINATION="1281;-45;" ID="Arrow_ID_1210551190" STARTARROW="None" STARTINCLINATION="515;46;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1566956347881" ID="ID_1434222749" MODIFIED="1678407474208" TEXT="Koordinaten beachten">
|
|
<arrowlink COLOR="#feeccd" DESTINATION="ID_309596538" ENDARROW="Default" ENDINCLINATION="18;-79;" ID="Arrow_ID_46419716" STARTARROW="None" STARTINCLINATION="-24;79;"/>
|
|
<linktarget COLOR="#5c5dc2" DESTINATION="ID_1434222749" ENDARROW="Default" ENDINCLINATION="-123;0;" ID="Arrow_ID_1862539064" SOURCE="ID_764240247" STARTARROW="None" STARTINCLINATION="-876;0;"/>
|
|
<linktarget COLOR="#787099" DESTINATION="ID_1434222749" ENDARROW="Default" ENDINCLINATION="217;624;" ID="Arrow_ID_933310315" SOURCE="ID_1031158985" STARTARROW="None" STARTINCLINATION="264;15;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1566956361471" ID="ID_1879544719" MODIFIED="1576282358041" TEXT="Vorsicht bei gemeinsam genormten Koordinaten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dann der Platz für den "pinned" Ruler redundant im Body-Canvas vorhanden ist!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1567876399531" ID="ID_1578713642" MODIFIED="1582926955027" TEXT="genau.... jetzt hamma den Salat">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1567876413663" ID="ID_1376431800" MODIFIED="1567876429537" TEXT="alle Content-Labels erscheinen nach untern verschoben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1567876430941" FOLDED="true" ID="ID_1855510589" MODIFIED="1582926556111" TEXT="Ursache untersuchen">
|
|
<linktarget COLOR="#38acd3" DESTINATION="ID_1855510589" ENDARROW="Default" ENDINCLINATION="-764;-101;" ID="Arrow_ID_1877663178" SOURCE="ID_75969285" STARTARROW="None" STARTINCLINATION="570;60;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1582845817042" ID="ID_317035495" MODIFIED="1582901732132" TEXT="nebenbei aufgefallen">
|
|
<node CREATED="1582845824385" ID="ID_1853554200" MODIFIED="1582845841960" TEXT="Denkfehler beim Zählen der Anzahl Präfix-Elemente"/>
|
|
<node CREATED="1582845855165" ID="ID_1657667532" MODIFIED="1582845856441" TEXT="TrackBody::establishTrackSpace">
|
|
<node CREATED="1582845898576" ID="ID_1214624406" MODIFIED="1582845927319" TEXT="profile.pinnedPrefixCnt = 1 + rulers_.size();">
|
|
<arrowlink COLOR="#e10705" DESTINATION="ID_959308964" ENDARROW="Default" ENDINCLINATION="54;0;" ID="Arrow_ID_1772031431" STARTARROW="None" STARTINCLINATION="-1;44;"/>
|
|
</node>
|
|
<node CREATED="1582845900167" ID="ID_453347449" MODIFIED="1582845907889" TEXT="das ist falsch">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582845871107" ID="ID_959308964" MODIFIED="1582845922007" TEXT="die Gaps sind separate Elemente">
|
|
<linktarget COLOR="#e10705" DESTINATION="ID_959308964" ENDARROW="Default" ENDINCLINATION="54;0;" ID="Arrow_ID_1772031431" SOURCE="ID_1214624406" STARTARROW="None" STARTINCLINATION="-1;44;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582901642866" ID="ID_1916425956" MODIFIED="1582901724294" TEXT="bessere Lösung...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582901712969" ID="ID_532243486" MODIFIED="1582901722384" TEXT="empirisch vorgehen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1582901692334" ID="ID_941827355" MODIFIED="1582901712145" TEXT="explizit auswerten und markieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
direkt in der Berechnungs-Schleife erkennen, wenn wir den Präfix-Bereich durchschritten haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582845744756" ID="ID_965171553" MODIFIED="1582902381463" TEXT="wir haben jeweils zwei Interpreter">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582845760250" ID="ID_1399771576" MODIFIED="1582845770516" TEXT="einer nur für den feststehenden Overview-Ruler"/>
|
|
<node CREATED="1582845771288" ID="ID_1968190860" MODIFIED="1582845788754" TEXT="der zweite beginnt mit dem Content des Root-Track"/>
|
|
<node CREATED="1582845789534" ID="ID_1600590667" MODIFIED="1582845801976" TEXT="jeder zählt seine line_ separat hoch"/>
|
|
</node>
|
|
<node CREATED="1582902389601" ID="ID_240179937" MODIFIED="1582902409203" TEXT="das heißt, hier sind definitiv zwei Koordinatensysteme involviert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582902428822" ID="ID_829811888" MODIFIED="1582902650580" TEXT="Ansatz(Versuch): Übersetzung im DisplayFrame">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582902457871" ID="ID_1162389366" MODIFIED="1582902473485" TEXT="genau dort werden auch die Track-lokalen Koordinaten gebildet"/>
|
|
<node CREATED="1582902494453" ID="ID_986992726" MODIFIED="1582902504457" TEXT="CanvasOffsetHook::hookAdjY"/>
|
|
<node CREATED="1582902510004" ID="ID_1627491014" MODIFIED="1582902518936" TEXT="technische Details delegiert">
|
|
<node CREATED="1582902540815" ID="ID_857717809" MODIFIED="1582902540815" TEXT="TrackBody::establishTrackSpace"/>
|
|
<node COLOR="#338800" CREATED="1582902544283" ID="ID_76600735" MODIFIED="1582925563094" TEXT="dort versteckt: line nach Overview-Ruler auf 0 zurücksetzen">
|
|
<linktarget COLOR="#22376a" DESTINATION="ID_76600735" ENDARROW="Default" ENDINCLINATION="1007;48;" ID="Arrow_ID_984706037" SOURCE="ID_330989158" STARTARROW="None" STARTINCLINATION="325;16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582902593784" ID="ID_984846963" MODIFIED="1582902611866" TEXT="damit bekommen die sub-Tracks die real korrekten Start-Koordinaten"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582902653211" ID="ID_1818419302" MODIFIED="1582926411285" TEXT="ab 2. Sub-Ebene immer noch falsch positioniert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582903546261" ID="ID_1725318843" MODIFIED="1582903552175" TEXT="beobachte(Debugger)">
|
|
<node CREATED="1582903562092" ID="ID_510339383" MODIFIED="1582904078739" TEXT="establishTrackSpace">
|
|
<node CREATED="1582904081457" ID="ID_1429267862" MODIFIED="1582907004900" TEXT="ruler-Prefix(after) = 107">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1429267862" ENDARROW="Default" ENDINCLINATION="375;31;" ID="Arrow_ID_650469273" SOURCE="ID_1193104474" STARTARROW="None" STARTINCLINATION="438;0;"/>
|
|
</node>
|
|
<node CREATED="1582904219421" ID="ID_672384800" MODIFIED="1582904230295" TEXT="Root-Track-content = 122"/>
|
|
<node CREATED="1582904431278" ID="ID_1322672602" MODIFIED="1582907742555" TEXT="Track1-startLine = 0+127">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582904514539" ID="ID_1295892623" MODIFIED="1582904521816" TEXT="contentOffset = 0"/>
|
|
<node CREATED="1582904560362" ID="ID_752277468" MODIFIED="1582904566598" TEXT="Track1-content = 122"/>
|
|
</node>
|
|
<node CREATED="1582904626737" ID="ID_1813609462" MODIFIED="1582904642294" TEXT="line == 122 + 127 == 249"/>
|
|
<node CREATED="1582904731713" ID="ID_1658550754" MODIFIED="1582907808467" TEXT="Track2-startLiine = 0+249">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582904827935" ID="ID_1958391380" MODIFIED="1582904836490" TEXT="rulerHeight = 20 + 0"/>
|
|
<node CREATED="1582904870226" ID="ID_545156872" MODIFIED="1582904875725" TEXT="contentOffset = 48">
|
|
<node CREATED="1582907863745" ID="ID_857608861" MODIFIED="1582907902330" TEXT="line == 297 (249+48)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582904995139" ID="ID_1851164004" MODIFIED="1582905014710" TEXT="Track2-content = 122 (80 + deco)"/>
|
|
<node CREATED="1582905032854" ID="ID_641952627" MODIFIED="1582905063158" TEXT="line == 48 +122 == 170">
|
|
<node CREATED="1582907950438" ID="ID_1853966130" MODIFIED="1582908083600" TEXT="line(global) == 419 (249+170)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582905091279" ID="ID_1290848966" MODIFIED="1582905097523" TEXT="+5 (down-slope)">
|
|
<node CREATED="1582907999767" ID="ID_1914135364" MODIFIED="1582908088879" TEXT="line(global) == 424">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582905153591" ID="ID_1291398442" MODIFIED="1582908037189" TEXT="Track-21-startLine := 249 + 175 == 424">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582905291109" ID="ID_99409263" MODIFIED="1582905300304" TEXT="contentOffset = 0"/>
|
|
<node CREATED="1582905314298" ID="ID_1814819446" MODIFIED="1582905321029" TEXT="Track21-content = 122"/>
|
|
</node>
|
|
<node CREATED="1582905358964" ID="ID_20842083" MODIFIED="1582905474065" TEXT="line == 175 + 122 == 297"/>
|
|
<node CREATED="1582905524030" ID="ID_271881918" MODIFIED="1582908073123" TEXT="Track-22-startLine := 249 + 297 == 546">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582905686984" ID="ID_1911307638" MODIFIED="1582905694883" TEXT="rulerHeight = 20 + 0"/>
|
|
<node CREATED="1582905727971" ID="ID_1314377409" MODIFIED="1582905733758" TEXT="contentOffset = 48">
|
|
<node CREATED="1582908146046" ID="ID_738674814" MODIFIED="1582908177368" TEXT="line(global) == 594(546+48)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582905766220" ID="ID_157127194" MODIFIED="1582905792493" TEXT="Track22-content = 170 - 48 == 122"/>
|
|
<node CREATED="1582905830637" ID="ID_899096367" MODIFIED="1582905843337" TEXT="line == 48 + 122 + 5 == 175"/>
|
|
<node CREATED="1582905896753" ID="ID_381270881" MODIFIED="1582908235770" TEXT="Track221-startLine := 546 + 175 == 721">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582906289133" ID="ID_1734369263" MODIFIED="1582906297119" TEXT="rulerHeigt = 20 +0"/>
|
|
<node CREATED="1582906298092" ID="ID_1471119167" MODIFIED="1582906302995" TEXT="contentOffset = 48">
|
|
<node CREATED="1582908287463" ID="ID_1992316773" MODIFIED="1582908400297" TEXT="line(global) == 769(721+48)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582906325651" ID="ID_1127420186" MODIFIED="1582906346780" TEXT="line = 48 + 122 == 170"/>
|
|
</node>
|
|
<node CREATED="1582906387686" ID="ID_1480877285" MODIFIED="1582906434468" TEXT="line == 175+170 == 345">
|
|
<node CREATED="1582908377032" ID="ID_950247145" MODIFIED="1582908395915" TEXT="line(global) == 891(546+345)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582906440264" ID="ID_1906259495" MODIFIED="1582908538979" TEXT="Track222-startLine := 546 + 345 == 891">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582906513386" ID="ID_1921963697" MODIFIED="1582906518050" TEXT="contentOffset = 0"/>
|
|
<node CREATED="1582906527452" ID="ID_1177882770" MODIFIED="1582906540015" TEXT="line = 122"/>
|
|
</node>
|
|
<node CREATED="1582906560121" ID="ID_1803290356" MODIFIED="1582906571437" TEXT="line == 345 + 122 == 467">
|
|
<node CREATED="1582908565738" ID="ID_112631959" MODIFIED="1582908605833" TEXT="line(global) == 1013(546+467)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582906612443" ID="ID_677398663" MODIFIED="1582906645875" TEXT="line == 297 + 467 == 764"/>
|
|
</node>
|
|
<node CREATED="1582906668404" ID="ID_518041792" MODIFIED="1582908632933" TEXT="line == 249 + 764 == 1013">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582906724418" ID="ID_201815304" MODIFIED="1582908692685" TEXT="line := 1027 (+14 slope-up)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582906786918" ID="ID_1986285948" MODIFIED="1582908719783" STYLE="fork" TEXT="line := 1027 + 11(botMar) + 5(TIMELINE_BOTTOM_PADDING) == 1043">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1986285948" ENDARROW="Default" ENDINCLINATION="281;0;" ID="Arrow_ID_1870504607" SOURCE="ID_356719128" STARTARROW="None" STARTINCLINATION="281;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582906910047" ID="ID_356719128" MODIFIED="1582906981791" TEXT="-> overallHeight = 1043">
|
|
<arrowlink DESTINATION="ID_1986285948" ENDARROW="Default" ENDINCLINATION="281;0;" ID="Arrow_ID_1870504607" STARTARROW="None" STARTINCLINATION="281;0;"/>
|
|
</node>
|
|
<node CREATED="1582906933077" ID="ID_1193104474" MODIFIED="1582907004900" TEXT="-> rulerHeight = 107">
|
|
<arrowlink DESTINATION="ID_1429267862" ENDARROW="Default" ENDINCLINATION="375;31;" ID="Arrow_ID_650469273" STARTARROW="None" STARTINCLINATION="438;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582903553636" ID="ID_421630336" MODIFIED="1582903561127" TEXT="Zeichen-Code">
|
|
<node COLOR="#338800" CREATED="1582909038719" ID="ID_24233739" MODIFIED="1582909049674" TEXT="oberer Canvas: Höhe OK">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582909051606" ID="ID_1642616871" MODIFIED="1582909067741" TEXT="(w,h) == (248,107)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582908797551" ID="ID_1600925226" MODIFIED="1582908821787" TEXT="unteren Canvas durchverfolgt: alle globalen Zeilen korrekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582908823851" ID="ID_1086427567" MODIFIED="1582926407709" TEXT="danach: Höhe weicht ab">
|
|
<arrowlink COLOR="#4f4bb1" DESTINATION="ID_407125396" ENDARROW="Default" ENDINCLINATION="59;-200;" ID="Arrow_ID_902537277" STARTARROW="None" STARTINCLINATION="-179;19;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582908842568" ID="ID_528889024" MODIFIED="1582908844275" TEXT="TimelineCanvas::drawGrounding"/>
|
|
<node CREATED="1582908852313" ID="ID_1725810299" MODIFIED="1582908890292" TEXT="(w,h) == (248,936)">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582923677605" ID="ID_69601825" MODIFIED="1582923752314" TEXT="der refHook schlägt bereits den ganzen Offset drauf">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582923645762" ID="ID_1584147087" MODIFIED="1582923659699" TEXT="während der Beobachtung springt's mir geradezu ins Auge..."/>
|
|
<node CREATED="1582923715319" ID="ID_1041462784" MODIFIED="1582923727431" TEXT="dann kanns ja gar nicht funktionieren">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1582923663958" ID="ID_573118783" MODIFIED="1582923713665" TEXT="wie immer">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582923858068" ID="ID_373464934" MODIFIED="1582924053211" TEXT="Lösung: Verkettung bereits im ViewHook anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582923873957" ID="ID_1453835216" MODIFIED="1582923895363" TEXT="der neue Offset-Hook muß den Offset des alten Hook entfernen können"/>
|
|
<node CREATED="1582923896129" ID="ID_188826667" MODIFIED="1582923913079" TEXT="wir wollen auch zur Laufzeit keine Dekorator-Ketten-Aufrufe">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1582923916162" ID="ID_879903056" MODIFIED="1582923946222">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
daher Policy ändern: jeder schlägt den <b>totalen absoluten</b>  Offset drauf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1582923948176" ID="ID_1562514737" MODIFIED="1582924052715" TEXT="und damit das geht, muß man irgendwo vom reinen ViewHook starten können">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dieser muß deshalb auch schon eine Funktion <font face="Monospaced">getAnchorHook()</font> auf dem API bieten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582924064889" ID="ID_1581753872" MODIFIED="1582924093938" TEXT="Template umbennen in ViewRefHook und hochschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582902750166" ID="ID_407125396" MODIFIED="1582926396858" TEXT="Canvas-Höhe insgesamt falsch (zu gering)">
|
|
<linktarget COLOR="#4f4bb1" DESTINATION="ID_407125396" ENDARROW="Default" ENDINCLINATION="59;-200;" ID="Arrow_ID_902537277" SOURCE="ID_1086427567" STARTARROW="None" STARTINCLINATION="-179;19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582925333183" ID="ID_370690048" MODIFIED="1582925346001" TEXT="liegt an der Unklarheit der Bezugsssysteme">
|
|
<node CREATED="1582925351805" ID="ID_1047753842" MODIFIED="1582925363463" TEXT="936 = 1043 - 107"/>
|
|
<node CREATED="1582925395639" ID="ID_604617266" MODIFIED="1582925408105" TEXT="also: wann/wo gelten die absoluten Koordinaten"/>
|
|
</node>
|
|
<node CREATED="1582925410396" ID="ID_1772952996" MODIFIED="1582925421631" TEXT="Beschluß: alle Berechnungen im Canvas sind relativ">
|
|
<node CREATED="1582925422715" ID="ID_543762048" MODIFIED="1582925436017" TEXT="sinnvoll, da ich mich jetzt für relative Koordinaten entschieden haben"/>
|
|
<node CREATED="1582925436929" ID="ID_509859650" MODIFIED="1582925449096" TEXT="d.h. jeder Canvas hat sein eigenes Bezugssystem"/>
|
|
<node CREATED="1582925449892" ID="ID_1269496698" MODIFIED="1582925470344" TEXT="und auch die Zeile in establishTrackSpace sollte relativ zum Canvas gelten">
|
|
<node CREATED="1582925471236" ID="ID_288322254" MODIFIED="1582925476432" TEXT="was sie jetzt bereits tut"/>
|
|
<node CREATED="1582925477248" ID="ID_330989158" MODIFIED="1582926537321" TEXT="mein "versteckter Trick" ist mithin sogar logisch konsistent">
|
|
<arrowlink COLOR="#22376a" DESTINATION="ID_76600735" ENDARROW="Default" ENDINCLINATION="1007;48;" ID="Arrow_ID_984706037" STARTARROW="None" STARTINCLINATION="325;16;"/>
|
|
<linktarget COLOR="#1d40c9" DESTINATION="ID_330989158" ENDARROW="Default" ENDINCLINATION="-289;13;" ID="Arrow_ID_420585761" SOURCE="ID_103638255" STARTARROW="None" STARTINCLINATION="219;13;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582925575929" ID="ID_1677196860" MODIFIED="1582925590560" TEXT="damit muß auch jede Höhe separat als Ganzes auf den Canvas angewendet werden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582926428346" ID="ID_1968205234" MODIFIED="1582926440570" TEXT="Restrukturierung: lokale und absolute Koordinaten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1582926442161" ID="ID_33511214" MODIFIED="1582926545738" TEXT="Beschluß: Canvas verwendet seine eigenen lokalen Koordinaten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582926466421" ID="ID_103638255" MODIFIED="1582926537321" TEXT="establishTrackSpace muß in diesen arbeiten">
|
|
<arrowlink COLOR="#1d40c9" DESTINATION="ID_330989158" ENDARROW="Default" ENDINCLINATION="-289;13;" ID="Arrow_ID_420585761" STARTARROW="None" STARTINCLINATION="219;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1611478078314" ID="ID_922960853" MODIFIED="1611478247952" TEXT="Fazit: Lösung besteht darin...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1611478094013" ID="ID_161468675" MODIFIED="1611478110959" TEXT="in jedem Track explizit einen Content-Offset zu speichern"/>
|
|
<node CREATED="1611478132776" ID="ID_107298111" MODIFIED="1611478155731" TEXT="damit überall relative (lokale) Bezugssysteme zu ermöglichen"/>
|
|
<node CREATED="1611478208171" ID="ID_383778310" MODIFIED="1611478224282" TEXT="in jedem (Teil)-Canvas die "natürlichen" Eigen-Koordinaten zu verwenden"/>
|
|
<node CREATED="1611478227499" ID="ID_1352834162" MODIFIED="1611482079208" TEXT="die Übersetzung komplett via ViewHook wegzuabstrahieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
tatsächlich ist es dann ein Sub-Interface: der CanvasHook. Und dieser
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
kennt (nur) implizit dein Ursprung seines relativen Bezugssystems
|
|
</li>
|
|
<li>
|
|
hat aber auch einen Callback, um formell relativ zu sich selbst einen sub-CanvasHook zu erschaffen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611481905544" ID="ID_269249582" MODIFIED="1611482248833" TEXT="aber: ViewHooks ― keine generische Quer-Beweglichkeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...trotzdem wurde die Idee eines generischen UI-Layout-Frameworks nach gründlicher Untersuchung aufgegeben; dies System der ViewHooks stiftet uns also "nur" ein Baumuster, und wir beschränken uns auf die bekannte kleine Zahl der konkreten Fälle, welche weitgehend im DisplayFrame gebündelt sind. Deshalb gibt es nun hilfsweise das Zugangs-Interface ViewHooks, von dem man alle relevanten, speziell getypten ViewHook, bzw. Canvas-Hook eben <i>im aktuellen Display-Frame</i> (relatives Koordinatensystem) beziehen kann.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611486170153" ID="ID_137005272" MODIFIED="1611487171442" TEXT="tatsächlich ist DisplayFrame der CanvasHook">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar für den einzigen relevanten Canvas, das ist nämlich der untere, in der ScrolledPane, mit dem Tack-Content. Wir verwenden inzwischen in jedem Canvas nur noch die lokalen Koordinaten, und daher addieren nun die jeweilgen TrackBody auch ihre eigene startLine_ in lokalen Koordinaten auf. Da der DisplayFrame direkten Zugang zu "seinem" zugehörigen TrackBody hat, bekommen wir über diesen Trick stets punktgenaue, lokale Koordinaten, solange wir uns im Geltungsbereich dieses TrackBody aufhalten. Das bedeutet, theoretisch könnte ein Clip auch weit unterhalb des TrackBody angeheftet werden. So etwas muß dann eigens im DisplayEvaluationPass ausgeschlossen werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#dc91e4" DESTINATION="ID_392294660" ENDARROW="Default" ENDINCLINATION="648;52;" ID="Arrow_ID_1413556921" STARTARROW="None" STARTINCLINATION="843;52;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1566955936904" ID="ID_925495886" MODIFIED="1679077819636" TEXT="vertikale Koordinaten">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1566955943327" FOLDED="true" ID="ID_309596538" MODIFIED="1582926985844" TEXT=""natürlich" ist es, wenn jeder Canvas eigene Koordinaten hat">
|
|
<arrowlink COLOR="#5d3885" DESTINATION="ID_1411864272" ENDARROW="Default" ENDINCLINATION="-1041;0;" ID="Arrow_ID_1078761950" STARTARROW="None" STARTINCLINATION="-660;30;"/>
|
|
<linktarget COLOR="#feeccd" DESTINATION="ID_309596538" ENDARROW="Default" ENDINCLINATION="18;-79;" ID="Arrow_ID_46419716" SOURCE="ID_1434222749" STARTARROW="None" STARTINCLINATION="-24;79;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1566955975338" ID="ID_1779775058" MODIFIED="1566955999837">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die gekoppelten Scrollbars funktionieren dann <i>"von selber"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1566956005927" ID="ID_1438858393" MODIFIED="1566956013610" TEXT="Größenberechnung wird einfach">
|
|
<node CREATED="1568384121791" ID="ID_1073937095" MODIFIED="1568384131713" TEXT="ich neige immer mehr dieser Lösung zu">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1582847591411" ID="ID_262535896" MODIFIED="1582847617087" TEXT="das heißt: man versteckt diese zusätzliche Komplexität als lokaler Belang"/>
|
|
</node>
|
|
<node CREATED="1582847416211" ID="ID_1315976508" MODIFIED="1582847542678">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>dann</i> muß ich aber die zwei Bezugssyteme wirklich auseinanderhalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1582847500246" ID="ID_1385190844" MODIFIED="1582847507162" TEXT="globale logische Koordinaten"/>
|
|
<node CREATED="1582847508092" ID="ID_38965837" MODIFIED="1582847520169" TEXT="im unteren Canvas: lokal justierte Koordinaten"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1566955956741" FOLDED="true" ID="ID_1266359061" MODIFIED="1612031448843" TEXT="wie können wir dann aber Clips korrekt positionieren?">
|
|
<arrowlink COLOR="#4943a0" DESTINATION="ID_1270677756" ENDARROW="Default" ENDINCLINATION="954;-120;" ID="Arrow_ID_1809237545" STARTARROW="None" STARTINCLINATION="-298;16;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1568383045628" ID="ID_557151257" MODIFIED="1576282358040" TEXT="dafür brauchen wir ohnehin eine access-Funtkion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil die Canvas-Controls tief eingewickelt in der Struktur liegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1568383095404" ID="ID_393689214" MODIFIED="1568383114645" TEXT="Auslösen wird das der ClipPresenter"/>
|
|
<node CREATED="1568383358860" ID="ID_619192777" LINK="#ID_633007604" MODIFIED="1568384041962" TEXT="den tatsächlichen Zugriff könnte der DisplayFrame haben"/>
|
|
</node>
|
|
<node CREATED="1568383386424" ID="ID_610235776" MODIFIED="1568383405042" TEXT="dieser Accessor könnte eine Koordinaten-Transformation machen"/>
|
|
<node COLOR="#338800" CREATED="1576975048525" ID="ID_1095950959" MODIFIED="1612031428184" TEXT="zusammen mit dem Sub-Attachment gelöst">
|
|
<arrowlink COLOR="#406fc9" DESTINATION="ID_272168913" ENDARROW="Default" ENDINCLINATION="-1471;82;" ID="Arrow_ID_1415590908" STARTARROW="None" STARTINCLINATION="-1695;79;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611787774512" FOLDED="true" ID="ID_1848866838" MODIFIED="1612031381604" TEXT="Problem: Layout-Anpassung">
|
|
<linktarget COLOR="#6bce9f" DESTINATION="ID_1848866838" ENDARROW="Default" ENDINCLINATION="-842;72;" ID="Arrow_ID_1370580747" SOURCE="ID_1798941398" STARTARROW="None" STARTINCLINATION="1148;66;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611787832152" ID="ID_421588952" MODIFIED="1611787838787" TEXT="Display-Evaluation-Pass"/>
|
|
<node COLOR="#435e98" CREATED="1611787839919" ID="ID_791476178" MODIFIED="1612031367778" TEXT="erfordert veränderte Interpretation der Koordinaten">
|
|
<arrowlink COLOR="#675b85" DESTINATION="ID_1709866969" ENDARROW="Default" ENDINCLINATION="684;566;" ID="Arrow_ID_541728210" STARTARROW="None" STARTINCLINATION="-1876;104;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611788484755" ID="ID_1242261012" MODIFIED="1612019536549" TEXT="wie kann eine Neu-Anordnung überhaupt bewirkt werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1611789188712" ID="ID_292272154" MODIFIED="1611789377585" TEXT="Problem: wer kennt die Koordinaten?">
|
|
<node CREATED="1611789203502" ID="ID_974096123" MODIFIED="1611789223591" TEXT="die ursprünglichen Koordinaten sind schon eine Summe"/>
|
|
<node CREATED="1611789225054" ID="ID_1746948156" MODIFIED="1611789248019" TEXT="ein Dekorator (RelativeCanvasHook) hat sie manipuliert"/>
|
|
<node CREATED="1611789249032" ID="ID_1964954296" MODIFIED="1611789268787" TEXT="sie wurden nur Gtk-Canvas-Control selber gespeichert"/>
|
|
</node>
|
|
<node CREATED="1611789382773" ID="ID_1721577123" MODIFIED="1611789397911" TEXT="⟹ wir brauchen...">
|
|
<node CREATED="1611789399027" ID="ID_61457943" MODIFIED="1611789413824" TEXT="entweder einen Zugang zu den roh-Koordinaten"/>
|
|
<node CREATED="1611789415136" ID="ID_1771759059" MODIFIED="1611789426867" TEXT="oder ein Delta der Layout-Anpassung"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612019484247" ID="ID_1243648856" MODIFIED="1612031378780" TEXT="Lösung: den 3.Pass der DisplayEvaluation auch hierfür nutzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612019507497" ID="ID_877065301" MODIFIED="1612019522485" TEXT="alle Widgets auf dem Canvas...."/>
|
|
<node CREATED="1612019523193" ID="ID_1272964807" MODIFIED="1612019533076" TEXT="...per move() repositionieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564934012352" ID="ID_909641864" MODIFIED="1679078002475" TEXT="korrekt zeichnen analog zum CSS Layout-Modell">
|
|
<arrowlink COLOR="#556dd4" DESTINATION="ID_756463948" ENDARROW="Default" ENDINCLINATION="-507;0;" ID="Arrow_ID_1335568264" STARTARROW="None" STARTINCLINATION="582;34;"/>
|
|
<linktarget COLOR="#47d95e" DESTINATION="ID_909641864" ENDARROW="Default" ENDINCLINATION="-129;8;" ID="Arrow_ID_1785938082" SOURCE="ID_859006044" STARTARROW="None" STARTINCLINATION="-87;-106;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1679078015422" ID="ID_705241250" MODIFIED="1679078022355" TEXT="weitgehend gelöst...">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679078023643" HGAP="28" ID="ID_857274090" MODIFIED="1679078167409" TEXT="einige offene Enden" VSHIFT="-24">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Feature-Definition der »Ruler« noch nicht gegeben
|
|
</li>
|
|
<li>
|
|
viele Details zum »Content« in den Tracks sind noch nicht klar
|
|
</li>
|
|
<li>
|
|
vertikale Positionierung von Content <i>innerhalb</i> der Tracks ist noch nicht gelöst
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#ac6889" DESTINATION="ID_1179051544" ENDARROW="Default" ENDINCLINATION="156;56;" ID="Arrow_ID_1100428264" STARTARROW="None" STARTINCLINATION="592;-47;"/>
|
|
<arrowlink COLOR="#833462" DESTINATION="ID_1673637596" ENDARROW="Default" ENDINCLINATION="363;27;" ID="Arrow_ID_1860808311" STARTARROW="None" STARTINCLINATION="743;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1564955053506" ID="ID_1662307644" MODIFIED="1679073402095" TEXT="Größen-Steuerung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1564955157184" ID="ID_1091509436" MODIFIED="1564955185828" TEXT="Aufgabe">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1564955132311" ID="ID_1839818990" MODIFIED="1564955142481" TEXT="muß vertikalen Platz allozieren">
|
|
<node CREATED="1564955168962" ID="ID_1426241163" MODIFIED="1564955173093" TEXT="abhängig vom Content"/>
|
|
<node CREATED="1564955174673" ID="ID_1616823062" MODIFIED="1564955181202" TEXT="rekursive Beziehung">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564955143913" ID="ID_758635487" MODIFIED="1564955153144" TEXT="und dann im Gleichlauf im Header / Body verwenden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1564955192182" ID="ID_1493629193" MODIFIED="1679073375897" TEXT="Größe des Canvas setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1564955220383" ID="ID_300626537" MODIFIED="1679073373770" TEXT="Ausdehnung berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1564955227226" ID="ID_1402788844" MODIFIED="1679073040285" TEXT="erster Entwurf: mehrfach rechnen, Werte merken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1679073359239" ID="ID_137522622" MODIFIED="1679073371266" TEXT="vertikale Ausdehnung ergibt sich aus dem Profil-Render-Pass">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1679073041362" ID="ID_1838761224" MODIFIED="1679073347163" TEXT="ZoomWindow übernimmt die Berechnung horizontal">
|
|
<arrowlink COLOR="#71b1ad" DESTINATION="ID_123640005" ENDARROW="Default" ENDINCLINATION="889;28;" ID="Arrow_ID_835967440" STARTARROW="None" STARTINCLINATION="1146;63;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582849672936" ID="ID_1387330222" MODIFIED="1679073035821" TEXT="2023: nicht sicher ob es schon korrekt ist">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679072757616" ID="ID_859006044" MODIFIED="1679072846462" TEXT="#1203 CSS styling for a properly shaded track profile">
|
|
<arrowlink COLOR="#47d95e" DESTINATION="ID_909641864" ENDARROW="Default" ENDINCLINATION="-129;8;" ID="Arrow_ID_1785938082" STARTARROW="None" STARTINCLINATION="-87;-106;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1679072896857" ID="ID_385103971" MODIFIED="1679072909390" TEXT="vertikale Struktur gemäß Struktur-Profil">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1679072924937" ID="ID_1728495568" MODIFIED="1679072932126" TEXT="Styles im Zeichen-Code aufgreifen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1567683913947" ID="ID_704534518" MODIFIED="1679072939881" TEXT="(optional) zusätzliche Schattierung im Overlay-Pass zeichnen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1566525274854" ID="ID_1976574053" MODIFIED="1679072952761" TEXT="Vorsicht: auch horizontal genügend Platz schaffen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567689612779" HGAP="9" ID="ID_1142611198" MODIFIED="1567689628166" TEXT="Probleme" VSHIFT="2">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1567689637751" ID="ID_1333933230" MODIFIED="1567689647034" TEXT="Scrollbar verschwindet nach Fokus-Verlust">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582988892133" ID="ID_483543888" MODIFIED="1582988892133" TEXT="#1208 automatic vertical scrollbar malfunctioning">
|
|
<linktarget COLOR="#8c6572" DESTINATION="ID_483543888" ENDARROW="Default" ENDINCLINATION="544;-34;" ID="Arrow_ID_759404699" SOURCE="ID_829958563" STARTARROW="None" STARTINCLINATION="395;28;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1567689657945" ID="ID_243238670" MODIFIED="1567689670071" TEXT="wird durch Größenänderung wieder sichtbar"/>
|
|
<node CREATED="1567689911283" ID="ID_1726946456" MODIFIED="1567689930883" TEXT="auch das Mausrad wirkt erst wieder nach Größenänderung"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1567689931927" ID="ID_974682979" MODIFIED="1567689942119" TEXT="das deutet auf einen Fehler in der Allokation hin">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1567869494614" ID="ID_244849159" MODIFIED="1567869662204" TEXT="möglicher Workaround: auf das "configureEvent" reagieren">
|
|
<arrowlink COLOR="#819eaf" DESTINATION="ID_842897291" ENDARROW="Default" ENDINCLINATION="1085;0;" ID="Arrow_ID_704507451" STARTARROW="None" STARTINCLINATION="2673;-176;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1568383963154" ID="ID_1080514398" MODIFIED="1568383975298" TEXT="hab ich da schon was gemacht?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1568383976601" ID="ID_120892436" MODIFIED="1568383991832" TEXT="besteht das Problem noch?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1567689738430" ID="ID_335898798" MODIFIED="1567689747264" TEXT="feine Zeichenfehler an der Stoßfläche">
|
|
<node CREATED="1567689750410" ID="ID_1517735190" MODIFIED="1567689771647" TEXT="...von zwei Bereichen mit box-shadow"/>
|
|
<node CREATED="1567689772565" ID="ID_1542367602" MODIFIED="1576282358040" TEXT="...sofern der box-shadow den im Zeichenvorgang abgedeckten Bereich überschreitet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
er wird von GTK eigentlich korrekt über die Nachbarbereiche darüber gezeichnet.
|
|
</p>
|
|
<p>
|
|
Aber an der Nahtstelle entsteht ein helle Linie von 1/2 Pixel Breite,
|
|
</p>
|
|
<p>
|
|
die sich nur beim Scrollen bemerkbar macht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1567689845067" ID="ID_1441909594" MODIFIED="1576282358039" TEXT="ich betrachte das Problem als eigentlich irrelevant">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man soll ohnehin keinen so großen box-shadow verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679073569262" ID="ID_1588787668" MODIFIED="1679073603054" TEXT="verbleibende Probleme in der Layout-Steuerung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1566689183161" ID="ID_1366095324" MODIFIED="1678063263325" TEXT="Layout im Track-Head immer noch etwas komisch">
|
|
<arrowlink COLOR="#b74f6e" DESTINATION="ID_1600275521" ENDARROW="Default" ENDINCLINATION="276;749;" ID="Arrow_ID_614998223" STARTARROW="None" STARTINCLINATION="644;37;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1678063155834" ID="ID_774623134" MODIFIED="1679073584761" TEXT="ein Problem könnte die Verteilung zusätzlcher vertikaler Ausdehnung sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...darüber bin ich auch beim Zeichnen der Connector im StaveBracket gestolpert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1678063198596" ID="ID_1800094446" MODIFIED="1679073586554" TEXT="wenn man den Splitter zieht, springt die vertikale Platzverteilung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sichtbar an der Höhe der Sub-Scope-Verbindungen auf den StaveBrackets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611914243018" ID="ID_604450209" MODIFIED="1611915210013" TEXT="Clip-Anzeige einbinden">
|
|
<linktarget COLOR="#aa6852" DESTINATION="ID_604450209" ENDARROW="Default" ENDINCLINATION="-1233;136;" ID="Arrow_ID_186901681" SOURCE="ID_1839157029" STARTARROW="None" STARTINCLINATION="-480;35;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611914301682" ID="ID_867069834" MODIFIED="1611915247263" TEXT="ClipPresenter bauen">
|
|
<arrowlink COLOR="#d03a17" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-144;-652;" ID="Arrow_ID_1292343123" STARTARROW="None" STARTINCLINATION="403;48;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1611915255650" HGAP="83" ID="ID_734202635" MODIFIED="1611915298195" TEXT="Klasse anlegen" VSHIFT="-3">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611915265289" HGAP="85" ID="ID_245617141" MODIFIED="1611915302849" TEXT="Diff-Handler definieren" VSHIFT="2">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611915316586" HGAP="94" ID="ID_1248959265" MODIFIED="1612031249722" TEXT="DisplayEvaluation - Anbindung" VSHIFT="-5">
|
|
<arrowlink COLOR="#5c849c" DESTINATION="ID_1488484275" ENDARROW="Default" ENDINCLINATION="-838;79;" ID="Arrow_ID_1236233773" STARTARROW="None" STARTINCLINATION="612;56;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611914423505" ID="ID_498480986" MODIFIED="1611914441536" TEXT="Clip-Widget integrieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480741374451" FOLDED="true" ID="ID_1270677756" MODIFIED="1582847535244" TEXT="in Display injizieren">
|
|
<linktarget COLOR="#4943a0" DESTINATION="ID_1270677756" ENDARROW="Default" ENDINCLINATION="954;-120;" ID="Arrow_ID_1809237545" SOURCE="ID_1266359061" STARTARROW="None" STARTINCLINATION="-298;16;"/>
|
|
<linktarget COLOR="#fd654f" DESTINATION="ID_1270677756" ENDARROW="Default" ENDINCLINATION="-300;38;" ID="Arrow_ID_278984117" SOURCE="ID_1043075543" STARTARROW="None" STARTINCLINATION="131;-344;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1568383480998" ID="ID_263963478" MODIFIED="1568383491356" TEXT="Problem: Zugang zum Canvas">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1568383512509" ID="ID_1358982564" MODIFIED="1568383526344" TEXT="durchschneidet die hierarchische Ordnung">
|
|
<node CREATED="1568383534499" ID="ID_608263529" MODIFIED="1568383545165" TEXT="denn der Canvas ist inhärent global"/>
|
|
<node CREATED="1568383546005" ID="ID_1965015990" MODIFIED="1568383556367" TEXT="(tatsächlich gehört er dem DisplayManager)"/>
|
|
</node>
|
|
<node CREATED="1568383561002" ID="ID_1707558582" MODIFIED="1568383593930" TEXT="Löungsansätze">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1568383568950" ID="ID_1484652442" MODIFIED="1583678291351" TEXT="über den Display-Manager gehen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1568383620427" ID="ID_879415775" MODIFIED="1568383626685" TEXT="gefällt mir nicht...."/>
|
|
<node CREATED="1568383627722" ID="ID_1387232403" MODIFIED="1568383684206" TEXT="Gefahr: Display-Manager wird Gott-Klasse">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1568383578647" ID="ID_633007604" MODIFIED="1568579999196" TEXT="den lokalen Display-Frame zur Abstraktion ausbauen">
|
|
<linktarget COLOR="#598cc8" DESTINATION="ID_633007604" ENDARROW="Default" ENDINCLINATION="-292;0;" ID="Arrow_ID_290509509" SOURCE="ID_685143843" STARTARROW="None" STARTINCLINATION="765;42;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1568581076086" ID="ID_536195735" MODIFIED="1568581089407" TEXT="Problem: der ist seinerseits eine Sackgasse">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1582498722221" ID="ID_90390359" MODIFIED="1582498771653" TEXT="naja... hab ihn jetzt als ViewHook ausgebaut">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das war ein größeres Refactoring; dafür fällt dann die Lösung mit den rekursiv "eingehäkelten" Lambdas weg. Ist sicherlich besser so...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612438613382" ID="ID_167120458" MODIFIED="1612438705315" TEXT="DisplayFrame bleibt als einzige Alternative übrig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...für eine zentrale Schaltstelle und Verteiler.<br />Denn nur der DisplayFrame ist hinreichend loka und dennoch erreichbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612438770925" ID="ID_225186300" MODIFIED="1612438799056" TEXT="⟹ DisplayFrame ist keine Abstraktion im strengen Sinn"/>
|
|
</node>
|
|
<node CREATED="1573926191124" ID="ID_1389602122" MODIFIED="1573928984092" TEXT="Display-Frame gehört eigentlich zum Track">
|
|
<arrowlink COLOR="#2769d6" DESTINATION="ID_1953592630" ENDARROW="Default" ENDINCLINATION="-300;1096;" ID="Arrow_ID_928857904" STARTARROW="None" STARTINCLINATION="-1987;53;"/>
|
|
</node>
|
|
<node CREATED="1568581102059" ID="ID_172612190" MODIFIED="1568581104782" TEXT="brauche....">
|
|
<node CREATED="1568581105914" ID="ID_1022292144" MODIFIED="1568581117148" TEXT="Zugang zum BodyCanvasWidget"/>
|
|
<node CREATED="1568581118403" ID="ID_1096266089" MODIFIED="1584888781745" TEXT="Zugang zum DisplayManager (bzw. Timeline Layout)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584888760695" ID="ID_1764561185" MODIFIED="1666919335841" TEXT="Übersetzung Time -> pixel (via DisplayMetric (im TimelineLayout)">
|
|
<arrowlink COLOR="#354ce1" DESTINATION="ID_380050520" ENDARROW="Default" ENDINCLINATION="-2737;0;" ID="Arrow_ID_459309015" STARTARROW="None" STARTINCLINATION="-907;39;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1568587312669" ID="ID_178738138" MODIFIED="1576975019591" TEXT="die vertikalen Start-Offsets aus dem passenden Display-Frame">
|
|
<arrowlink COLOR="#5e57bd" DESTINATION="ID_1792139654" ENDARROW="Default" ENDINCLINATION="-2065;214;" ID="Arrow_ID_1917645572" STARTARROW="None" STARTINCLINATION="-949;44;"/>
|
|
<linktarget COLOR="#8395a4" DESTINATION="ID_178738138" ENDARROW="Default" ENDINCLINATION="-297;15;" ID="Arrow_ID_1606292545" SOURCE="ID_1574493569" STARTARROW="None" STARTINCLINATION="273;30;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1611478658033" HGAP="73" ID="ID_1825783827" MODIFIED="1611479264977" TEXT="diese Lösung scheint tragfähig. Nun fertig bauen!" VSHIFT="12">
|
|
<arrowlink COLOR="#f2d4e1" DESTINATION="ID_811510338" ENDARROW="Default" ENDINCLINATION="-516;-1779;" ID="Arrow_ID_1877167801" STARTARROW="None" STARTINCLINATION="481;25;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1611479345795" HGAP="88" ID="ID_911852543" MODIFIED="1611540320555" STYLE="bubble" TEXT="einen Clip via Diff injizieren" VSHIFT="-7">
|
|
<edge COLOR="#fad1c1"/>
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611479345795" HGAP="88" ID="ID_1289774279" MODIFIED="1666475465420" STYLE="bubble" TEXT="ein funktionsfähiges Clip-Widget..." VSHIFT="-7">
|
|
<edge COLOR="#fad1c1"/>
|
|
<icon BUILTIN="full-2"/>
|
|
<node COLOR="#435e98" CREATED="1611540326300" ID="ID_126501533" MODIFIED="1624027187371" TEXT="Clip erscheint">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666475500559" ID="ID_270580844" MODIFIED="1666475554439" TEXT="abridged Form — Längenbeschränkung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611479345795" HGAP="94" ID="ID_915417374" MODIFIED="1612031266360" STYLE="bubble" TEXT="an der richtigen Stelle zur Anzeige bringen" VSHIFT="-7">
|
|
<edge COLOR="#fad1c1"/>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611479345795" HGAP="106" ID="ID_1202942223" MODIFIED="1611479604603" STYLE="bubble" TEXT="per Diff editieren, umordnen und löschen" VSHIFT="-6">
|
|
<edge COLOR="#fad1c1"/>
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611479345795" HGAP="125" ID="ID_174645402" MODIFIED="1611479634502" STYLE="bubble" TEXT="dynamisch expandierbar machen..." VSHIFT="-40">
|
|
<edge COLOR="#fad1c1"/>
|
|
<icon BUILTIN="full-5"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1569711798770" ID="ID_1031858777" MODIFIED="1569712082881" TEXT="baut auf dem ViewHook auf">
|
|
<arrowlink COLOR="#5f74b7" DESTINATION="ID_1964864197" ENDARROW="Default" ENDINCLINATION="-1024;0;" ID="Arrow_ID_992148976" STARTARROW="None" STARTINCLINATION="-717;0;"/>
|
|
<node CREATED="1569711218032" ID="ID_892450390" MODIFIED="1569711340989" TEXT="bietet abstrahierten Zugang zum Canvas">
|
|
<arrowlink COLOR="#2245a8" DESTINATION="ID_578594394" ENDARROW="Default" ENDINCLINATION="-218;1468;" ID="Arrow_ID_1185551045" STARTARROW="None" STARTINCLINATION="-1702;0;"/>
|
|
</node>
|
|
<node CREATED="1569711228399" ID="ID_370497060" MODIFIED="1569711249152" TEXT=""klinkt" dieses ClipWidget in den Canvas ein"/>
|
|
<node CREATED="1569711251268" ID="ID_251536360" MODIFIED="1573162551740" TEXT="dadurch wird es Kind, und zeichnet sich selbst auf den Canvas"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583678317690" ID="ID_121923998" MODIFIED="1583678324853" TEXT="Zugang zum aktiven Widget">
|
|
<node CREATED="1583678326249" ID="ID_682261661" MODIFIED="1583678359510" TEXT="Zusammenhang mit dem Anzeigestil">
|
|
<arrowlink COLOR="#50457a" DESTINATION="ID_471098853" ENDARROW="Default" ENDINCLINATION="-144;-446;" ID="Arrow_ID_49809880" STARTARROW="None" STARTINCLINATION="-439;32;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1583678964323" ID="ID_1817011421" MODIFIED="1583678990571" TEXT="das Slave-Widget existiert nicht zwansläufig"/>
|
|
<node CREATED="1583678991615" ID="ID_498577144" MODIFIED="1583679009289" TEXT="das Slave-Widget kann jederzeit wechseln">
|
|
<node CREATED="1583679010636" ID="ID_1913532501" MODIFIED="1583679015784" TEXT="auch durch reine UI-Interaktion"/>
|
|
<node CREATED="1583679017253" ID="ID_453387495" MODIFIED="1583679027366" TEXT="dann müssen alle Datenverbindungen umgehängt werden"/>
|
|
</node>
|
|
<node CREATED="1583679054039" ID="ID_183239846" MODIFIED="1583679082455" TEXT="die Art des Einhängens in den Canvas ist variabel">
|
|
<node CREATED="1583679084131" ID="ID_1312984580" MODIFIED="1583679092325" TEXT="entweder ein nested Clip"/>
|
|
<node CREATED="1583679093066" ID="ID_360628937" MODIFIED="1583679101501" TEXT="oder ein custom-Drawing-Callback">
|
|
<node CREATED="1583679120382" ID="ID_1632040558" MODIFIED="1583679136946" TEXT="nicht klar, ob der vom ClipPresenter gesteuert wird">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1583679138220" ID="ID_1641273224" MODIFIED="1583679221489" TEXT="es handelt sich eigentlich um etas Übergreifendes">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich eine abgekürzte Übersichts-Darstellung, die wohl ehr auf der Basis ganzer Tracks zu zeichnen wäre (Tracks deshalb, weil wir eine <i>Abkürzungs-Darstellung</i>  der Tracks selber nicht vorsehen)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583678863154" ID="ID_1584052496" MODIFIED="1583678871115" TEXT="Zusammenhang mit der Diff-Mutation">
|
|
<node CREATED="1583678873295" ID="ID_791277837" MODIFIED="1583678899047" TEXT="ClipPresenter muß alle Eigenschaften des Clips handhaben können"/>
|
|
<node CREATED="1583678899851" ID="ID_441031651" MODIFIED="1583678915845" TEXT="die betreffenden Daten müssen im Speicher vorliegen"/>
|
|
<node CREATED="1583678916721" ID="ID_1647922777" MODIFIED="1583678929851" TEXT="und für den ClipPresenter zuordenbar und zugänglich sein"/>
|
|
</node>
|
|
<node CREATED="1583679298311" HGAP="-63" ID="ID_1284937858" MODIFIED="1583679310737" TEXT="Konsequenzen" VSHIFT="20">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1583679312741" ID="ID_440797673" MODIFIED="1584108642018" TEXT="dediziertes Clip-API">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
gegen das das Diff-Binding arbeiten kann
|
|
</li>
|
|
<li>
|
|
und welches den Anzeigestil abstrahiert
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612438537570" ID="ID_336118739" MODIFIED="1612438557683" TEXT="schrittweise herausfinden was gebraucht wird...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583679368212" FOLDED="true" ID="ID_1574493569" MODIFIED="1584289385953" TEXT="Einhänge-Mechanismus">
|
|
<arrowlink COLOR="#4668c0" DESTINATION="ID_1121301646" ENDARROW="Default" ENDINCLINATION="-360;299;" ID="Arrow_ID_1147127867" STARTARROW="None" STARTINCLINATION="472;50;"/>
|
|
<arrowlink COLOR="#8395a4" DESTINATION="ID_178738138" ENDARROW="Default" ENDINCLINATION="-297;15;" ID="Arrow_ID_1606292545" STARTARROW="None" STARTINCLINATION="273;30;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1584201581597" HGAP="61" ID="ID_1793842194" MODIFIED="1584289376633" TEXT="muß direkt beim Ctor-Aufruf passieren" VSHIFT="19">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1584201621519" ID="ID_1861895495" MODIFIED="1584201634905" TEXT="und zwar des demjenigen des tatsächlichen Widget">
|
|
<node CREATED="1584201671057" ID="ID_1545904786" MODIFIED="1584201682507" TEXT="der aber mit dem des Presenters zusammenfällt..."/>
|
|
<node CREATED="1584201683192" ID="ID_1482356055" MODIFIED="1584201718557" TEXT="weil man keine aufgedoppelte Referenz auf den ViewHook möchte">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
*) die Referenz steckt nämlich schon im ViewHookable
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584204158075" HGAP="48" ID="ID_1291783159" MODIFIED="1584204209950" VSHIFT="-2">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann erst erfolgen, <i>wenn's soweit ist</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und muß damit in den State-Change-Mechanismus für den Präsentationsstil verlegt werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1584289349339" ID="ID_1202416542" MODIFIED="1584289360503" TEXT="also eben doch nicht gleich beim ctor-Aufruf"/>
|
|
<node COLOR="#338800" CREATED="1584289361215" ID="ID_1687516658" MODIFIED="1584319384536" TEXT="brauche stattdessen einen Diff-Listener">
|
|
<linktarget COLOR="#38abc2" DESTINATION="ID_1687516658" ENDARROW="Default" ENDINCLINATION="30;37;" ID="Arrow_ID_901736037" SOURCE="ID_560620961" STARTARROW="None" STARTINCLINATION="129;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1584307692087" ID="ID_1525336492" MODIFIED="1584318646372" TEXT="genügen uns Struktur-Änderungen (onSeqChange)?">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1584307718907" ID="ID_211654301" MODIFIED="1584318632228" TEXT="im Moment ja, aber vermutlich längerfristig nicht">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1584309711112" ID="ID_161551669" MODIFIED="1584309897727" TEXT="Diff-Listener um assignElm() ergänzen">
|
|
<arrowlink COLOR="#427176" DESTINATION="ID_274485695" ENDARROW="Default" ENDINCLINATION="-1913;0;" ID="Arrow_ID_1484023114" STARTARROW="None" STARTINCLINATION="926;63;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584309903737" ID="ID_1025527544" MODIFIED="1584318627678" TEXT="onLocalChange()-Listener installieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584307731586" ID="ID_1716161483" MODIFIED="1584307998380">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Nebenbei bemerkt: die Aktion muß <b>idempotent</b> sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584201751260" ID="ID_1492285349" MODIFIED="1584932876269" TEXT="Problem: initiale Koordinaten">
|
|
<linktarget COLOR="#6fa9d7" DESTINATION="ID_1492285349" ENDARROW="Default" ENDINCLINATION="-156;14;" ID="Arrow_ID_819317359" SOURCE="ID_726635217" STARTARROW="None" STARTINCLINATION="170;10;"/>
|
|
<node COLOR="#338800" CREATED="1584201782842" ID="ID_560620961" MODIFIED="1584319384536" TEXT="sind nicht (zwingend) im Populations-Diff">
|
|
<arrowlink COLOR="#38abc2" DESTINATION="ID_1687516658" ENDARROW="Default" ENDINCLINATION="30;37;" ID="Arrow_ID_901736037" STARTARROW="None" STARTINCLINATION="129;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1584202974665" ID="ID_920397941" MODIFIED="1584203052619" TEXT="eigentlich ehr vom Anzeigestil abhängig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oder umgekeht....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
nur wenn auch Koordinaten da sind
|
|
</li>
|
|
<li>
|
|
und auch ein Anzeigestil gefordert wird, welcher ein dediziertes Widget verlangt
|
|
</li>
|
|
<li>
|
|
kann man ein ViewHooked konstruieren
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1584319394162" ID="ID_1919037634" MODIFIED="1584319465811" TEXT="wir wollen aber eine unnötige Doppel-Allokation pro Clip vermeiden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man das naiv coden würde, dann würden wir für jeden Clip erst mal einen ClipData-Placeholder erzeugen, nur um dann, nach dem Empfangen des vollständigen Diff, diesen wieder zu deallozieren und dafür ein ClipWidget zu erzeugen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611124962031" ID="ID_280018655" MODIFIED="1611478836551" TEXT="Aufgabe: vertikale Position">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611124973464" ID="ID_1224168080" MODIFIED="1611124982198" TEXT="konstanter Trim-Offset">
|
|
<node CREATED="1611478802279" ID="ID_1598711640" MODIFIED="1611478807273" TEXT="vorerst fest verdrahtet"/>
|
|
<node CREATED="1611478807981" ID="ID_614042972" MODIFIED="1611478833491" TEXT="kann später mal noch einen Offset pro Clip bekommen"/>
|
|
</node>
|
|
<node CREATED="1611124983105" ID="ID_93713729" MODIFIED="1611124999600" TEXT="ggfs eine spezifische Verschiebung, die sich der Clip merkt"/>
|
|
<node COLOR="#435e98" CREATED="1611125005500" ID="ID_1031158985" MODIFIED="1611478790295" TEXT="Problem Koordinaten-System im Track-Canvas">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem wegen dem Overview-Ruler, d.h. wie berücksichtigt der untere Canvas die Ausdehnung des oberen Canvas?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#787099" DESTINATION="ID_1434222749" ENDARROW="Default" ENDINCLINATION="217;624;" ID="Arrow_ID_933310315" STARTARROW="None" STARTINCLINATION="264;15;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611788045499" ID="ID_38758894" MODIFIED="1612031322771" TEXT="Problem: Layout initial noch nicht berechnet">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611788291010" ID="ID_301451653" MODIFIED="1611788307310" TEXT="wenn der ClipPresenter-Ctor läuft..."/>
|
|
<node CREATED="1611788308544" ID="ID_1059196785" MODIFIED="1611788327179" TEXT="und das CanvasHooked<ClipWidget> erzeugt"/>
|
|
<node CREATED="1611788328205" ID="ID_278674516" MODIFIED="1611788361528" TEXT="sind aber die Koordinaten-Offsets noch nicht bekannt">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611788373594" ID="ID_1798941398" MODIFIED="1612031319833" TEXT="Anpassung nach Layout-Bestimmung notwendig">
|
|
<arrowlink COLOR="#6bce9f" DESTINATION="ID_1848866838" ENDARROW="Default" ENDINCLINATION="-842;72;" ID="Arrow_ID_1370580747" STARTARROW="None" STARTINCLINATION="1148;66;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584201841529" ID="ID_1310327519" MODIFIED="1584202923362" TEXT="Nebengedanke: Eigenheiten des Populations-Diff">
|
|
<arrowlink COLOR="#2e3f60" DESTINATION="ID_1634323626" ENDARROW="Default" ENDINCLINATION="-1672;80;" ID="Arrow_ID_1671674197" STARTARROW="None" STARTINCLINATION="-1407;99;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584932756457" HGAP="142" ID="ID_726635217" MODIFIED="1612031332118" TEXT="Einhängen, wenn möglich" VSHIFT="-7">
|
|
<arrowlink COLOR="#6fa9d7" DESTINATION="ID_1492285349" ENDARROW="Default" ENDINCLINATION="-156;14;" ID="Arrow_ID_819317359" STARTARROW="None" STARTINCLINATION="170;10;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1584932910051" HGAP="63" ID="ID_1737560927" MODIFIED="1584932955050" TEXT="Zustands-Wechsel-Logik" VSHIFT="16">
|
|
<arrowlink COLOR="#4768d0" DESTINATION="ID_1833569495" ENDARROW="Default" ENDINCLINATION="943;-75;" ID="Arrow_ID_416244548" STARTARROW="None" STARTINCLINATION="207;23;"/>
|
|
<node CREATED="1612028128117" HGAP="71" ID="ID_631122092" MODIFIED="1612028188306" TEXT="Konvention: Time::NEVER ⟹ Clip bleibt verborgen" VSHIFT="-15">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584229199851" HGAP="47" ID="ID_1146096669" MODIFIED="1584229499004" TEXT="Vorsicht: Darstellung von Spuren und Effekten im Clip" VSHIFT="2">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir verwenden das ClipDelegate aber auch, um in Clips eingebettete Effekte oder die einzelnen Spuren darzustellen. Die Logik für den Anzeigestil muß das mit berücksichtigen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#a92d35" DESTINATION="ID_63120870" ENDARROW="Default" ENDINCLINATION="246;-353;" ID="Arrow_ID_973658371" STARTARROW="None" STARTINCLINATION="392;20;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1611125230101" HGAP="87" ID="ID_158847541" MODIFIED="1611125270395" TEXT="...abhängig vom Anzeigestil" VSHIFT="-1">
|
|
<edge COLOR="#925050" STYLE="linear"/>
|
|
</node>
|
|
<node CREATED="1611125230101" HGAP="107" ID="ID_1343303475" MODIFIED="1611125295487" TEXT="....brauchen einen nested canvas" VSHIFT="-8">
|
|
<edge COLOR="#925050" STYLE="linear"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#eb1854" CREATED="1611035931543" HGAP="27" ID="ID_1392905607" MODIFIED="1611038487716" STYLE="bubble" TEXT="⌛ hier war ich vor dem Covid-Jahr..." VSHIFT="20">
|
|
<edge COLOR="#eb1854" STYLE="sharp_linear" WIDTH="8"/>
|
|
<linktarget COLOR="#faeab8" DESTINATION="ID_1392905607" ENDARROW="Default" ENDINCLINATION="-1498;-119;" ID="Arrow_ID_871958604" SOURCE="ID_1578788883" STARTARROW="None" STARTINCLINATION="-2110;202;"/>
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<node COLOR="#435e98" CREATED="1611036115693" ID="ID_442179206" MODIFIED="1611036155856" TEXT="Design schaut robust aus">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611036133179" ID="ID_124683313" MODIFIED="1611036172537" TEXT="Grundlage der Anzeigesteuerung steht">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1584203074908" HGAP="34" ID="ID_366939108" MODIFIED="1584203089228" TEXT="das führt zu einem State-Pattern" VSHIFT="6">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1584203093953" ID="ID_1630684905" MODIFIED="1584289430184" TEXT="das jeweilge Slave-Widgtet repräsentiert auch den Anzeigestil"/>
|
|
<node CREATED="1584203184258" ID="ID_465578643" MODIFIED="1584203194792" TEXT="es gibt einen Placeholder für den Fall "unsichtbar""/>
|
|
<node CREATED="1584203854907" ID="ID_796620475" MODIFIED="1584203870238" TEXT="PImpl + ClipDelegate-Interface"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584289439497" ID="ID_1171233423" MODIFIED="1584289445670" TEXT="Zustandswahl">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584289446828" ID="ID_1852467427" MODIFIED="1584289455699" TEXT="Initial-Zustand errichten">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584289456539" ID="ID_375798695" MODIFIED="1584289466378" TEXT="Zustands-Wechsel implementieren">
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1568580048464" ID="ID_297402706" MODIFIED="1568580056499" TEXT="Übersetzung Zeit -> Pixel">
|
|
<node CREATED="1568580066766" ID="ID_382441114" MODIFIED="1568580080675" TEXT="letztlich Aufgabe des Display-Managers">
|
|
<node CREATED="1568580086251" ID="ID_965746340" LINK="#ID_1038931568" MODIFIED="1568580147307" TEXT="siehe: Thema Zeit-Darstellung und -Übersetzung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1568580161555" ID="ID_117814603" MODIFIED="1568580189881" TEXT="sollte aus dem ClipPresenter herausgehalten werden">
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1584207879889" ID="ID_433221711" MODIFIED="1584207971089" TEXT="Konsequenz: Abstraktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
entweder der ClipPresenter delegiert explizit an einen Service des Display-Managers
|
|
</p>
|
|
<p>
|
|
oder dieser Übersetzungs-Service wird irgendwo implizit versteckt.
|
|
</p>
|
|
<p>
|
|
Letzteres gefällt mir definitiv besser
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1584207894439" ID="ID_1587524009" MODIFIED="1584207912800" TEXT="Idee: den ViewHook spezialisieren..."/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611914653896" ID="ID_1275311433" MODIFIED="1611914705986" TEXT="Clip-Anzeigesteuerung">
|
|
<arrowlink COLOR="#772c4f" DESTINATION="ID_1431813131" ENDARROW="Default" ENDINCLINATION="-428;-554;" ID="Arrow_ID_144365857" STARTARROW="None" STARTINCLINATION="298;32;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480607059909" ID="ID_703281238" MODIFIED="1557498707231" TEXT="Control">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1540639047422" ID="ID_945522690" MODIFIED="1557498707231" TEXT="Timeline insgesamt">
|
|
<node COLOR="#338800" CREATED="1540638806886" ID="ID_1690989313" MODIFIED="1678407557078" TEXT="bauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1540639330313" ID="ID_335264895" MODIFIED="1557498707231" TEXT="top-level Population-Diff">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1540639342856" ID="ID_1646839476" MODIFIED="1557498707231" TEXT="ausschließlich per TimelineWidget-Ctor">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1540639375028" ID="ID_690498169" MODIFIED="1557498707231" TEXT="erzeugt">
|
|
<node CREATED="1540639382945" ID="ID_1389266781" MODIFIED="1557498707231" TEXT="Widget-Struktur">
|
|
<arrowlink COLOR="#7696bb" DESTINATION="ID_1999928728" ENDARROW="Default" ENDINCLINATION="113;285;" ID="Arrow_ID_198017810" STARTARROW="None" STARTINCLINATION="-139;0;"/>
|
|
</node>
|
|
<node CREATED="1540639386795" ID="ID_35543915" MODIFIED="1557498707231" TEXT="Layout-Manager"/>
|
|
<node CREATED="1540639392170" ID="ID_1944083475" MODIFIED="1557498707231" TEXT="(root)-TrackPresenter"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638810920" ID="ID_481615571" MODIFIED="1557498707231" TEXT="zerstören">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1540640109628" ID="ID_147809215" MODIFIED="1557498707231" TEXT="TODO: TimelineGui (proxy) muß kaskadieren">
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1544135984042" ID="ID_429363053" MODIFIED="1584932261288" TEXT="Grund für den Fehler im Nexus?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ERR: nexus.hpp:189: worker_3: ~Nexus: Some UI components are still connected to the backbone.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#d23194" DESTINATION="ID_535289114" ENDARROW="Default" ENDINCLINATION="90;0;" ID="Arrow_ID_186398670" STARTARROW="None" STARTINCLINATION="110;9;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540640144175" ID="ID_158939327" MODIFIED="1557498707231" TEXT="Zugang via TimelinePanel">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584932054082" ID="ID_535289114" MODIFIED="1584932261288" TEXT="#1216 Some UI components are still connected to the backbone at shutdown">
|
|
<linktarget COLOR="#b183a2" DESTINATION="ID_535289114" ENDARROW="Default" ENDINCLINATION="-2880;0;" ID="Arrow_ID_1219325605" SOURCE="ID_1234616959" STARTARROW="None" STARTINCLINATION="1004;61;"/>
|
|
<linktarget COLOR="#d23194" DESTINATION="ID_535289114" ENDARROW="Default" ENDINCLINATION="90;0;" ID="Arrow_ID_186398670" SOURCE="ID_429363053" STARTARROW="None" STARTINCLINATION="110;9;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540639255700" ID="ID_1855001421" MODIFIED="1557498707231" TEXT="Anzeige..">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639285684" ID="ID_1194974667" MODIFIED="1557498707231" TEXT="Scrollen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639289320" ID="ID_1983393978" MODIFIED="1557498707231" TEXT="Rollen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639291974" ID="ID_1116103118" MODIFIED="1557498707231" TEXT="Zoom">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540638842100" ID="ID_202893866" MODIFIED="1557498707231" TEXT="Track...">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638853648" ID="ID_1229923831" MODIFIED="1557498707231" TEXT="hinzufügen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638857930" ID="ID_1666790008" MODIFIED="1557498707231" TEXT="löschen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1560694757109" ID="ID_46205088" MODIFIED="1560694763764" TEXT="TODO klären">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1560694764824" ID="ID_358602712" MODIFIED="1560694782260" TEXT="inwiefern müssen Kind-Widgets aktiv entfernt werden?"/>
|
|
<node CREATED="1560694869833" ID="ID_1349567495" MODIFIED="1563466899646" TEXT="im Besonderen der DisplayFrame">
|
|
<arrowlink COLOR="#ac8396" DESTINATION="ID_1492670388" ENDARROW="Default" ENDINCLINATION="-473;37;" ID="Arrow_ID_1838431568" STARTARROW="None" STARTINCLINATION="-428;36;"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1560695202385" ID="ID_1396137041" MODIFIED="1560695217396" TEXT="experimentell klären">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638882639" ID="ID_334962853" MODIFIED="1557498707231" TEXT="verschieben">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638923233" ID="ID_841357096" MODIFIED="1557498707231" TEXT="auf/zuklappen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639232287" ID="ID_294651227" MODIFIED="1557498707231" TEXT="Placement">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540638984772" ID="ID_166725122" MODIFIED="1557498707231" TEXT="Marker....">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638991848" ID="ID_822413142" MODIFIED="1557498707231" TEXT="platzieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540638996751" ID="ID_1431308221" MODIFIED="1557498707231" TEXT="verschieben">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639002174" ID="ID_1757448745" MODIFIED="1557498707231" TEXT="entfernen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540639065618" ID="ID_619025500" MODIFIED="1611915198783" TEXT="Clip........">
|
|
<linktarget COLOR="#943868" DESTINATION="ID_619025500" ENDARROW="Default" ENDINCLINATION="-954;73;" ID="Arrow_ID_1146152324" SOURCE="ID_936967290" STARTARROW="None" STARTINCLINATION="-490;51;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639139572" ID="ID_740288619" MODIFIED="1557498707231" TEXT="einfügen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639160480" ID="ID_1171854695" MODIFIED="1557498707231" TEXT="löschen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1540639189634" ID="ID_836956028" MODIFIED="1557498707231" TEXT="mutieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1479434763643" FOLDED="true" HGAP="48" ID="ID_1572413636" MODIFIED="1666372883231" TEXT="Clip" VSHIFT="32">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1479434774138" ID="ID_912862507" MODIFIED="1557498707231" TEXT="Grundlagen">
|
|
<node CREATED="1479434780105" ID="ID_239720378" MODIFIED="1576282358038" TEXT="apperances">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ein Clip hat verschiedene Erscheinungsformen im UI
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Verwende das als Leitgedanke, um das Layout zu entwickeln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1479434831825" ID="ID_975727645" MODIFIED="1557498707231" TEXT="abridged form">
|
|
<node CREATED="1479434845992" ID="ID_609815513" MODIFIED="1557498707231" TEXT="media bin, collapsed fork"/>
|
|
<node CREATED="1479441548335" ID="ID_150470698" MODIFIED="1557498707231" TEXT="icon + ID label"/>
|
|
<node CREATED="1479601640961" ID="ID_191706335" MODIFIED="1557498707231" TEXT="Gtk::Frame"/>
|
|
</node>
|
|
<node CREATED="1479441503085" ID="ID_386209482" MODIFIED="1557498707231" TEXT="compact form">
|
|
<node CREATED="1479441530689" ID="ID_1057853337" MODIFIED="1557498707231" TEXT="timeline default"/>
|
|
<node CREATED="1479441567268" ID="ID_1413366977" MODIFIED="1557498707231" TEXT="rendered content strip + decorations"/>
|
|
<node CREATED="1479601649615" ID="ID_417588278" MODIFIED="1557498707231" TEXT="Gtk::Frame + Gtk::Layout"/>
|
|
</node>
|
|
<node CREATED="1479441519834" ID="ID_1669486876" MODIFIED="1557498707231" TEXT="expanded form">
|
|
<node CREATED="1479441586057" ID="ID_64386373" MODIFIED="1557498707231" TEXT="window with embedded sub-clips"/>
|
|
<node CREATED="1479601667734" ID="ID_1877644742" MODIFIED="1557498707231" TEXT="dto, with recursive embedded sub-clips"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1479442296443" ID="ID_911884433" MODIFIED="1557498707231" TEXT="graceful display degradation">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1479442310537" ID="ID_1849995398" MODIFIED="1557498707231" TEXT="Fall1: wenigstens 1 pixel"/>
|
|
<node CREATED="1479442322359" ID="ID_492785140" MODIFIED="1557498707231" TEXT="Fall2: in diesem Pixel ist content"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480797025150" ID="ID_852148145" MODIFIED="1557498707231" TEXT="verwendet für">
|
|
<node CREATED="1480797029581" ID="ID_1257172627" MODIFIED="1557498707231" TEXT="Clips">
|
|
<node CREATED="1480797161164" ID="ID_1187665675" MODIFIED="1557498707231" TEXT="abridged"/>
|
|
<node CREATED="1480797166355" ID="ID_1788361951" MODIFIED="1557498707231" TEXT="compact"/>
|
|
<node CREATED="1480797170331" ID="ID_174323572" MODIFIED="1557498707231" TEXT="expanded"/>
|
|
</node>
|
|
<node CREATED="1480797032709" ID="ID_597046922" MODIFIED="1557498707231" TEXT="Spuren im Clip"/>
|
|
<node CREATED="1480797036804" ID="ID_418077851" MODIFIED="1557498707231" TEXT="Effekte">
|
|
<node CREATED="1480797067392" ID="ID_1213128633" MODIFIED="1557498707231" TEXT="compact"/>
|
|
<node CREATED="1480797155052" ID="ID_640502487" MODIFIED="1557498707231" TEXT="abridged"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1479601690675" FOLDED="true" ID="ID_542607961" MODIFIED="1679359674772" TEXT="Struktur">
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1479601699057" ID="ID_1130364446" MODIFIED="1557498707231" TEXT="Konflikt mit der UI-Bus-Architektur">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1479601736116" ID="ID_891600328" MODIFIED="1557498707231" TEXT="Bus == Rolle des Controler/Model"/>
|
|
<node CREATED="1479601749946" ID="ID_887287956" MODIFIED="1557498707231" TEXT="Widget == View-Rolle"/>
|
|
</node>
|
|
<node CREATED="1479601765896" ID="ID_1632476975" MODIFIED="1557498707231">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
UI-Bus gilt nur für <b>globale Belange</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1479601788237" ID="ID_1871715779" MODIFIED="1557498707231" TEXT="wichtige neue Unterscheidung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1479601796075" ID="ID_1177606400" MODIFIED="1557498707231" TEXT="Global == in der Session aufgezeichnet"/>
|
|
<node CREATED="1479601807666" ID="ID_1374495669" MODIFIED="1557498707231" TEXT="vs. lokale UI-Mechanik"/>
|
|
<node CREATED="1479601828799" ID="ID_1797519191" MODIFIED="1557498707231" TEXT="Ziel: Subsidiarität für lokale Belange"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1479601884288" HGAP="34" ID="ID_1371609613" MODIFIED="1679362063122" TEXT="Lösungs-Konzept" VSHIFT="18">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1479601889567" ID="ID_1123973572" MODIFIED="1557498707231">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es geht nur um <i>Rollen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1479601907221" ID="ID_286625648" MODIFIED="1557498707231" TEXT="es ist ein Design-Pattern">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1479601925938" ID="ID_22286545" MODIFIED="1557498707231">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das lokale Element muß nur als View <i>fungieren</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1479601945839" ID="ID_254470029" MODIFIED="1557498707231" TEXT="Model-View-Presenter">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1479602306718" ID="ID_359464754" MODIFIED="1611914851717" TEXT="ClipPresenter">
|
|
<arrowlink COLOR="#a34086" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-47;-76;" ID="Arrow_ID_937303144" STARTARROW="None" STARTINCLINATION="-228;43;"/>
|
|
<node CREATED="1479602311740" ID="ID_963961994" MODIFIED="1557498707231" TEXT="Mittelsmann"/>
|
|
<node CREATED="1479602314676" ID="ID_944757170" MODIFIED="1557498707231" TEXT="steht für den Clip"/>
|
|
<node CREATED="1479602319555" ID="ID_1557047586" MODIFIED="1557498707231" TEXT="steuert ein ClipWidget"/>
|
|
<node CREATED="1479602338609" ID="ID_444253818" MODIFIED="1557498707231" TEXT="ClipWidget">
|
|
<node CREATED="1479602341777" ID="ID_1610807382" MODIFIED="1557498707231" TEXT="empfängt DisplayStrategy"/>
|
|
<node CREATED="1479602382195" ID="ID_1504834509" MODIFIED="1557498707231">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann sich selbst
|
|
</p>
|
|
<p>
|
|
transformieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1479602412095" ID="ID_832808487" MODIFIED="1557498707231" TEXT="Frame"/>
|
|
<node CREATED="1479602415654" ID="ID_1358720" MODIFIED="1557498707231" TEXT="Frame + Layout"/>
|
|
<node CREATED="1479602419134" ID="ID_1788706818" MODIFIED="1557498707231" TEXT="sub-Clips im Layout"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538938500754" ID="ID_715902958" MODIFIED="1679362063121" TEXT="Implementierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" FOLDED="true" ID="ID_834517953" MODIFIED="1611957469012" TEXT="ClipPresenter">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_483670351" SOURCE="ID_1570849604" STARTARROW="None" STARTINCLINATION="407;0;"/>
|
|
<linktarget COLOR="#d03a17" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-144;-652;" ID="Arrow_ID_1292343123" SOURCE="ID_867069834" STARTARROW="None" STARTINCLINATION="403;48;"/>
|
|
<linktarget COLOR="#a34086" DESTINATION="ID_834517953" ENDARROW="Default" ENDINCLINATION="-47;-76;" ID="Arrow_ID_937303144" SOURCE="ID_359464754" STARTARROW="None" STARTINCLINATION="-228;43;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1568579757736" ID="ID_1709509664" MODIFIED="1568579767971" TEXT="Bedeutung/Aufgaben">
|
|
<node CREATED="1568579769886" ID="ID_512050563" MODIFIED="1568579787568" TEXT="vermittelt zwischen Modell und Anzeigesteuerung"/>
|
|
<node CREATED="1568579788436" ID="ID_339334267" MODIFIED="1568579815948" TEXT="ClipPresenter ist "der Clip" im Bezug auf Diff und UI-Bus"/>
|
|
<node CREATED="1568579817151" ID="ID_1136229909" MODIFIED="1568579839085" TEXT="ClipPresenter betreibt das tatsächliche ClipWidget als Slave"/>
|
|
<node CREATED="1568579939879" ID="ID_685143843" MODIFIED="1611914607030" TEXT="ClipPresenter kennt einen Display-Frame für die Anzeige">
|
|
<arrowlink COLOR="#598cc8" DESTINATION="ID_633007604" ENDARROW="Default" ENDINCLINATION="-292;0;" ID="Arrow_ID_290509509" STARTARROW="None" STARTINCLINATION="765;42;"/>
|
|
<arrowlink COLOR="#3f67c9" DESTINATION="ID_1043075543" ENDARROW="Default" ENDINCLINATION="210;7;" ID="Arrow_ID_678826417" STARTARROW="None" STARTINCLINATION="199;11;"/>
|
|
</node>
|
|
<node CREATED="1661693443440" ID="ID_107743433" MODIFIED="1661695034015" TEXT="ClipPresenter vermittelt beim Content-Preview-Rendering"/>
|
|
</node>
|
|
<node CREATED="1480741362389" ID="ID_328415412" MODIFIED="1557498707230" TEXT="ClipWidget">
|
|
<node CREATED="1480741370347" ID="ID_1275685315" MODIFIED="1557498707230" TEXT="erzeugen">
|
|
<node COLOR="#338800" CREATED="1611914449590" ID="ID_1043075543" MODIFIED="1678407768845" TEXT="in die Track/Display-Struktur einhängen">
|
|
<arrowlink COLOR="#fd654f" DESTINATION="ID_1270677756" ENDARROW="Default" ENDINCLINATION="-300;38;" ID="Arrow_ID_278984117" STARTARROW="None" STARTINCLINATION="131;-344;"/>
|
|
<linktarget COLOR="#3f67c9" DESTINATION="ID_1043075543" ENDARROW="Default" ENDINCLINATION="210;7;" ID="Arrow_ID_678826417" SOURCE="ID_685143843" STARTARROW="None" STARTINCLINATION="199;11;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471014218" ID="ID_1520693411" MODIFIED="1679359261786" TEXT="Setup und Wiring für Clip-drag">
|
|
<arrowlink COLOR="#3a4d88" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-642;-252;" ID="Arrow_ID_1448328801" STARTARROW="None" STARTINCLINATION="-826;77;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1568580210235" ID="ID_36042409" MODIFIED="1568580212814" TEXT="Verhalten">
|
|
<node CREATED="1568580214139" ID="ID_461989100" MODIFIED="1568580217102" TEXT="passiv....">
|
|
<node CREATED="1568580218145" ID="ID_1698735124" MODIFIED="1568580229519" TEXT="im Hinblick auf die Wahl des Darstellungsformats"/>
|
|
<node CREATED="1568580230888" ID="ID_384933602" MODIFIED="1568580242882" TEXT="im Hinblick auf die Layout- und Anzeigesteuerung"/>
|
|
</node>
|
|
<node CREATED="1661693565527" ID="ID_361309488" MODIFIED="1661693572119" TEXT="vermittelnd.....">
|
|
<node CREATED="1661693573892" ID="ID_554831193" MODIFIED="1661693649780" TEXT="Endpunkt für UI-Signal-Wiring">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aktive Elemente im Clip-Widget lösen UI-Signale aus, die eine abstrahierte Funktion aufrufen — und diese gebundene Funktion (zumindest der Einsprungpunkt) liegt im Clip-Presenter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1661693668281" ID="ID_470989168" MODIFIED="1661693685843" TEXT="sendet dann Command-Nachrichten in den UI-Bus"/>
|
|
<node CREATED="1661695924875" ID="ID_1090402146" MODIFIED="1661696035362" TEXT="kann auch für allgemeine Menü/UI-Aktionen vermitteln">
|
|
<linktarget COLOR="#4b557b" DESTINATION="ID_1090402146" ENDARROW="Default" ENDINCLINATION="-1035;0;" ID="Arrow_ID_1722473168" SOURCE="ID_634897151" STARTARROW="None" STARTINCLINATION="-385;32;"/>
|
|
<node CREATED="1661696072514" ID="ID_1764427475" MODIFIED="1661696199675" TEXT="Verwaltung der pop-Up-Menü(s)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist ein übergreifendes Thema zum UI-Verhalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b75976" DESTINATION="ID_847601277" ENDARROW="Default" ENDINCLINATION="599;-2197;" ID="Arrow_ID_579055023" STARTARROW="None" STARTINCLINATION="945;81;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661693702610" ID="ID_1055135476" MODIFIED="1661693718279" TEXT="empfängt Inhalts- und Metadaten-Änderungen als Nachricht per UI-Bus"/>
|
|
<node CREATED="1661695087724" ID="ID_1578237138" MODIFIED="1661695191411" TEXT="stellt bei Bedarf die Verbindung her zu einem Placement-UI">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Placement-UI wird z.B. durch Klick auf das Placement-Icon aktiviert — aber es kann auch <i>modal gemacht werden, </i>und dann wird es in ein Property-Box/Grid-UI alloziert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1661693729872" ID="ID_1318749773" MODIFIED="1661693884693" TEXT="Koordiniert das Preview-Rendering vom Clip-Content">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1661693756725" ID="ID_610729215" MODIFIED="1661693776364" TEXT="komplexes Thema ⟹ später">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1661693786231" ID="ID_439776533" MODIFIED="1661693870436" TEXT="vorerst/anfangs zeigt das Clip-Widget einen Content-Platzhalter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dieser muß einfach lokal im UI zu realisieren sein, also ein Stock-Icon und ggfs ein Vektorgraphic-Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1568587417811" ID="ID_525225515" MODIFIED="1568587421270" TEXT="Beziehungen">
|
|
<node CREATED="1568587422690" ID="ID_1184376218" MODIFIED="1568587435748" TEXT="vollkommene Herrschaft über das ClipWidget"/>
|
|
<node CREATED="1568587448231" ID="ID_1753498057" MODIFIED="1568587484879" TEXT="DisplayManager bestimmt über den Darstellungs-Stil">
|
|
<node CREATED="1568587486002" ID="ID_983778450" MODIFIED="1568587492401" TEXT="bidirektionale Beziehung!"/>
|
|
<node CREATED="1568587493345" ID="ID_1580477403" MODIFIED="1568587506515" TEXT="ClipPresenter muß Darstellungsstil kennen"/>
|
|
<node CREATED="1568587508479" ID="ID_846594106" MODIFIED="1568587523871" TEXT="DisplayManager muß Darstellungsstil auch nachträglich ändern können">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1568587562714" ID="ID_178330712" MODIFIED="1568587573965" TEXT="muß er den zugehörigen Track kennen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1568587576213" ID="ID_1892967536" MODIFIED="1568587597423" TEXT="Clip-Widget muß letztlich an die richtige Position kommen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480741386769" ID="ID_1808095573" MODIFIED="1557498707230" TEXT="Kinder">
|
|
<node CREATED="1480741389777" ID="ID_1548768233" MODIFIED="1557498707230" TEXT="welche kommen in Frage">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1480741397880" ID="ID_299590632" MODIFIED="1557498707230" TEXT="Effekte werden als ClipPresenter implementiert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1480741425668" ID="ID_826648354" MODIFIED="1576282358039" TEXT="Labels werden als eigenes Tangible MarkerWidget implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sie verwenden dann ein LabelWidget zur Darstellung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1480741466519" ID="ID_29080454" MODIFIED="1557498707230" TEXT="das werden zwei Collections">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611953921264" FOLDED="true" ID="ID_1906679490" MODIFIED="1611957488186" TEXT="Clip-Delegate">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1611953928847" ID="ID_1673338897" MODIFIED="1611957494335" TEXT="zunächst einmal ein PImpl">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1611953939576" ID="ID_293462928" MODIFIED="1611953949625" TEXT="vom ClipPresenter her gesehen ein Interface"/>
|
|
<node CREATED="1611954093314" ID="ID_962423794" MODIFIED="1611954107569" TEXT="erlaubt Umschalten des Anzeige-Modus"/>
|
|
<node CREATED="1611953963818" ID="ID_1698628993" MODIFIED="1611953976829" TEXT="hängt als Slave am ClipPresenter"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611954113609" ID="ID_814561596" MODIFIED="1611959535616" TEXT="Clip-Daten-Storage">
|
|
<linktarget COLOR="#70365f" DESTINATION="ID_814561596" ENDARROW="Default" ENDINCLINATION="-427;-565;" ID="Arrow_ID_1226103397" SOURCE="ID_866053960" STARTARROW="None" STARTINCLINATION="805;58;"/>
|
|
<node CREATED="1611954160033" ID="ID_327901028" MODIFIED="1611954175455" TEXT="hängt stark vom Nutzungsmuster ab">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611954178655" ID="ID_895957324" MODIFIED="1611957398393" TEXT="und dieses kennen wir noch nicht">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611954223338" ID="ID_184379518" MODIFIED="1611954237793" TEXT="Daten-Duplikation und häufiges Kopieren vermeiden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611954240824" ID="ID_1048238324" MODIFIED="1611957379318" TEXT="1.Entwurf: Datencontainer als Basisklasse">
|
|
<linktarget COLOR="#82b7c6" DESTINATION="ID_1048238324" ENDARROW="Default" ENDINCLINATION="-451;461;" ID="Arrow_ID_22542364" SOURCE="ID_1850041925" STARTARROW="None" STARTINCLINATION="-209;-7;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611954259205" ID="ID_596924875" MODIFIED="1611954280703" TEXT="damit gibt es dann immer nur eine Allokation"/>
|
|
<node COLOR="#338800" CREATED="1611954666544" ID="ID_1268124709" MODIFIED="1611957366432" TEXT="Datencontainer-Klasse moveable machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1611954396933" ID="ID_1771085068" MODIFIED="1611954498300" TEXT="Alternative wäre: Datencontainer per Pointer anhängen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
diese Alternative würde dann attraktiv, wenn es häufig vorkommt, daß zwischen einem Clip-Widget und einer anderen Repräsentation des ClipDelegate dynamisch hin- und hergeschaltet werden muß. Weil man dann den relativ schwergewichtigen Datencontainer einfach umhängen könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969027570" ID="ID_508866033" MODIFIED="1665969148445" TEXT="Medien-Typ über ctor entgegennehmen">
|
|
<linktarget COLOR="#a55386" DESTINATION="ID_508866033" ENDARROW="Default" ENDINCLINATION="270;19;" ID="Arrow_ID_591115346" SOURCE="ID_1751225815" STARTARROW="None" STARTINCLINATION="294;-18;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" FOLDED="true" ID="ID_1240926804" MODIFIED="1557498707230" TEXT="Clip-Anzeige">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_1240926804" ENDARROW="Default" ENDINCLINATION="-1142;35;" ID="Arrow_ID_435369727" SOURCE="ID_1131206858" STARTARROW="None" STARTINCLINATION="394;108;"/>
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_1240926804" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_1799878244" SOURCE="ID_632606530" STARTARROW="None" STARTINCLINATION="933;139;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1541095839946" ID="ID_471098853" MODIFIED="1557498707231" TEXT="Anzeigestil">
|
|
<linktarget COLOR="#50457a" DESTINATION="ID_471098853" ENDARROW="Default" ENDINCLINATION="-144;-446;" ID="Arrow_ID_49809880" SOURCE="ID_682261661" STARTARROW="None" STARTINCLINATION="-439;32;"/>
|
|
<node CREATED="1538940683586" ID="ID_1478100178" MODIFIED="1557498707231" TEXT="placeholder"/>
|
|
<node CREATED="1538940686978" ID="ID_1747675588" MODIFIED="1557498707231" TEXT="abridged"/>
|
|
<node CREATED="1538940690154" ID="ID_1132412756" MODIFIED="1661694144478" TEXT="compact"/>
|
|
<node CREATED="1538940692545" ID="ID_1827979765" MODIFIED="1557498707231" TEXT="expanded"/>
|
|
</node>
|
|
<node CREATED="1541095848871" ID="ID_1480696061" MODIFIED="1557498707231" TEXT="Anzeige-Modi">
|
|
<node CREATED="1541095855984" ID="ID_1437927701" MODIFIED="1557498707231" TEXT="verwendet ElementBoxWidget">
|
|
<arrowlink COLOR="#f6cca4" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-599;39;" ID="Arrow_ID_703893400" STARTARROW="None" STARTINCLINATION="42;-316;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584229399430" FOLDED="true" ID="ID_1431813131" MODIFIED="1665962034569" TEXT="Logik zur Auswahl des Anzeigestils">
|
|
<linktarget COLOR="#772c4f" DESTINATION="ID_1431813131" ENDARROW="Default" ENDINCLINATION="-428;-554;" ID="Arrow_ID_144365857" SOURCE="ID_1275311433" STARTARROW="None" STARTINCLINATION="298;32;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="flag"/>
|
|
<node CREATED="1584229415906" ID="ID_153053846" MODIFIED="1584229421096" TEXT="ist teilweise generisch">
|
|
<node CREATED="1584229508960" ID="ID_1415254796" MODIFIED="1584229544527" TEXT="ausreichend spezifiziert für eine Anzeige"/>
|
|
<node CREATED="1584229545211" ID="ID_1361609374" MODIFIED="1584229556397" TEXT="zumindest die Zeitspanne muß feststellbar sein">
|
|
<node CREATED="1584229568528" ID="ID_890807423" MODIFIED="1584229573721" TEXT="lib::TimeSpan"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584229557893" ID="ID_1779361600" MODIFIED="1584229577271" TEXT="Spezialfall "alles"">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1584229580470" ID="ID_1095483529" MODIFIED="1584229645233" TEXT="Effekt/Medienspur">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...diese erstreckt sich typischerweise über die gesamte Länge des umschließenden Containers, und paßt sich dieser ohne weiteres dynamisch an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1584229601787" ID="ID_4294703" MODIFIED="1584229614293" TEXT="Unterschied zwischen "unbekannt" und "nicht limitiert"">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584229422204" ID="ID_184368820" MODIFIED="1665962050770" TEXT="teilweise abhängig von äußeren Vorgaben">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1584229436514" ID="ID_973243748" MODIFIED="1584229447389" TEXT="Zoom und Anzeimodus global"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584229448099" ID="ID_63120870" MODIFIED="1584229493037" TEXT="Fallunterscheidung">
|
|
<linktarget COLOR="#a92d35" DESTINATION="ID_63120870" ENDARROW="Default" ENDINCLINATION="246;-353;" ID="Arrow_ID_973658371" SOURCE="ID_1146096669" STARTARROW="None" STARTINCLINATION="392;20;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1584229452911" ID="ID_1237351867" MODIFIED="1584229457411" TEXT="Clip auf Track"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584229458191" ID="ID_911164271" MODIFIED="1584318715606" TEXT="Effekt / Medienspur im clip">
|
|
<icon BUILTIN="flag"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1584318674620" ID="ID_789719668" MODIFIED="1584318732864" TEXT="noch TOTAL ungeklärt">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1584318680419" ID="ID_1709596760" MODIFIED="1584318690915" TEXT="TODO: brauche nested Canvas-ViewHook">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611124813478" ID="ID_107886915" MODIFIED="1611124859455">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aufgabe: wie geht man mit einem Anzeigestil um, der den Effkt<i> gar nicht</i>  darstellt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584319635024" ID="ID_1833569495" MODIFIED="1665960817265" TEXT="Logik im Detail ausimplementieren">
|
|
<linktarget COLOR="#4768d0" DESTINATION="ID_1833569495" ENDARROW="Default" ENDINCLINATION="943;-75;" ID="Arrow_ID_416244548" SOURCE="ID_1737560927" STARTARROW="None" STARTINCLINATION="207;23;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1585012756014" HGAP="67" ID="ID_1256841575" MODIFIED="1585012768478" TEXT="konzeptionell...." VSHIFT="-6">
|
|
<node CREATED="1585012775180" HGAP="101" ID="ID_1578039290" MODIFIED="1585012804301" TEXT="Modus vs Stil" VSHIFT="13">
|
|
<node CREATED="1585012812495" ID="ID_112398937" MODIFIED="1585012828657" TEXT="Modus ist die grundlegende Form">
|
|
<node CREATED="1585012830612" ID="ID_1153727552" MODIFIED="1585012839351" TEXT="verborgen (Datencontainer)"/>
|
|
<node CREATED="1585012840187" ID="ID_313601159" MODIFIED="1585012848078" TEXT="individuelle Anzeige"/>
|
|
<node CREATED="1585012848975" ID="ID_1618567382" MODIFIED="1585012862104" TEXT="Teil einer Übersichtsgraphik"/>
|
|
</node>
|
|
<node CREATED="1585012925784" ID="ID_1875100027" MODIFIED="1585012968430" TEXT="Modus entscheidet über das Delegate"/>
|
|
<node CREATED="1585012969538" ID="ID_623305880" MODIFIED="1585012977855" TEXT="das Delegate entscheidet über den Stil"/>
|
|
</node>
|
|
<node CREATED="1585013243486" HGAP="65" ID="ID_1462532047" MODIFIED="1585013261423" TEXT="Ordnung der Modi" VSHIFT="4">
|
|
<node CREATED="1585013262627" ID="ID_1902435778" MODIFIED="1585013271278" TEXT="ist nicht linear-parametrisch"/>
|
|
<node CREATED="1585013272098" ID="ID_1116174873" MODIFIED="1585013276773" TEXT="sondern eine Verzweigung">
|
|
<node CREATED="1585013324819" ID="ID_152773896" MODIFIED="1585013334819" TEXT="könnte auch noch komplexer werden"/>
|
|
<node CREATED="1585013335575" ID="ID_1950230557" MODIFIED="1585013822494" TEXT="es sind wenige, und essentiell festgelegte">
|
|
<arrowlink COLOR="#653773" DESTINATION="ID_645312696" ENDARROW="Default" ENDINCLINATION="114;0;" ID="Arrow_ID_192929536" STARTARROW="Default" STARTINCLINATION="139;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1585010903183" FOLDED="true" ID="ID_1658829752" MODIFIED="1665960800978" TEXT="Kernfragen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1585010871688" ID="ID_1289641734" MODIFIED="1585010901339" TEXT="wer entscheidet über den möglichen Stil?">
|
|
<node CREATED="1585011007329" ID="ID_1945212792" MODIFIED="1585928197710" TEXT="die Factory">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1585013037644" ID="ID_765039376" MODIFIED="1585928217290" TEXT="das geht zwar immer">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1585013043104" ID="ID_645312696" MODIFIED="1585013815190" TEXT="..würde aber die Logik fest verdrahten">
|
|
<linktarget COLOR="#653773" DESTINATION="ID_645312696" ENDARROW="Default" ENDINCLINATION="114;0;" ID="Arrow_ID_192929536" SOURCE="ID_1950230557" STARTARROW="Default" STARTINCLINATION="139;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1585011013867" ID="ID_1777393889" MODIFIED="1585011031594" TEXT="Methode im Basis-Delegate">
|
|
<linktarget COLOR="#6bd6de" DESTINATION="ID_1777393889" ENDARROW="Default" ENDINCLINATION="-24;52;" ID="Arrow_ID_1626468139" SOURCE="ID_418040349" STARTARROW="None" STARTINCLINATION="106;6;"/>
|
|
<node CREATED="1585013060956" ID="ID_1696216374" MODIFIED="1585013076512" TEXT="kann nur den Zugang zum Modus weisen"/>
|
|
<node CREATED="1585013104936" ID="ID_280575875" MODIFIED="1585013115674" TEXT="kann aber ekennen, ob das Delgate wechselt"/>
|
|
</node>
|
|
<node CREATED="1585011032442" ID="ID_1163292905" MODIFIED="1585011037825" TEXT="das konkrete Delegate?">
|
|
<node CREATED="1585013118735" ID="ID_1852369137" MODIFIED="1585013129889" TEXT="nur dieses kennt die Feinheiten des Stils"/>
|
|
<node CREATED="1585013162456" ID="ID_1644140186" MODIFIED="1585013172896" TEXT="und justiert diese in einer virtuellen Methode"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1585010936491" ID="ID_418040349" MODIFIED="1585013943024" TEXT="wer entscheidet über den konkreten Delegate-Typ?">
|
|
<arrowlink COLOR="#6bd6de" DESTINATION="ID_1777393889" ENDARROW="Default" ENDINCLINATION="-24;52;" ID="Arrow_ID_1626468139" STARTARROW="None" STARTINCLINATION="106;6;"/>
|
|
</node>
|
|
<node CREATED="1585013943839" ID="ID_1056640354" MODIFIED="1585013970000" TEXT="kann ein bereits eingeschlagener Weg abelehnt werden?">
|
|
<node CREATED="1585013977195" ID="ID_727500697" MODIFIED="1585013993925" TEXT="d.h. wer prüft die Mindestanforderungen?">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1585931039924" ID="ID_29030858" MODIFIED="1585931110002" TEXT="Problem Mindestlänge">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1585931060297" ID="ID_1656250390" MODIFIED="1585931069044" TEXT="eigentlich ein generisches Kriterium"/>
|
|
<node CREATED="1585931069824" ID="ID_432040203" MODIFIED="1585931078051" TEXT="tritt aber repliziert auf Blatt-Ebene auf"/>
|
|
<node CREATED="1585931078903" ID="ID_702074103" MODIFIED="1585931095124" TEXT="Gefahr der massiven Daten-Duplikation"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1585928556619" ID="ID_1959943787" MODIFIED="1585928560215" TEXT="Kriterien">
|
|
<node CREATED="1585928575585" ID="ID_1181266579" MODIFIED="1585928581974" TEXT="individueller Clip">
|
|
<node CREATED="1585928654303" ID="ID_1323996178" MODIFIED="1585928665049" TEXT="hat Startpunkt"/>
|
|
<node CREATED="1585928673364" ID="ID_1131131049" MODIFIED="1585928737490" TEXT="Mindestlänge"/>
|
|
</node>
|
|
<node CREATED="1585928582857" ID="ID_1870451258" MODIFIED="1585928588716" TEXT="Teil einer Übersicht">
|
|
<node CREATED="1585930006760" ID="ID_1545926932" MODIFIED="1585930010979" TEXT="hat Startpunkt"/>
|
|
<node CREATED="1585931000122" ID="ID_121156248" MODIFIED="1585931009316" TEXT="Wunsch oder Pin auf diesen Modus"/>
|
|
</node>
|
|
<node CREATED="1585928596439" ID="ID_1983527574" MODIFIED="1585928606156" TEXT="sonst: Datencontainer">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1585010953762" ID="ID_236488907" MODIFIED="1585010961491" TEXT="wer baut/klont ein Delegate?">
|
|
<node CREATED="1611120913617" ID="ID_187744399" MODIFIED="1611120932339" TEXT="...hier zunächst einfache Lösung verfolgt">
|
|
<node CREATED="1611120934086" ID="ID_1626846671" MODIFIED="1611120949303" TEXT="das ClipDelegate (Basisklasse)"/>
|
|
<node CREATED="1612028377220" ID="ID_289156345" MODIFIED="1612028395368" TEXT="...im Moment gefällt mir diese Lösung sogar ganz gut">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1665960687878" ID="ID_1888787380" MODIFIED="1665960788984">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Stand 10/22</u> : Fragen grundsätzlich geklärt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1665960703226" ID="ID_1725010150" MODIFIED="1665960713388" TEXT="Implementierungs-Logik ist gut lesbar"/>
|
|
<node CREATED="1665960749212" ID="ID_1674197078" MODIFIED="1665960776942" TEXT="noch fehlende Strukturen wird die Praxis aufzeigen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1665960714097" ID="ID_1314523478" MODIFIED="1665960733439" TEXT="der Fall der Übersichts-Anzeige ist auf später vertagt">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1585924331517" HGAP="27" ID="ID_1558559501" MODIFIED="1585924351368" TEXT="state pattern" VSHIFT="26">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1585924411195" ID="ID_1837360138" MODIFIED="1585924430097" TEXT="das Clip-Delegate ist eine natürliche State-Repräasentation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1585924431448" ID="ID_1611710777" MODIFIED="1585924442213" TEXT="Schwachstelle: state handling API">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1585924446046" ID="ID_554920835" MODIFIED="1585924462752" TEXT="dieses wird auf äußerer/innerer Kapsel aufgedoppelt"/>
|
|
<node CREATED="1585924468627" ID="ID_1944983930" MODIFIED="1585924475997" TEXT="was brauchen wir hier für Operationen?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612028431732" ID="ID_1246129167" MODIFIED="1612028851514" TEXT="Implementierungsdetails">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1612028439450" ID="ID_1104410954" MODIFIED="1612028458261" TEXT="die Entscheidungslogik wird in der generischen ClipDelegate-Implementierung untergebracht"/>
|
|
<node CREATED="1612028459191" ID="ID_1113891567" MODIFIED="1612028476585" TEXT="auf absehbare Zeit ist diese Logik recht einfach"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1665960835432" ID="ID_687668284" MODIFIED="1665960869210" TEXT="komplexere Themen vertagt (Medienspuren, Effekte, Übersicht)">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612028487004" ID="ID_619535893" MODIFIED="1612030600973" TEXT="spezielle Konvention: start == Time::NEVER ⟹ Appearance::PENDING">
|
|
<linktarget COLOR="#4663c4" DESTINATION="ID_619535893" ENDARROW="Default" ENDINCLINATION="-1983;81;" ID="Arrow_ID_309098301" SOURCE="ID_592528621" STARTARROW="None" STARTINCLINATION="631;32;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969056112" ID="ID_993785590" MODIFIED="1665969090871" TEXT="Umgang mit dem Medien-Typ (#1251)">
|
|
<linktarget COLOR="#d7407e" DESTINATION="ID_993785590" ENDARROW="Default" ENDINCLINATION="-434;31;" ID="Arrow_ID_699706289" SOURCE="ID_1632230778" STARTARROW="None" STARTINCLINATION="137;-25;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969172803" ID="ID_1892015467" MODIFIED="1665969185904" TEXT="Übersetung in Typ-Parameter für ElementBoxWidget">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665969187006" ID="ID_207274074" MODIFIED="1665969332390" TEXT="aber auch: Auswahl der Anzeige-Strategy im Detail">
|
|
<arrowlink COLOR="#e36874" DESTINATION="ID_405495257" ENDARROW="Default" ENDINCLINATION="-2189;115;" ID="Arrow_ID_127305949" STARTARROW="None" STARTINCLINATION="928;-50;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1584319522106" ID="ID_600779996" MODIFIED="1665962000322" TEXT="Vorsicht Falle: Kopieren beim Wechsel des Anzeigestils">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1584319543957" ID="ID_615255607" MODIFIED="1584319606901" TEXT="erst den alten ClipDelegate vom smart-Ptr abkoppeln">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1584319564342" ID="ID_1748945736" MODIFIED="1584319609077" TEXT="denn den neuen per Copy-Initialisierung erzeugen">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1584319578712" ID="ID_1036218022" MODIFIED="1584319612171" TEXT="dann den alten ClipDelegate verwerfen">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1584319587975" ID="ID_609955363" MODIFIED="1665962012480" TEXT="und das alles per smart-Ptr abgesichert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661693939894" ID="ID_498333619" MODIFIED="1661693947269" TEXT="Aufgaben / Anforderungen">
|
|
<node CREATED="1661693951292" ID="ID_92526598" MODIFIED="1661693963022" TEXT="sichtbarer Rahmen mit präziser Länge"/>
|
|
<node CREATED="1661693966450" ID="ID_1491933608" MODIFIED="1661693986619" TEXT="Menü+Label in Sicht halten (bei Scrolling)"/>
|
|
<node CREATED="1661693992375" ID="ID_892363221" MODIFIED="1661694009584" TEXT="Bindings für Menü + ggfs.Standard-Aktion">
|
|
<node CREATED="1661695952095" ID="ID_355417196" MODIFIED="1661695968945" TEXT="(Pop-up) Menü"/>
|
|
<node CREATED="1661695972709" ID="ID_348063726" MODIFIED="1661695981528" TEXT="kontextsensitive Aktions-Button"/>
|
|
<node CREATED="1661695983467" ID="ID_634897151" MODIFIED="1661696042865" TEXT="⟹ werden via Presenter vermittelt">
|
|
<arrowlink COLOR="#4b557b" DESTINATION="ID_1090402146" ENDARROW="Default" ENDINCLINATION="-1035;0;" ID="Arrow_ID_1722473168" STARTARROW="None" STARTINCLINATION="-385;32;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661694023197" ID="ID_1963221274" MODIFIED="1661694032933" TEXT="Registrierung von/mit Gesten-Controllern"/>
|
|
<node CREATED="1661694049166" ID="ID_68957599" MODIFIED="1661694057265" TEXT="Content-Rendering">
|
|
<node CREATED="1661694058286" ID="ID_1358424088" MODIFIED="1661694080438" TEXT="abridged: nur Farbe/Stil"/>
|
|
<node CREATED="1661694156704" ID="ID_389557944" MODIFIED="1661694179001" TEXT="compact: Farbe + Platzhalter / Preview optional"/>
|
|
<node CREATED="1661694180301" ID="ID_962010212" MODIFIED="1661694231410" TEXT="expanded: Canvas ⟹ Content-Display delegiert an nested Widgets"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679072452752" ID="ID_1508246286" MODIFIED="1679072579066" TEXT="TODO: Ausdehnung und vertikalen Offset des Clip tatsächlich steuern">
|
|
<linktarget COLOR="#ff4275" DESTINATION="ID_1508246286" ENDARROW="Default" ENDINCLINATION="1281;-45;" ID="Arrow_ID_1210551190" SOURCE="ID_698148454" STARTARROW="None" STARTINCLINATION="515;46;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583102068949" ID="ID_1157479559" MODIFIED="1583102075826" TEXT="Probleme / Entscheidungen">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1583102099206" ID="ID_1626144230" MODIFIED="1679065446533" TEXT="Umgang mit einem Clip-Header">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was ist das?
|
|
</p>
|
|
<p>
|
|
Wenn ein Clip mehrere Spuren oder Datenströme oder sonst irgend eine Art innerer Struktur trägt, dann braucht man irgendwann einen vom Zeitpunkt unabhängigen »Kopf-Bereich«, um die Struktur zu steuern und zu manipulieren. Für die Tracks gibt es dafür einen eigenen "patchbay"-Bereich links von der Timeline-Anzeige. Aber für die Clips ist nicht klar
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
ob wir das wirklich brauchen
|
|
</li>
|
|
<li>
|
|
wo wir es anordnen
|
|
</li>
|
|
<li>
|
|
und wie wir mit Clips umgehen, die weit über das Anzeigefenster hinsausreichen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#9a5670" DESTINATION="ID_1054753498" ENDARROW="Default" ENDINCLINATION="-3448;194;" ID="Arrow_ID_948617682" STARTARROW="None" STARTINCLINATION="1004;81;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1679065449777" HGAP="47" ID="ID_33601627" MODIFIED="1679065611000" STYLE="fork" TEXT="3/23 noch offenes Problem zur Entscheidung" VSHIFT="11">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Und zwar geht es hier um eine sehr grundsätzliche Layout /
|
|
Design-Entscheidung, die auch sehr starken Einfluß auf den Workflow und
|
|
die »Mechanik« der Clips haben wird; <i>im aktuellen Stand
|
|
(2023) der Entwicklung habe ich nicht den Boden, um diese Enstscheidung
|
|
treffen zu können </i>��
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1586383134447" ID="ID_415124968" MODIFIED="1586383138432" TEXT="Clip-Timings">
|
|
<node CREATED="1586383139624" ID="ID_683488370" MODIFIED="1586383149522" TEXT="gegeben als TimeSpan"/>
|
|
<node CREATED="1586383150821" ID="ID_51987562" MODIFIED="1586383287858" TEXT="Übersetzung in Pixel ist rein Client-seitig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zoomen, Scrollen, Scroll-Window und View-Path sind reine Gui-Bildungen und werden instantan ohne Round-Trip realisiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#821a26" CREATED="1586383188716" ID="ID_1268226317" MODIFIED="1586383420749" TEXT="muß daher komplett im Clip gespeichert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#e12e2e"><b>Vorsicht Falle</b></font>: es reicht nicht, nur die auf Pixel quantisierte Position zu speichern, denn diese wird bei geringem Zoom relativ ungenau. Es wäre leicht möglich, durch Heraus- und wieder Hereinscrollen die sichtbare Position eines Clip massiv zu verschieben.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1541861481967" ID="ID_552550333" MODIFIED="1666451358766" TEXT="Problem: Metrik auf dem Canvas">
|
|
<arrowlink COLOR="#2a79c1" DESTINATION="ID_1038931568" ENDARROW="Default" ENDINCLINATION="-511;19;" ID="Arrow_ID_405016415" STARTARROW="None" STARTINCLINATION="-1360;-43;"/>
|
|
<linktarget COLOR="#5276de" DESTINATION="ID_552550333" ENDARROW="Default" ENDINCLINATION="203;16;" ID="Arrow_ID_54504759" SOURCE="ID_103620026" STARTARROW="None" STARTINCLINATION="-66;-259;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1666451389394" ID="ID_511046839" MODIFIED="1666451403226" TEXT="Anfrage wird aus der GTK-Layoutbehandlung getriggert">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1666451404745" ID="ID_1685238185" MODIFIED="1666451415979" TEXT="Clip muß seine eigene Ausdehnung festsetzen können"/>
|
|
<node CREATED="1666451422758" ID="ID_1448482248" MODIFIED="1666451488041">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Lösung</u>: Interface <font face="Monospaced"><b>DisplayMetric</b></font> im <font face="Monospaced" color="#1e128f">CanvasHook</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1666451523988" HGAP="57" ID="ID_244578537" MODIFIED="1675897253036" TEXT="Implementierung: liegt im TimelineLayout (opaque)" VSHIFT="-8">
|
|
<arrowlink COLOR="#3c4864" DESTINATION="ID_1202075896" ENDARROW="Default" ENDINCLINATION="-1351;104;" ID="Arrow_ID_1210722108" STARTARROW="None" STARTINCLINATION="-74;-277;"/>
|
|
<linktarget COLOR="#644d8a" DESTINATION="ID_244578537" ENDARROW="Default" ENDINCLINATION="-220;12;" ID="Arrow_ID_7428365" SOURCE="ID_1827001710" STARTARROW="None" STARTINCLINATION="55;-63;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1672679706488" HGAP="34" ID="ID_824353880" MODIFIED="1672679719594" TEXT="Anforderungen" VSHIFT="1">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1672679774855" ID="ID_1101197260" MODIFIED="1672679787848" TEXT="beliebige Zeit in absolute Pixel-Pos übersetzen"/>
|
|
<node CREATED="1672679806161" ID="ID_1865833486" MODIFIED="1672679824547" TEXT="relativen Offset / Ausdehnung in Pixel-Zahl übersetzen"/>
|
|
<node CREATED="1672679826392" ID="ID_1729893363" MODIFIED="1672679848861" TEXT="explizit gegebenen Pixel-Offset in ein Zeit-Δ übersetzen"/>
|
|
<node CREATED="1672680113722" ID="ID_411598486" MODIFIED="1672680137577" TEXT="Domäne / Canvas-Bereich in Pixel-Koordinaten übersetzen">
|
|
<node CREATED="1672680147413" ID="ID_1912182961" MODIFIED="1672680162863" TEXT="für AbstractTrackRenderer::visible_"/>
|
|
<node CREATED="1672680203512" ID="ID_1802952569" MODIFIED="1672680209657" TEXT="BodyCanvasWidget::establishLayout (DisplayEvaluation&)">
|
|
<node CREATED="1672680242305" ID="ID_1540246434" MODIFIED="1672680249988" TEXT="BodyCanvasWidget::adjustCanvasSize(int canvasWidth, int contentHeight, int rulerHeight)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672694819791" ID="ID_1304491361" MODIFIED="1672694834368" TEXT="Canvas-Ursprung bleibt implizit">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1672694860846" ID="ID_1013198591" MODIFIED="1672694871984" TEXT="sollte negative Pixel-Werte vermeiden"/>
|
|
<node CREATED="1672694872852" ID="ID_428750573" MODIFIED="1672694887285" TEXT="sollte dem (technischen) Ursprung entsprechen"/>
|
|
<node CREATED="1672694948622" ID="ID_795049630" LINK="#ID_1323685955" MODIFIED="1672695119697" TEXT="rein interner Belang der Zeichen-Routinen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Pixel-Koordinaten sind ein rein interner Belang für die Zeichen-Routinen; insofern genügt es, wenn die Umwandlungsfunktion stets einen konsistenten Ursprung liefert, sich aber auch sinngemäß an verändertetes Timeline-Layout anpaßt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665968722004" ID="ID_1632230778" MODIFIED="1665969102137" TEXT="#1251 specify Clip media type for the UI">
|
|
<arrowlink COLOR="#d7407e" DESTINATION="ID_993785590" ENDARROW="Default" ENDINCLINATION="-434;31;" ID="Arrow_ID_699706289" STARTARROW="None" STARTINCLINATION="137;-25;"/>
|
|
<linktarget COLOR="#bb4f76" DESTINATION="ID_1632230778" ENDARROW="Default" ENDINCLINATION="-986;67;" ID="Arrow_ID_1432405411" SOURCE="ID_865599543" STARTARROW="None" STARTINCLINATION="-1713;-126;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665968963166" ID="ID_1751225815" MODIFIED="1665969148445" TEXT="sollte schon sofort über den ctor möglich sein">
|
|
<arrowlink COLOR="#a55386" DESTINATION="ID_508866033" ENDARROW="Default" ENDINCLINATION="270;19;" ID="Arrow_ID_591115346" STARTARROW="None" STARTINCLINATION="294;-18;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665968975867" ID="ID_1127286532" MODIFIED="1665968988821" TEXT="sollte aber auch später noch änderbar sein">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1661694782421" ID="ID_1828319625" MODIFIED="1661694793230" TEXT="Strategy-Pattern verwenden!">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583678040736" ID="ID_1805643410" MODIFIED="1583678050738" TEXT="Umsetzung">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1583677631958" ID="ID_811510338" MODIFIED="1611479264977" TEXT="vorläufige Clip-Repräsentation">
|
|
<linktarget COLOR="#ab415e" DESTINATION="ID_811510338" ENDARROW="Default" ENDINCLINATION="-975;-81;" ID="Arrow_ID_610185006" SOURCE="ID_214009767" STARTARROW="None" STARTINCLINATION="744;47;"/>
|
|
<linktarget COLOR="#f2d4e1" DESTINATION="ID_811510338" ENDARROW="Default" ENDINCLINATION="-516;-1779;" ID="Arrow_ID_1877167801" SOURCE="ID_1825783827" STARTARROW="None" STARTINCLINATION="481;25;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661610654817" ID="ID_1038790770" MODIFIED="1661610893078" TEXT="#1038 draft clip UI representation">
|
|
<arrowlink COLOR="#541915" DESTINATION="ID_96949358" ENDARROW="Default" ENDINCLINATION="-1458;130;" ID="Arrow_ID_1319876475" STARTARROW="None" STARTINCLINATION="818;-68;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1583678069596" FOLDED="true" ID="ID_749021089" MODIFIED="1665962512413" TEXT="Stufe-1">
|
|
<icon BUILTIN="licq"/>
|
|
<node COLOR="#338800" CREATED="1583678075045" ID="ID_1071916226" MODIFIED="1612439673716" TEXT="erst mal überhaupt einen Block belegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1584318751425" ID="ID_1908104469" MODIFIED="1584318760838" TEXT="nehme mal einen Gtk::Button...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1611539454282" ID="ID_1159321207" MODIFIED="1611539483874" TEXT="Data-Storage: erst mal lauter lokale Datenfelder"/>
|
|
<node COLOR="#338800" CREATED="1611479299338" ID="ID_1803753965" MODIFIED="1612030625987" TEXT="damit die erste lauffähige Clip-Widget-Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611492890873" ID="ID_458756808" MODIFIED="1611492956892" TEXT="sollte in der seit 4/20 existierenden Implementierung bereits funktionieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...habe ich aber noch nie getestet...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611494845768" ID="ID_591566495" MODIFIED="1611540171140" TEXT="erst mal vorläufig die Datenfelder anlegen ⟹ kann vertikale Ausdehnung berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611527884423" ID="ID_1232626344" MODIFIED="1612030654011" TEXT="Ergebnis der DisplayEvaluation ≙ lokales Maximum → TrackBody::contentHeight_ ">
|
|
<arrowlink COLOR="#3b4b73" DESTINATION="ID_1530876056" ENDARROW="Default" ENDINCLINATION="802;689;" ID="Arrow_ID_471691943" STARTARROW="None" STARTINCLINATION="700;24;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583678122516" ID="ID_73602256" MODIFIED="1612439671575" TEXT="...und dessen vertikale Ausdehnung ermitteln und zurückmelden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612439704954" FOLDED="true" ID="ID_102633650" MODIFIED="1665962687088" TEXT="Clip-Parameter → horizontale Ausdehnung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1612471194589" ID="ID_1485158816" MODIFIED="1665962268509" TEXT="mehrere Probleme zu überwinden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1612471205161" ID="ID_544296566" MODIFIED="1665962213180" TEXT="GTK erlaubt keine explizite Größe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist eine grundlegende Design-Enscheidung (und zwar eine Gute), aber in der Praxis muß es natürlich trotzdem einen Weg geben, nur ist der dann relativ indirekt und auch nicht wirklich dokumentiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#a09aae" DESTINATION="ID_1508852681" ENDARROW="Default" ENDINCLINATION="-2048;204;" ID="Arrow_ID_1446927054" STARTARROW="None" STARTINCLINATION="-3602;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#990000" CREATED="1612471458578" ID="ID_611633103" MODIFIED="1612480292438" TEXT="Experiment: genügt der size_request?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1612480298341" ID="ID_1348090876" MODIFIED="1612480308730" TEXT="funktioniert nur zur Vergrößerung"/>
|
|
<node CREATED="1612480309646" ID="ID_1463447127" MODIFIED="1612480315253" TEXT="aber beschneidet nicht"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1612527452448" ID="ID_1007765197" MODIFIED="1665962447036" TEXT="genügt noch nicht: kann nicht beschneiden">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1612527477300" ID="ID_734302531" MODIFIED="1612527498185" TEXT="es funktioniert so bereits, das Widget zu vergrößern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612620409921" ID="ID_643882250" MODIFIED="1663946479492" TEXT="size handling in Framework">
|
|
<arrowlink COLOR="#364ec7" DESTINATION="ID_615948747" ENDARROW="Default" ENDINCLINATION="-1440;0;" ID="Arrow_ID_866144981" STARTARROW="None" STARTINCLINATION="-1942;189;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1612613065268" FOLDED="true" ID="ID_700841626" LINK="https://stackoverflow.com/q/66076682/444796" MODIFIED="1665962160061" TEXT="Frage auf Stackoverflow gestellt">
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1663957087480" ID="ID_9335539" MODIFIED="1663957260417" TEXT="Frage wurde automatisch gelöscht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p http-equiv="content-type" content="text/html; charset=utf-8">
|
|
<strong>If the question is more than <code>365</code> days old, and ...</strong>
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
has a score of 0 or less, <strong>or</strong> a score of 1 and a deleted owner
|
|
</li>
|
|
<li>
|
|
has no answers
|
|
</li>
|
|
<li>
|
|
is not locked
|
|
</li>
|
|
<li>
|
|
has view count <= the age of the question in days times 1.5
|
|
</li>
|
|
<li>
|
|
has 1 or 0 comments
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1663957105414" ID="ID_1623688955" MODIFIED="1663957110606" TEXT="nur 55 Views"/>
|
|
<node CREATED="1663957111175" ID="ID_1833399738" MODIFIED="1663957115320" TEXT="kein Upvote"/>
|
|
<node CREATED="1663957116078" ID="ID_713646207" MODIFIED="1663957119176" TEXT="kein Kommentar"/>
|
|
<node CREATED="1663957119988" ID="ID_1332345095" MODIFIED="1663957122487" TEXT="keine Antwort"/>
|
|
</node>
|
|
<node CREATED="1663957303187" ID="ID_697240020" MODIFIED="1663957310774" TEXT="ist definitiv keine Bösartigkeit"/>
|
|
<node CREATED="1663957264448" ID="ID_642110272" MODIFIED="1663962465341" TEXT="Merke: um "mühsame" Fragen muß man sich kümmern">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612619390361" ID="ID_571017696" MODIFIED="1663955991363" TEXT="nächster Ansatz: get_preferred_width_vfunc">
|
|
<arrowlink COLOR="#77afb6" DESTINATION="ID_321040886" ENDARROW="Default" ENDINCLINATION="-3752;338;" ID="Arrow_ID_765236235" STARTARROW="None" STARTINCLINATION="-3454;-1310;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1612619418068" ID="ID_506962706" MODIFIED="1612619499778" TEXT="auf dem Clip-Widget selber überschrieben"/>
|
|
<node CREATED="1612619434154" ID="ID_1820519135" MODIFIED="1612619499778" TEXT="ignoriert das Kind und liefert den nominellen Wert zurück"/>
|
|
<node CREATED="1612619448816" ID="ID_616104406" MODIFIED="1612620546458" TEXT="funktioniert, aber es gibt eine Menge von Warnungen">
|
|
<linktarget COLOR="#67384d" DESTINATION="ID_616104406" ENDARROW="Default" ENDINCLINATION="-605;33;" ID="Arrow_ID_349418044" SOURCE="ID_548348096" STARTARROW="None" STARTINCLINATION="241;19;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1663955680592" HGAP="19" ID="ID_1517213874" MODIFIED="1663955701843" TEXT="trotzdem: das ist vermutlich der einzige gangbare Weg" VSHIFT="5">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1663955710647" HGAP="23" ID="ID_1436931569" MODIFIED="1663955749454" VSHIFT="17">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil dies die einzige Info ist,
|
|
</p>
|
|
<p>
|
|
welche direkt vom Widget abgefragt wird,
|
|
</p>
|
|
<p>
|
|
im Zuge der Layout-Berechnung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665962384509" ID="ID_1318638341" MODIFIED="1665962423510" TEXT="Ansatz bestätigt → ElementBoxWidget">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612471480502" ID="ID_103620026" MODIFIED="1612480353892" TEXT="Übersetzung Zeit in Pixel">
|
|
<arrowlink COLOR="#5276de" DESTINATION="ID_552550333" ENDARROW="Default" ENDINCLINATION="203;16;" ID="Arrow_ID_54504759" STARTARROW="None" STARTINCLINATION="-66;-259;"/>
|
|
<node CREATED="1612471500084" ID="ID_269480980" MODIFIED="1612474845425" TEXT="eigentlich Aufgabe der Zoom-Steuerung">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612471511450" ID="ID_116082667" MODIFIED="1665962257879" TEXT="Problematisch ist der Zugang">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612471524505" ID="ID_1226213044" MODIFIED="1612471811699" TEXT="Widgets sollen nicht direkt mit dem Layout-Manager reden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ich will nicht, daß der DisplayManager zu bedeutend wird, weil dann eine direkte Manipulation einzelner Widgets durch den DisplayManager als die "einfachste" und "natürlichste" Lösung erscheinen könnte. Dagegen wehre ich mich, weil es zu einer starken Kopplung führt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612471562435" ID="ID_1613228671" MODIFIED="1612471569974" TEXT="abstrahiert über den CanvasHook">
|
|
<node CREATED="1612471572242" ID="ID_1034906351" MODIFIED="1612471577173" TEXT="hatte es dort schön versteckt"/>
|
|
<node CREATED="1612471577749" ID="ID_1723611368" MODIFIED="1612471646979" TEXT="aber anscheinend ist das doch eine API-Funktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt bereits einen <i>Sündenfall,</i> nämlich im RelativeCanvasHook: der muß delegieren, und daher von außen diese Methode aufrufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612471892599" ID="ID_97557081" MODIFIED="1612471918991" TEXT="und noch schlimmer: wir haben jetzt zwei verkettete virtual calls">
|
|
<arrowlink COLOR="#9b3c5a" DESTINATION="ID_735591701" ENDARROW="Default" ENDINCLINATION="-828;79;" ID="Arrow_ID_619578495" STARTARROW="None" STARTINCLINATION="-1537;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612473087980" ID="ID_1089235510" MODIFIED="1612473100872" TEXT="ist dieser Zugangspunkt sinnvoll?">
|
|
<node CREATED="1612473107642" ID="ID_790590091" MODIFIED="1666474893867" TEXT="dafür spricht">
|
|
<node CREATED="1666474895435" ID="ID_1743952496" MODIFIED="1666474895435" TEXT="per Zeit an den Canvas geheftet"/>
|
|
<node CREATED="1612473206764" ID="ID_383710389" MODIFIED="1666475206066" TEXT="Widget kann sich selbst um seine eigene Ausdehnung kümmern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das mag überraschend sein — erst dachte ich, es sein ein Nachteil, aber tatsächlich fügt es sich natürlich in die Layout-Steuerung von GTK ein; denn GTK fragt ja das Widget nach seiner benötigten Ausdehnung, und das ist auch genau der Mechanismus, über den wir eine Beschränkung auf eine vorgegebene zeitliche Ausdehnung realisieren. Zudem hat das Widget die Information über seine eigene Ausdehnung als Zeitangabe vorliegen, und das paßt dann auch gut in dieses Aufrufschema
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612473146517" ID="ID_116246629" MODIFIED="1612473172733" TEXT="dagegen spricht">
|
|
<node CREATED="1612473174072" ID="ID_589866375" MODIFIED="1612473205808" TEXT="bei Zoom-Änderung muß sich das Widget neu anheften"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612474248183" ID="ID_1920258813" MODIFIED="1612474254178" TEXT="Neben-Constraint: Storage">
|
|
<node CREATED="1612474255953" ID="ID_1180938524" MODIFIED="1612474796077" TEXT="den Pointer auf den View habe ich zwangsläufig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das ist eine Konsequenz aus dem Design des Diff-Framework; genauer, aus der konkreten Form, die die Implementierung des Diff-Framework bekommen hat: Und zwar, daß ein generischer Container gebunden wird. Das bedeutet, daß die Elemente im Container wie Werte behandelt werden. Und deshalb müssen sich Widgets selbständig vom Canvas abmelden. Die Alternative dazu wäre, daß der Parent den Diff interpretiert, und seine Kinder direkt manipuliert. Dann wären diese Kinder aber auch Widgets, und nicht nochmal indirekt als Presenter angebunden. Könnte man machen, habe ich aber ein mulmiges Gefühl. Da nehme ich dann doch lieber ein smart-Handle und einen Back-Pointer in Kauf.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612474798393" ID="ID_426717931" MODIFIED="1612474928592" TEXT="jeder andere Service müßte noch zusätzlich verdrahtet werden">
|
|
<arrowlink COLOR="#6377b1" DESTINATION="ID_1343110314" ENDARROW="Default" ENDINCLINATION="33;-52;" ID="Arrow_ID_1779941265" STARTARROW="None" STARTINCLINATION="-154;7;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1612474853633" ID="ID_1343110314" MODIFIED="1612480345782" TEXT="Beschluß: es wird explizit Bestandteil des CanvasHook-API">
|
|
<linktarget COLOR="#7479c0" DESTINATION="ID_1343110314" ENDARROW="Default" ENDINCLINATION="-766;-1697;" ID="Arrow_ID_712594873" SOURCE="ID_859822896" STARTARROW="None" STARTINCLINATION="520;37;"/>
|
|
<linktarget COLOR="#6377b1" DESTINATION="ID_1343110314" ENDARROW="Default" ENDINCLINATION="33;-52;" ID="Arrow_ID_1779941265" SOURCE="ID_426717931" STARTARROW="None" STARTINCLINATION="-154;7;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1612480328315" ID="ID_1469666563" MODIFIED="1612480344504" TEXT="public machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612480333285" ID="ID_435258153" MODIFIED="1612480343249" TEXT="direkt verwenden im RelativeCanvasHook">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612619529157" ID="ID_1950608874" MODIFIED="1665962365176" TEXT="vorläufiger Entwurf: mit einem Button">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1612619554554" ID="ID_548348096" MODIFIED="1612620546458" TEXT="funktioniert erst mal so halbwegs">
|
|
<arrowlink COLOR="#67384d" DESTINATION="ID_616104406" ENDARROW="Default" ENDINCLINATION="-605;33;" ID="Arrow_ID_349418044" STARTARROW="None" STARTINCLINATION="241;19;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1612620549021" ID="ID_351516626" MODIFIED="1665962352755" TEXT="inzwischen im Detail aufgeklärt (‣ElementBoxWidget)">
|
|
<arrowlink COLOR="#6fb9c8" DESTINATION="ID_1826613475" ENDARROW="Default" ENDINCLINATION="1266;110;" ID="Arrow_ID_1550601686" STARTARROW="None" STARTINCLINATION="2230;117;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617888163319" ID="ID_1711872430" MODIFIED="1665962559005" TEXT="vorläufige Impl. für Clip-dragging versuchen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1617888201086" ID="ID_1199769870" MODIFIED="1617888281168" TEXT="das schafft schon mal einen Entwurf für das Framework">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1617888226463" ID="ID_650089378" MODIFIED="1617888281168" TEXT="und erlaubt zugleich, die Struktur des Designs zu überprüfen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617888246955" ID="ID_719593541" MODIFIED="1665962556416" TEXT="zunächst einmal: neuer Anlauf für kontext-bezogene Commands">
|
|
<arrowlink COLOR="#425c68" DESTINATION="ID_1624270915" ENDARROW="Default" ENDINCLINATION="-809;-2134;" ID="Arrow_ID_1181760372" STARTARROW="None" STARTINCLINATION="-299;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1583678162183" ID="ID_798000610" MODIFIED="1666368507250" TEXT="Stufe-2">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1583678167438" ID="ID_342453194" MODIFIED="1583678173531" TEXT="vereinfachte Darstellung"/>
|
|
<node CREATED="1583678176917" ID="ID_1637892152" MODIFIED="1583678182657" TEXT="Vorstufe für "abridged""/>
|
|
<node COLOR="#435e98" CREATED="1612620756065" ID="ID_485594461" MODIFIED="1666368525693" STYLE="fork" TEXT="ElementBoxWidget verwenden....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das EventBoxWidget mußte dazu natürlich erst einmal gebaut werden; dieses ist nämlich im Grunde genommen genau die Abstraktion eines <i>abridged clip... </i>
|
|
</p>
|
|
<p>
|
|
<u>Stand 10/2022</u>: Basis-Implementierung geschaffen <font color="#25d56b">#1219</font> und sieht soweit gut aus...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#406d5c" DESTINATION="ID_368245484" ENDARROW="Default" ENDINCLINATION="-469;652;" ID="Arrow_ID_264431308" STARTARROW="None" STARTINCLINATION="-1674;133;"/>
|
|
<linktarget COLOR="#2082a9" DESTINATION="ID_485594461" ENDARROW="Default" ENDINCLINATION="872;71;" ID="Arrow_ID_1204090343" SOURCE="ID_474563596" STARTARROW="None" STARTINCLINATION="2306;92;"/>
|
|
<node COLOR="#338800" CREATED="1666452299624" HGAP="49" ID="ID_1827001710" MODIFIED="1675897244770" TEXT="Zeit → Pixel Übersetzung" VSHIFT="-13">
|
|
<arrowlink COLOR="#644d8a" DESTINATION="ID_244578537" ENDARROW="Default" ENDINCLINATION="-220;12;" ID="Arrow_ID_7428365" STARTARROW="None" STARTINCLINATION="55;-63;"/>
|
|
<linktarget COLOR="#525d93" DESTINATION="ID_1827001710" ENDARROW="Default" ENDINCLINATION="873;-869;" ID="Arrow_ID_892468806" SOURCE="ID_998825618" STARTARROW="None" STARTINCLINATION="-1738;113;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1675896850015" ID="ID_145894801" MODIFIED="1675896902499" TEXT="indirekt per Interface CanvasHook"/>
|
|
<node CREATED="1675896935547" ID="ID_1938738483" MODIFIED="1675897220295" TEXT="CanvasHook::getMetric()">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1675896996419" ID="ID_1311118876" LINK="#ID_412094029" MODIFIED="1675897215015" TEXT="implementierung delegiert an ZoomWindow">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611539501493" HGAP="38" ID="ID_1849626018" MODIFIED="1665962611640" TEXT="TODO: Überlegungen zur Daten-Storage" VSHIFT="18">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611539517985" ID="ID_1850041925" MODIFIED="1665962618399" TEXT="macht es Sinn, für alle Clip-Anzeigeformen einen gemeinsamen Daten-Record zu verwenden?">
|
|
<arrowlink COLOR="#82b7c6" DESTINATION="ID_1048238324" ENDARROW="Default" ENDINCLINATION="-451;461;" ID="Arrow_ID_22542364" STARTARROW="None" STARTINCLINATION="-209;-7;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611539550821" ID="ID_219259739" MODIFIED="1611539584717" TEXT="und: diesen einbetten, oder per Pointer halten und weitergeben?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1675384884653" ID="ID_1042919827" MODIFIED="1675385087573" TEXT="Lifecycle für Content-Renderer potentiell problematisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da das ElementBoxWidget nicht die ownership für sein Kind-Widget (den ContentRenderer) übernimmt; daher muß das Kind länger leben als das ElementBoxWidget, aber genau das ist <b>nicht gewährleistet</b>, wenn das Clip-Delegate von ElementBoxWidget <b>erbt</b>.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583678206105" ID="ID_1843404430" MODIFIED="1583678219642" TEXT="Stufe-3">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1583678212600" ID="ID_1423004945" MODIFIED="1583678217411" TEXT="Flexibilität einbauen"/>
|
|
</node>
|
|
<node CREATED="1583678222687" ID="ID_789044666" MODIFIED="1583678227642" TEXT="...."/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611479083504" ID="ID_1933989336" MODIFIED="1611479093202" TEXT="vollständige Clip-Repräsentation">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611914931941" ID="ID_22248942" MODIFIED="1611914940429" TEXT="Integration">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1611914946556" ID="ID_1839157029" MODIFIED="1611915226243" TEXT="Einbindung in die Track-Kontrollstruktur">
|
|
<arrowlink COLOR="#aa6852" DESTINATION="ID_604450209" ENDARROW="Default" ENDINCLINATION="-1233;136;" ID="Arrow_ID_186901681" STARTARROW="None" STARTINCLINATION="-480;35;"/>
|
|
</node>
|
|
<node CREATED="1611914988277" ID="ID_1193135800" MODIFIED="1611914995176" TEXT="Einbindung in die Verhaltens-Steuerung"/>
|
|
<node CREATED="1611915139913" ID="ID_936967290" MODIFIED="1611915198783" TEXT="Manipulations-Operationen">
|
|
<arrowlink COLOR="#943868" DESTINATION="ID_619025500" ENDARROW="Default" ENDINCLINATION="-954;73;" ID="Arrow_ID_1146152324" STARTARROW="None" STARTINCLINATION="-490;51;"/>
|
|
</node>
|
|
<node CREATED="1611914955818" ID="ID_1742858971" MODIFIED="1611914964972" TEXT="Anbindung via Diff-Framework"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1476376943985" HGAP="52" ID="ID_1422206856" MODIFIED="1557498707231" TEXT="Viewer" VSHIFT="10">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567087657" ID="ID_621933360" MODIFIED="1680567105120" TEXT="entwickeln">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680564423273" ID="ID_7752918" MODIFIED="1680567145813" TEXT="Video-Display-GUI">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_7752918" ENDARROW="Default" ENDINCLINATION="-612;79;" ID="Arrow_ID_1986887171" SOURCE="ID_1435039515" STARTARROW="None" STARTINCLINATION="-2008;-180;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567169798" ID="ID_1105975184" MODIFIED="1680567175175" TEXT="Play-control">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680567033328" ID="ID_60631732" MODIFIED="1680567036668" TEXT="Infrastruktur">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680565198929" ID="ID_1636806116" MODIFIED="1680567189686" TEXT="Video-Widget">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_1636806116" ENDARROW="Default" ENDINCLINATION="-757;117;" ID="Arrow_ID_820803219" SOURCE="ID_961883511" STARTARROW="None" STARTINCLINATION="-239;41;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680565204949" ID="ID_754563967" MODIFIED="1680567194869" TEXT="OutputManager für Video-Display">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_754563967" ENDARROW="Default" ENDINCLINATION="-691;58;" ID="Arrow_ID_1893379752" SOURCE="ID_962521952" STARTARROW="None" STARTINCLINATION="-230;29;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680567197898" ID="ID_73360951" MODIFIED="1680567628091" TEXT="Integration mit Output-Management (allgemein)">
|
|
<arrowlink COLOR="#fe756b" DESTINATION="ID_1644608240" ENDARROW="Default" ENDINCLINATION="-1507;-562;" ID="Arrow_ID_246148002" STARTARROW="None" STARTINCLINATION="-591;33;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680567513016" ID="ID_1328492043" MODIFIED="1680567618172" TEXT="Grundlage für Medien-Verbindungs-Framework">
|
|
<arrowlink COLOR="#ba4677" DESTINATION="ID_212457558" ENDARROW="Default" ENDINCLINATION="-1225;-80;" ID="Arrow_ID_1272242151" STARTARROW="None" STARTINCLINATION="360;22;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1480639186172" HGAP="45" ID="ID_838667304" MODIFIED="1557498707231" TEXT="Mixer" VSHIFT="28">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1476376927660" FOLDED="true" HGAP="35" ID="ID_688318446" MODIFIED="1680569140448" TEXT="Docks" VSHIFT="12">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1504200504235" ID="ID_125942292" MODIFIED="1557498707231" TEXT="PanelManager muß umgebaut werden">
|
|
<arrowlink COLOR="#e1a169" DESTINATION="ID_1249897876" ENDARROW="Default" ENDINCLINATION="-636;0;" ID="Arrow_ID_446871395" STARTARROW="None" STARTINCLINATION="-311;562;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504193029907" ID="ID_945788817" MODIFIED="1557498707231" TEXT="#1104 how to instruct actions through panels">
|
|
<linktarget COLOR="#b37033" DESTINATION="ID_945788817" ENDARROW="None" ENDINCLINATION="-255;-86;" ID="Arrow_ID_61914" SOURCE="ID_1943521361" STARTARROW="Default" STARTINCLINATION="-618;-18;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1504368481111" ID="ID_1149652836" MODIFIED="1557498707231" TEXT="PanelManager selber verbleibt im top-level window">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1504368500421" ID="ID_184425569" MODIFIED="1557498707231" TEXT="es gibt einen PanelLocator im WindowLocator">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1504368540111" ID="ID_1747666798" MODIFIED="1557498707232" TEXT="es gibt einen ViewLocator im InteractionDirector">
|
|
<arrowlink COLOR="#7f97bd" DESTINATION="ID_344392695" ENDARROW="Default" ENDINCLINATION="-977;81;" ID="Arrow_ID_1627222173" STARTARROW="None" STARTINCLINATION="1159;303;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504200512737" ID="ID_320931452" MODIFIED="1557498707232" TEXT="Müllhaufen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1504200743610" ID="ID_1973994759" MODIFIED="1679362063119" TEXT="Übergangsweise....">
|
|
<node CREATED="1504200750905" ID="ID_1728645080" MODIFIED="1679359485827" TEXT="gab es noch eine ZombieTimeline">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zum Abschluß der GUI-Überarbeitung 3/23 habe ich diese Zombie-Timeline tot gemacht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1504200758920" FOLDED="true" ID="ID_19179662" MODIFIED="1561827465280" TEXT="hab ich schon mal eine InfoBox dazugebaut">
|
|
<linktarget COLOR="#f5dd67" DESTINATION="ID_19179662" ENDARROW="Default" ENDINCLINATION="743;-1563;" ID="Arrow_ID_1195014928" SOURCE="ID_340215113" STARTARROW="None" STARTINCLINATION="-452;605;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1504200878312" ID="ID_1934842950" MODIFIED="1576282358037" TEXT="...für #1099 DemoGuiRoundtrip">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um mal was im UI anzeigen zu können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1504200907356" ID="ID_1939871955" MODIFIED="1538838450291" TEXT="neues Dock">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1504201024836" ID="ID_541911572" MODIFIED="1518487921083" TEXT="brauche Icon"/>
|
|
<node CREATED="1504201506172" ID="ID_739793394" MODIFIED="1518487921083" TEXT="nimm vorerst Asset-Icon">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1504201029004" ID="ID_1898190659" MODIFIED="1538838744207" TEXT="als SVG machen...">
|
|
<arrowlink COLOR="#8697d2" DESTINATION="ID_1569870904" ENDARROW="Default" ENDINCLINATION="-935;-133;" ID="Arrow_ID_421953450" STARTARROW="None" STARTINCLINATION="-861;94;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534523269133" ID="ID_403796438" MODIFIED="1538838457405" TEXT="interne Struktur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534523277547" ID="ID_1662503806" MODIFIED="1538838460701" TEXT="FelerLog-Anzeige">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1534523283443" ID="ID_329149746" MODIFIED="1534524676311" TEXT="erst bei Bedarf belegen">
|
|
<arrowlink COLOR="#7ca8bc" DESTINATION="ID_1941760302" ENDARROW="Default" ENDINCLINATION="-1967;5936;" ID="Arrow_ID_192358692" STARTARROW="None" STARTINCLINATION="670;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534523296448" ID="ID_734584528" MODIFIED="1538838422608" TEXT="zuklappbar">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1534523292305" ID="ID_1595061322" MODIFIED="1538838426589" TEXT="Platzhalter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538838427984" ID="ID_1386470288" MODIFIED="1538838432888" TEXT="Buttonts">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534850747192" ID="ID_109802175" MODIFIED="1538838438202" TEXT="vorläufig per Grid implementieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504200915915" ID="ID_335470074" MODIFIED="1538838470692" TEXT="später wird das ein nichtmodaler Parameter-Editor">
|
|
<arrowlink DESTINATION="ID_1405249171" ENDARROW="Default" ENDINCLINATION="222;-82;" ID="Arrow_ID_1395046288" STARTARROW="None" STARTINCLINATION="644;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833434094" ID="ID_349655067" MODIFIED="1557498707232">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Docks enthalten <b>Component Views</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#929fdf" DESTINATION="ID_1717772756" ENDARROW="Default" ENDINCLINATION="-34;-71;" ID="Arrow_ID_1343685046" STARTARROW="None" STARTINCLINATION="-79;76;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1538941704952" HGAP="12" ID="ID_429142366" MODIFIED="1557498707232" TEXT="konkrete Panels" VSHIFT="26">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" ID="ID_712786561" MODIFIED="1557498707232" TEXT="Timeline-Panel">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_712786561" ENDARROW="Default" ENDINCLINATION="-1077;-98;" ID="Arrow_ID_433721169" SOURCE="ID_1231562526" STARTARROW="None" STARTINCLINATION="860;206;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1539394757429" ID="ID_376064530" MODIFIED="1557498707232" TEXT="wegräumen des Testcodes">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539394765628" ID="ID_308731527" MODIFIED="1557498707232" TEXT="Widget-Struktur anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539459412979" ID="ID_1273129379" MODIFIED="1557498707232" TEXT="leere Platzhalter-Timeline">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539459428928" ID="ID_1156538064" MODIFIED="1557498707232" TEXT="bestücken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539394779490" ID="ID_1710199928" MODIFIED="1557498707232" TEXT="Verwalten der Tabs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539394670721" ID="ID_1510868551" MODIFIED="1557498707232" TEXT="TimelineWidget übernehmen">
|
|
<linktarget COLOR="#7882c8" DESTINATION="ID_1510868551" ENDARROW="Default" ENDINCLINATION="-587;-51;" ID="Arrow_ID_206932394" SOURCE="ID_50363803" STARTARROW="None" STARTINCLINATION="-699;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1539394802679" ID="ID_1716564275" MODIFIED="1557498707232" TEXT="neuen Tab dafür belegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1539480719942" ID="ID_1686433179" MODIFIED="1557498707232" TEXT="ggfs Platzhalter wegwerfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477342616175" HGAP="37" ID="ID_954058801" MODIFIED="1557498707232" TEXT="Workspace" VSHIFT="33">
|
|
<node CREATED="1477342624942" FOLDED="true" ID="ID_56920104" MODIFIED="1679359422465" TEXT="ist-Zustand">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1477342634181" ID="ID_930340610" MODIFIED="1518487921084" TEXT="ein globaler WindowManager">
|
|
<node CREATED="1477342640932" ID="ID_950379507" MODIFIED="1518487921084" TEXT="hat Liste von WorkspaceWindow-s"/>
|
|
<node CREATED="1477342694237" ID="ID_1913986184" MODIFIED="1518487921084" TEXT="diese deregistrieren sich beim Schließen"/>
|
|
<node CREATED="1477342711442" ID="ID_500847959" MODIFIED="1518487921084" TEXT="wenn letztes Fenster zu, dann Main->quit"/>
|
|
<node CREATED="1477342816853" ID="ID_205499879" MODIFIED="1576282358037" TEXT="steuert Zusand von Menu>Window>CloseWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nur <i>enabled</i> wenn
|
|
</p>
|
|
<p>
|
|
mehr als ein top-level Fenster offen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477342868574" ID="ID_679226593" MODIFIED="1518487921084" TEXT="WorkspaceWindow">
|
|
<node CREATED="1477342962345" ID="ID_1801410798" MODIFIED="1518487921084" TEXT="verbunden mit">
|
|
<node CREATED="1477342985710" ID="ID_1944710826" MODIFIED="1518487921084" TEXT="Project"/>
|
|
<node CREATED="1477342971448" ID="ID_1574175266" MODIFIED="1518487921084" TEXT="Controller"/>
|
|
</node>
|
|
<node CREATED="1477343022529" ID="ID_1585028268" MODIFIED="1518487921084" TEXT="owns">
|
|
<node CREATED="1477343030104" ID="ID_350881879" MODIFIED="1576282358036" TEXT="gtk::UiManager">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
A Gtk::UIManager constructs a user interface (menus and toolbars) from one or more UI definitions,
|
|
</p>
|
|
<p>
|
|
which reference actions from one or more action groups.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1477343041295" ID="ID_1874325062" MODIFIED="1518487921084" TEXT="PanelManager">
|
|
<node CREATED="1477343244428" ID="ID_513688853" MODIFIED="1518487921084" TEXT="managed die Docks"/>
|
|
<node CREATED="1477345531413" ID="ID_1082348568" MODIFIED="1518487921084" TEXT="Liste möglicher Panel-Typen"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1477345852274" HGAP="30" ID="ID_1401392249" MODIFIED="1518487921084" TEXT="Kritik" VSHIFT="15">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1477345882862" ID="ID_1342647727" MODIFIED="1518487921084" TEXT="arbeitet zu viel mit Pointern ohe RAII"/>
|
|
<node CREATED="1477345906723" ID="ID_906895860" MODIFIED="1518487921084" TEXT=""poor man's reflection""/>
|
|
<node CREATED="1477345939063" ID="ID_984848221" MODIFIED="1576282358035">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
realisiert Vererbung <i>zu fuß</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...anstatt eine auf den konkreten Typ getemplatete Subklasse zu verwenden,
|
|
</p>
|
|
<p>
|
|
wird eine "CreatePanelProc" in einen PanelDescriptor eingewickelt.
|
|
</p>
|
|
<p>
|
|
Letzten Endes wird dieser dann per Match auf die Typ-ID ausgewählt.
|
|
</p>
|
|
<p>
|
|
AUA!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477347390430" HGAP="46" ID="ID_138529757" MODIFIED="1518487921084" TEXT="Panel" VSHIFT="31">
|
|
<node CREATED="1477347401045" ID="ID_919458304" MODIFIED="1518487921084" TEXT="Timeline">
|
|
<node CREATED="1477347410884" ID="ID_507837490" MODIFIED="1518487921084" TEXT="im Umbau"/>
|
|
</node>
|
|
<node CREATED="1477347405332" ID="ID_1735199230" MODIFIED="1518487921084" TEXT="Asset"/>
|
|
<node CREATED="1477347407324" ID="ID_1325322495" MODIFIED="1518487921084" TEXT="Viewer">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1477347416659" ID="ID_1220196828" MODIFIED="1518487921084" TEXT="kaputt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1477347424858" ID="ID_439722309" MODIFIED="1518487921084" TEXT="wird nicht mehr erzeugt">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1477347448199" ID="ID_432416001" MODIFIED="1518487921084" TEXT="Grund: kein Displayer">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1477616970387" HGAP="56" ID="ID_786267715" MODIFIED="1518487921084" TEXT="Problem: Panel clean-up" VSHIFT="40">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1477617009766" ID="ID_205353538" MODIFIED="1576282358035" TEXT="Verdacht: dtor wird nicht aufgerufen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie komme ich da drauf?
|
|
</p>
|
|
<p>
|
|
Ich wollte untersuchen, ob Gtk::manage( ptr ) korrekt die übergebenen Objekte aufräumt.
|
|
</p>
|
|
<p>
|
|
Wie sich nun zeigt, passiert das Aufräumen im dtor desjenigen Widget, dem das zu managende Objekt als Kind gegeben wurde.
|
|
</p>
|
|
<p>
|
|
Im vorliegenden Fall wäre das der dtor des umschließenden ScrolledWindow. Der aber wird <i>offensichtlich nicht aufgerufen,</i>
|
|
</p>
|
|
<p>
|
|
auch nicht im Application-Shutdown!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1477617185582" ID="ID_634277803" MODIFIED="1576282358034" TEXT="PanelManager::createPanels()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....erzeugt wird das hier:
|
|
</p>
|
|
<p>
|
|
dock_.add_item(timelinePanel->getDockItem(),Gdl::DOCK_BOTTOM);
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477343061900" ID="ID_589166101" MODIFIED="1518487921084" TEXT="Statusbar"/>
|
|
<node CREATED="1477343071827" ID="ID_369966079" MODIFIED="1576282358034" TEXT="Actions">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Helper to build the menu and for registering and handling of user action events
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477344354329" ID="ID_1683945104" MODIFIED="1518487921084" TEXT="createUi()">
|
|
<node CREATED="1477344605448" ID="ID_960836253" MODIFIED="1518487921084" TEXT="panelManager_.setupDock();"/>
|
|
<node CREATED="1477344610087" ID="ID_844257690" MODIFIED="1518487921084" TEXT="baut auf">
|
|
<node CREATED="1477344616486" ID="ID_466606949" MODIFIED="1518487921084" TEXT="Menübar"/>
|
|
<node CREATED="1477344619541" ID="ID_1111690482" MODIFIED="1518487921084" TEXT="dockContainer"/>
|
|
<node CREATED="1477344659440" ID="ID_1310811438" MODIFIED="1518487921084" TEXT="statusBar"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477343115357" ID="ID_213954404" MODIFIED="1518487921084" TEXT="Kritik">
|
|
<node CREATED="1477343120660" ID="ID_1940152250" MODIFIED="1576282358033" TEXT="Multiplizität unklar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es sieht so aus, als wäre es "das" WorkspaceWindow
|
|
</p>
|
|
<p>
|
|
aber es kann davon mehrere geben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1477343152288" ID="ID_1267678981" MODIFIED="1518487921084" TEXT="Vermengung von Fenster und Workspace"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477522265208" HGAP="53" ID="ID_41510242" MODIFIED="1557498707232" TEXT="Neuerungen" VSHIFT="28">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1477522271822" FOLDED="true" ID="ID_622217667" MODIFIED="1557498707232" TEXT="PanelExperiment">
|
|
<arrowlink COLOR="#e0d18d" DESTINATION="ID_340215113" ENDARROW="Default" ENDINCLINATION="-389;5426;" ID="Arrow_ID_1440864098" STARTARROW="None" STARTINCLINATION="-1637;-8191;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1477522330886" ID="ID_1920846276" MODIFIED="1557498707232" TEXT="ScrolledWindow"/>
|
|
<node CREATED="1477522340573" ID="ID_168076322" MODIFIED="1557498707232" TEXT="Grid">
|
|
<node CREATED="1477523590806" ID="ID_908611386" MODIFIED="1557498707232" TEXT="attach()"/>
|
|
<node CREATED="1477523593462" ID="ID_1461366621" MODIFIED="1557498707232" TEXT="attach_next_to()"/>
|
|
<node CREATED="1477523578208" ID="ID_738525852" MODIFIED="1557498707232" TEXT="add()"/>
|
|
</node>
|
|
<node CREATED="1477523550484" ID="ID_1492266905" MODIFIED="1557498707232" TEXT="Box">
|
|
<node CREATED="1477523556667" ID="ID_852178687" MODIFIED="1557498707232" TEXT="horizontal / vertikal"/>
|
|
<node CREATED="1477523561930" ID="ID_868197404" MODIFIED="1557498707232" TEXT="pack_start() "/>
|
|
<node CREATED="1477523573184" ID="ID_1063091132" MODIFIED="1557498707232" TEXT="pack_end()"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1534849790225" HGAP="46" ID="ID_326815949" MODIFIED="1557498707232" TEXT="#1164 investigate docking panel behaviour">
|
|
<linktarget COLOR="#a35f7f" DESTINATION="ID_326815949" ENDARROW="Default" ENDINCLINATION="33;189;" ID="Arrow_ID_746548615" SOURCE="ID_1536071305" STARTARROW="None" STARTINCLINATION="246;-229;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850081097" ID="ID_264379011" MODIFIED="1557498707232" TEXT="mögliche Schachtelungen">
|
|
<icon BUILTIN="full-1"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850106454" ID="ID_1465835366" MODIFIED="1557498707232" TEXT="nebeneinander (Grid)">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850113247" ID="ID_667518060" MODIFIED="1557498707232" TEXT="Tabs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850159866" ID="ID_1887039635" MODIFIED="1557498707232" TEXT="Teil-Layout programatisch erzeugen / rekonstruieren">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850200900" ID="ID_754628121" MODIFIED="1557498707232" TEXT="programmatische Größenänderung">
|
|
<icon BUILTIN="full-3"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850230072" ID="ID_333353660" MODIFIED="1557498707232" TEXT="size-request">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850238426" ID="ID_1411766694" MODIFIED="1557498707232" TEXT="harte Größenvorgabe">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850256212" ID="ID_761478120" MODIFIED="1557498707232" TEXT="bei mehrfacher Schachtelung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534850278149" ID="ID_348255325" MODIFIED="1557498707232" TEXT="Zusammenspiel mit Persistenz">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487464476801" FOLDED="true" ID="ID_1621360845" MODIFIED="1679362327422" TEXT="Umbau">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1487464480872" ID="ID_830603607" MODIFIED="1679362266710" TEXT="bestehende Strukturen stillegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1487464489143" ID="ID_1990719718" MODIFIED="1679362270779" TEXT="noch erhalten als Bezugspunkt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1487464495494" ID="ID_1238357229" MODIFIED="1679362273315" TEXT="daneben neue Controller-Backbone hochziehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1487464505469" ID="ID_707273464" MODIFIED="1679362300502" TEXT="Umbau in neuen top-level">
|
|
<arrowlink COLOR="#30bc74" DESTINATION="ID_1868522177" ENDARROW="Default" ENDINCLINATION="374;490;" ID="Arrow_ID_600425644" STARTARROW="None" STARTINCLINATION="2009;200;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477522287316" ID="ID_1942021610" MODIFIED="1557498707232" TEXT="TimelinePanel"/>
|
|
<node COLOR="#338800" CREATED="1502390603674" ID="ID_1926586811" MODIFIED="1557498707232" TEXT="#1102 : build a message display box in the UI">
|
|
<linktarget COLOR="#8c8bae" DESTINATION="ID_1926586811" ENDARROW="Default" ENDINCLINATION="1539;60;" ID="Arrow_ID_1593124756" SOURCE="ID_125356908" STARTARROW="None" STARTINCLINATION="-850;779;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504833474521" FOLDED="true" HGAP="39" ID="ID_1439141983" MODIFIED="1557498707232" TEXT="Struktur" VSHIFT="10">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1504833487359" ID="ID_1631525475" MODIFIED="1557498707232" TEXT="UI-Frame: Fenster"/>
|
|
<node CREATED="1504833498453" ID="ID_815439481" MODIFIED="1557498707232" TEXT="Perspektive"/>
|
|
<node CREATED="1504833508516" ID="ID_1973916831" MODIFIED="1557498707232" TEXT="einzelne Panel"/>
|
|
<node CREATED="1504833540720" ID="ID_1717772756" MODIFIED="1557498707232" TEXT="Component View">
|
|
<linktarget COLOR="#92a9df" DESTINATION="ID_1717772756" ENDARROW="Default" ENDINCLINATION="-1346;-3359;" ID="Arrow_ID_1986148222" SOURCE="ID_583036636" STARTARROW="None" STARTINCLINATION="385;845;"/>
|
|
<linktarget COLOR="#929fdf" DESTINATION="ID_1717772756" ENDARROW="Default" ENDINCLINATION="-34;-71;" ID="Arrow_ID_1343685046" SOURCE="ID_349655067" STARTARROW="None" STARTINCLINATION="-79;76;"/>
|
|
<node CREATED="1504833565425" ID="ID_529173859" MODIFIED="1557498707232" TEXT="Timeline"/>
|
|
<node CREATED="1504833569692" ID="ID_1708962269" MODIFIED="1557498707232" TEXT="Viewer"/>
|
|
<node CREATED="1504833572687" ID="ID_57378390" MODIFIED="1557498707232" TEXT="(Asset)Bin"/>
|
|
<node CREATED="1504833574246" ID="ID_897436866" MODIFIED="1557498707232" TEXT="Infobox">
|
|
<node CREATED="1534523010591" ID="ID_1405249171" MODIFIED="1557498707232" TEXT="Zentrale Informationsanzeigen">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1405249171" ENDARROW="Default" ENDINCLINATION="222;-82;" ID="Arrow_ID_1395046288" SOURCE="ID_335470074" STARTARROW="None" STARTINCLINATION="644;0;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534848989905" ID="ID_1536071305" MODIFIED="1557498707232" TEXT="Anforderungen">
|
|
<arrowlink COLOR="#a35f7f" DESTINATION="ID_326815949" ENDARROW="Default" ENDINCLINATION="33;189;" ID="Arrow_ID_746548615" STARTARROW="None" STARTINCLINATION="246;-229;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1534849000159" ID="ID_82161143" MODIFIED="1557498707232" TEXT="fest vorgegebener Platz im UI"/>
|
|
<node CREATED="1534849057715" ID="ID_1467109522" MODIFIED="1557498707232" TEXT="stets sichbarer Status-Bereich">
|
|
<node CREATED="1534849188780" ID="ID_1937021840" MODIFIED="1557498707232" TEXT="sehr kompakt / effizient"/>
|
|
<node CREATED="1534849196166" ID="ID_1813708845" MODIFIED="1557498707232" TEXT="enthält minimale Navi"/>
|
|
</node>
|
|
<node CREATED="1534849205203" ID="ID_1997665939" MODIFIED="1557498707232" TEXT="darunter">
|
|
<node CREATED="1534849381630" ID="ID_1209297989" MODIFIED="1557498707232" TEXT="Paletten-Stacks">
|
|
<node CREATED="1534849546781" ID="ID_657722273" MODIFIED="1557498707232" TEXT="zweidimensionale Anordnung"/>
|
|
<node CREATED="1534849630348" ID="ID_506310851" MODIFIED="1557498707232" TEXT="Fokus in einer Spalte + Zelle"/>
|
|
<node CREATED="1534849646074" ID="ID_1030720361" MODIFIED="1557498707232" TEXT="der Rest wird reduziert (abridged)"/>
|
|
</node>
|
|
<node CREATED="1534849493068" ID="ID_1029182833" MODIFIED="1557498707232" TEXT="kann sich in Pupup vergrößern"/>
|
|
<node CREATED="1534849512730" ID="ID_1444658378" MODIFIED="1557498707232" TEXT="kollabiert bei Fokusverlust"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534850609493" ID="ID_798164713" MODIFIED="1557498707232" TEXT="Belegung">
|
|
<node CREATED="1534850615125" ID="ID_1470557953" MODIFIED="1557498707232" TEXT="eindeutiger View-Name"/>
|
|
<node CREATED="1534850658265" ID="ID_60455430" MODIFIED="1557498707232" TEXT="Tab == Sub-View oder Fach"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534523024189" ID="ID_215944418" MODIFIED="1557498707232" TEXT="Fehlerlog">
|
|
<node CREATED="1534523031493" ID="ID_1146002742" MODIFIED="1557498707232" TEXT="wird bei erstem Bedarf belegt"/>
|
|
<node CREATED="1534523042035" ID="ID_1292242862" MODIFIED="1557498707232" TEXT="klappt bei Fehlern auf"/>
|
|
</node>
|
|
<node CREATED="1534523020334" ID="ID_295859017" MODIFIED="1557498707232" TEXT="Status"/>
|
|
</node>
|
|
<node CREATED="1504833575700" ID="ID_1470115932" MODIFIED="1557498707232" TEXT="Playcontrol"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423383765" FOLDED="true" HGAP="339" ID="ID_1046643705" MODIFIED="1557498707232" TEXT="Verhalten" VSHIFT="23">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1488423418968" ID="ID_1169811882" MODIFIED="1557498707232" TEXT="Lebenszyklus">
|
|
<node CREATED="1488423424111" ID="ID_1090980479" MODIFIED="1557498707232" TEXT="Start">
|
|
<node COLOR="#338800" CREATED="1531417429342" ID="ID_991918611" MODIFIED="1557498707232" TEXT="als Subsystem">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1531417434195" FOLDED="true" ID="ID_176564515" MODIFIED="1679086498314" TEXT="Strukturen hochfahren">
|
|
<linktarget COLOR="#fee998" DESTINATION="ID_176564515" ENDARROW="Default" ENDINCLINATION="-1211;-7367;" ID="Arrow_ID_157207334" SOURCE="ID_1850773836" STARTARROW="None" STARTINCLINATION="-617;103;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1531417551148" ID="ID_579526750" MODIFIED="1557498707232" TEXT="UI top-level"/>
|
|
<node CREATED="1531417577048" ID="ID_371378063" MODIFIED="1557498707232" TEXT="Rahmen bereitstellen"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531419217662" ID="ID_745789650" MODIFIED="1557498707232" TEXT="#1147 establish UI start-up sequence">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544238959075" ID="ID_317908194" MODIFIED="1557498707232" TEXT="es gibt noch Lücken">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1544238974604" ID="ID_116347689" MODIFIED="1557498707232" TEXT="Exception beim Hochfahren der Backbone">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544240822252" ID="ID_1036837893" MODIFIED="1557498707232" TEXT="#1192 Lumiera hangs on failed GUI start">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544238994154" ID="ID_1878681615" MODIFIED="1557498707232" TEXT="Problem: Fehler-Handler schützt nur die Loop selber">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1544239461493" ID="ID_1795051800" MODIFIED="1582493900730" TEXT="catch-Block anders anordnen">
|
|
<arrowlink COLOR="#e02825" DESTINATION="ID_478753729" ENDARROW="Default" ENDINCLINATION="-3550;0;" ID="Arrow_ID_840138296" STARTARROW="None" STARTINCLINATION="-69;-346;"/>
|
|
<linktarget COLOR="#e5221e" DESTINATION="ID_1795051800" ENDARROW="Default" ENDINCLINATION="-1916;0;" ID="Arrow_ID_127697886" SOURCE="ID_110235945" STARTARROW="None" STARTINCLINATION="-716;43;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544239713424" ID="ID_632286012" MODIFIED="1557498707232" TEXT="möglichen Race mit Subsystem-Runner prüfen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1544241151268" ID="ID_1182875214" MODIFIED="1557498707232" TEXT="sigTerm ist durch Lock geschützt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1544241162650" ID="ID_830024837" MODIFIED="1557498707232" TEXT="d.h. sigTerm blockt, solange der startup läuft"/>
|
|
<node CREATED="1544241230874" ID="ID_24965814" MODIFIED="1557498707232" TEXT="was macht GuiFacade::checkRunningState() ?">
|
|
<node CREATED="1544241332932" ID="ID_924360922" MODIFIED="1557498707232" TEXT="prüft den Facade-ptr"/>
|
|
<node CREATED="1544241469845" ID="ID_1172060220" MODIFIED="1557498707232" TEXT="der ist gesetzt, sobald der UI-Thread läuft"/>
|
|
<node COLOR="#338800" CREATED="1544241497023" ID="ID_1127634183" MODIFIED="1557498707232" TEXT="das ist also OK">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544241590705" ID="ID_1914479382" MODIFIED="1557498707232">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
demnach würde startup sauber beendet,
|
|
</p>
|
|
<p>
|
|
und unmittelbar danach würder der UI-Thread einen
|
|
</p>
|
|
<p>
|
|
emergency-Shutdown initiieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544241647251" ID="ID_1802228559" MODIFIED="1557498707232" TEXT="sieht soweit sauber aus">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538265361374" ID="ID_1843835835" MODIFIED="1575131660804" TEXT="Detailierte Analyse">
|
|
<arrowlink COLOR="#77c1c5" DESTINATION="ID_226245696" ENDARROW="Default" ENDINCLINATION="-1683;73;" ID="Arrow_ID_532646791" STARTARROW="None" STARTINCLINATION="2799;341;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1531417583847" ID="ID_1316715960" MODIFIED="1557498707232" TEXT="Dienste starten">
|
|
<node CREATED="1531417744657" ID="ID_350697541" MODIFIED="1561827465287" TEXT="Inhalts-Konsument">
|
|
<arrowlink COLOR="#30327c" DESTINATION="ID_527465217" ENDARROW="Default" ENDINCLINATION="25;-45;" ID="Arrow_ID_1130203410" STARTARROW="None" STARTINCLINATION="-75;21;"/>
|
|
<node CREATED="1531588709162" ID="ID_152567143" MODIFIED="1531588724487" TEXT="wann aktivieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1531588726503" ID="ID_1064852599" MODIFIED="1531588733706" TEXT="mit InteractionDirector?"/>
|
|
<node CREATED="1531588734582" ID="ID_1508027862" MODIFIED="1531588750296" TEXT="vor GTK-Loop?"/>
|
|
<node CREATED="1531588753044" ID="ID_387089286" MODIFIED="1532788602238" TEXT="in der Loop?">
|
|
<arrowlink COLOR="#9d1a41" DESTINATION="ID_1581791639" ENDARROW="Default" ENDINCLINATION="-211;-16;" ID="Arrow_ID_1635616322" STARTARROW="None" STARTINCLINATION="-419;0;"/>
|
|
<linktarget COLOR="#8a226e" DESTINATION="ID_387089286" ENDARROW="Default" ENDINCLINATION="300;0;" ID="Arrow_ID_1663921099" SOURCE="ID_262149423" STARTARROW="None" STARTINCLINATION="136;3;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1531588828738" ID="ID_1453043346" MODIFIED="1531588835780" TEXT="Verhalten">
|
|
<node CREATED="1531588837008" ID="ID_803785652" MODIFIED="1531588855466" TEXT="ctor sendet Aktivierungs-Command"/>
|
|
<node CREATED="1531588848359" ID="ID_1792032686" MODIFIED="1531588864496" TEXT="dtor sendet deAktivierungs-Command"/>
|
|
<node CREATED="1531588867077" ID="ID_291300049" MODIFIED="1531588877210" TEXT="setzt Session voraus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1531588878587" ID="ID_1315265515" MODIFIED="1531588883734" TEXT="per Subsystem sichergestellt"/>
|
|
<node CREATED="1531588884490" ID="ID_1508293978" MODIFIED="1531588894300" TEXT="GUI setzt generell Session voraus"/>
|
|
</node>
|
|
<node CREATED="1531588911686" ID="ID_666574025" MODIFIED="1531588947853" TEXT="Konsequenzen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1531588919981" ID="ID_1457124086" MODIFIED="1531588926952" TEXT="danach können Diff-Nachrichten ankommen"/>
|
|
<node CREATED="1531588927700" ID="ID_1330332232" MODIFIED="1531588932375" TEXT="dazu muß die Loop laufen"/>
|
|
<node CREATED="1531588933107" ID="ID_262149423" MODIFIED="1531588977291" TEXT="und die NotificationFacade offen sein">
|
|
<arrowlink COLOR="#8a226e" DESTINATION="ID_387089286" ENDARROW="Default" ENDINCLINATION="300;0;" ID="Arrow_ID_1663921099" STARTARROW="None" STARTINCLINATION="136;3;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1531417463128" FOLDED="true" HGAP="24" ID="ID_1392317817" MODIFIED="1679359381265" TEXT="mit Inhalt beladen" VSHIFT="37">
|
|
<linktarget COLOR="#665692" DESTINATION="ID_1392317817" ENDARROW="Default" ENDINCLINATION="-1993;202;" ID="Arrow_ID_609042013" SOURCE="ID_1997153046" STARTARROW="Default" STARTINCLINATION="1943;108;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531417714894" ID="ID_527465217" MODIFIED="1561827465291" TEXT="Inhalts-Empfang etablieren">
|
|
<linktarget COLOR="#30327c" DESTINATION="ID_527465217" ENDARROW="Default" ENDINCLINATION="25;-45;" ID="Arrow_ID_1130203410" SOURCE="ID_350697541" STARTARROW="None" STARTINCLINATION="-75;21;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531423717866" ID="ID_1400324647" MODIFIED="1531423724074" TEXT="#1150 GUI content connector">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531423582548" ID="ID_751311895" MODIFIED="1533392488074" TEXT="Aktivierungs-Command">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1531423597642" ID="ID_1814328528" MODIFIED="1533395218014" TEXT="definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533395230685" ID="ID_556592297" MODIFIED="1533400280528" TEXT="Ausführung sicherstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533400281627" ID="ID_1248361340" MODIFIED="1533400375591" TEXT="geht noch nicht -- logging-Strategy fehlt">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533400377118" ID="ID_1072134705" MODIFIED="1541547696433" TEXT="#211 handling pattern for dispatch">
|
|
<arrowlink COLOR="#ca91c2" DESTINATION="ID_1192893155" ENDARROW="Default" ENDINCLINATION="1415;0;" ID="Arrow_ID_207842771" STARTARROW="None" STARTINCLINATION="2581;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533400389668" ID="ID_1875748001" MODIFIED="1533400427879" TEXT="vorläufig: Präfix test_">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533400398059" ID="ID_1419077642" MODIFIED="1533400424027" TEXT="Magie im ProcDispatcher">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533400403290" ID="ID_950948089" MODIFIED="1533400426028" TEXT="führt Command unmittelbar aus">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533400412337" ID="ID_462882830" MODIFIED="1533400420146" TEXT="funktioniert">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533392476019" ID="ID_1798579710" MODIFIED="1533401269006" TEXT="vorläufige Dummy-Implementierung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1533401271538" ID="ID_613065826" MODIFIED="1538263724168" TEXT="erst mal nur eine Nachricht als UI-Notification">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1533402513829" ID="ID_1456159316" MODIFIED="1538839303541" TEXT="#1099 DemoGuiRoundtrip">
|
|
<arrowlink COLOR="#f0eca5" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="881;2029;" ID="Arrow_ID_1736540527" STARTARROW="None" STARTINCLINATION="765;-14;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538839326830" ID="ID_1942975878" MODIFIED="1582443399893" TEXT="jetzt regulär über die Notification facade">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582443855728" ID="ID_1789967574" MODIFIED="1582443913545" TEXT="cmd::test_meta_activateContentDiff">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
InteractionDirector::populateContent_afterStart()
|
|
</li>
|
|
<li>
|
|
meta-cmd.cpp
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401303142" ID="ID_1338326263" MODIFIED="1533401327708" TEXT="hart gecodeten initialen Diff hochschicken">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1533403016000" ID="ID_515841398" MODIFIED="1533403026256" TEXT="Diff-Nachrichten wieder verstehen">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533403027894" ID="ID_488294111" MODIFIED="1533403133894" TEXT="Diff-Nachricht inline generieren">
|
|
<arrowlink COLOR="#e34459" DESTINATION="ID_294556843" ENDARROW="Default" ENDINCLINATION="287;0;" ID="Arrow_ID_1612526412" STARTARROW="None" STARTINCLINATION="190;339;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531423600722" ID="ID_311523916" MODIFIED="1533392474052" TEXT="Implementierung klären">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1533401971601" ID="ID_883504437" MODIFIED="1533401978732" TEXT="Service in der Session">
|
|
<node CREATED="1533401984272" ID="ID_813978364" MODIFIED="1533401990795" TEXT="Aktivierungs-Status"/>
|
|
<node CREATED="1533401991455" ID="ID_1252573502" MODIFIED="1533402001594" TEXT="kann sich "irgendwo" einklinken">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533403071072" ID="ID_1097229623" MODIFIED="1533403086052" TEXT="Content-Listener">
|
|
<arrowlink DESTINATION="ID_1724879903" ENDARROW="Default" ENDINCLINATION="17;-198;" ID="Arrow_ID_275658114" STARTARROW="None" STARTINCLINATION="-79;12;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531423632949" ID="ID_1724879903" MODIFIED="1533403086052" TEXT="Content-Listener">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1724879903" ENDARROW="Default" ENDINCLINATION="17;-198;" ID="Arrow_ID_275658114" SOURCE="ID_1097229623" STARTARROW="None" STARTINCLINATION="-79;12;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401384155" ID="ID_1494781570" MODIFIED="1533403062858" TEXT="#1153 define foundation for live diff updates Session -> UI">
|
|
<arrowlink COLOR="#a47f9a" DESTINATION="ID_1106740084" ENDARROW="Default" ENDINCLINATION="2561;-1079;" ID="Arrow_ID_1276188897" STARTARROW="None" STARTINCLINATION="1703;327;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1531423640788" ID="ID_865939750" MODIFIED="1531423650015" TEXT="Ort finden"/>
|
|
<node CREATED="1531423650339" ID="ID_583637266" MODIFIED="1531423655294" TEXT="Lebenszyklus klären"/>
|
|
<node CREATED="1531423734880" ID="ID_1658395629" MODIFIED="1531423739643" TEXT="Verbindungen klären"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532788529509" ID="ID_390131579" MODIFIED="1533388695623" TEXT="Trigger-Punkt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1532788547560" ID="ID_1581791639" MODIFIED="1664059203522" TEXT="muß in der GTK-Event-Loop liegen">
|
|
<linktarget COLOR="#9d1a41" DESTINATION="ID_1581791639" ENDARROW="Default" ENDINCLINATION="-211;-16;" ID="Arrow_ID_1635616322" SOURCE="ID_387089286" STARTARROW="None" STARTINCLINATION="-419;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532788645307" FOLDED="true" ID="ID_254810710" MODIFIED="1561827465292" TEXT="Trigger-Technik klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1532788681197" FOLDED="true" HGAP="336" ID="ID_32192034" MODIFIED="1576282358033" TEXT="bei GTK selber abschauen" VSHIFT="-52">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erinnere mich, diverse Mechanismen gesehen zu haben,
|
|
</p>
|
|
<p>
|
|
die erlauben, eine Init-Aktion in die Loop zu schedulen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1532793805646" ID="ID_1917720417" MODIFIED="1532793811649" TEXT="Gtk::Application">
|
|
<node CREATED="1532797033134" ID="ID_1310675334" MODIFIED="1532797038441" TEXT="Gio::Application">
|
|
<node CREATED="1532797039293" ID="ID_827848177" MODIFIED="1532797041784" TEXT="Basisklasse"/>
|
|
<node CREATED="1532797042628" ID="ID_868500366" MODIFIED="1532797129536" TEXT="statisches member: Application_Class">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1532797071961" ID="ID_965723020" MODIFIED="1532797076020" TEXT="hat init-Funktionen"/>
|
|
<node CREATED="1532797076656" ID="ID_1083316138" MODIFIED="1576282358032">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
betrifft aber <b>nur Framework</b>-Funktionalität
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also kein Initialisieren des Toolkit,
|
|
</p>
|
|
<p>
|
|
sondern Sachen wie verallgemeinerte "Files", D-Bus-Connection etc etc
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1532794470116" ID="ID_539459561" MODIFIED="1533310145219" TEXT="Fazit">
|
|
<linktarget COLOR="#dc217a" DESTINATION="ID_539459561" ENDARROW="Default" ENDINCLINATION="33;201;" ID="Arrow_ID_601982135" SOURCE="ID_1901487140" STARTARROW="None" STARTINCLINATION="-55;-186;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1532794476795" ID="ID_1999030504" MODIFIED="1532794483438" TEXT="gibt es statische Funktionen?">
|
|
<node CREATED="1533310001705" ID="ID_1113571044" MODIFIED="1533310014123" TEXT="nur Application::create(..) -> smart-Ptr"/>
|
|
</node>
|
|
<node CREATED="1532794485778" ID="ID_86543147" MODIFIED="1532794494804" TEXT="was für on-start-Callbacks gibt es?">
|
|
<node CREATED="1533309934787" ID="ID_768351523" MODIFIED="1533309939685" TEXT="signal_activate()"/>
|
|
</node>
|
|
<node CREATED="1532794495416" ID="ID_1267822394" MODIFIED="1532794501700" TEXT="wie wird das Fenster angezeigt?">
|
|
<node CREATED="1533309900271" ID="ID_1679581564" MODIFIED="1576282358032" TEXT="entweder man macht es selber noch sichtbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
ein Fenster als Solches braucht noch keine Event-Loop
|
|
</li>
|
|
<li>
|
|
ohne ein Fenster macht die event-Loop keinen Sinn
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533309913133" ID="ID_1543846508" MODIFIED="1533310043556" TEXT="oder man verwendet run(Window&)">
|
|
<arrowlink COLOR="#88cecc" DESTINATION="ID_1128899175" ENDARROW="Default" ENDINCLINATION="112;-110;" ID="Arrow_ID_117418578" STARTARROW="None" STARTINCLINATION="-22;73;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533252714471" ID="ID_1128899175" MODIFIED="1533310039265" TEXT="Gtk::Application::run( Window&)">
|
|
<linktarget COLOR="#88cecc" DESTINATION="ID_1128899175" ENDARROW="Default" ENDINCLINATION="112;-110;" ID="Arrow_ID_117418578" SOURCE="ID_1543846508" STARTARROW="None" STARTINCLINATION="-22;73;"/>
|
|
<node CREATED="1533252783548" ID="ID_1476873021" MODIFIED="1533252802635" TEXT="irgendwie hatte ich das in Erinnerung">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1533252737995" ID="ID_763153536" MODIFIED="1533252745030" TEXT="application.cc Zeile 160"/>
|
|
<node CREATED="1533252758840" ID="ID_346690959" MODIFIED="1576282358031" TEXT="signal_activate()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
  //We cannot add and show the window until the GApplication::activate signal
|
|
</p>
|
|
<p>
|
|
  //has been emitted, or we will crash because the application has not been
|
|
</p>
|
|
<p>
|
|
  //registered. (At least if window is an ApplicationWindow.)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533252809112" ID="ID_394563790" MODIFIED="1533252812836" TEXT="woot?"/>
|
|
<node CREATED="1533252813376" ID="ID_1458058904" MODIFIED="1533252820105" TEXT="wer definiert das?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1533252821175" ID="ID_1891535415" MODIFIED="1533253383339" TEXT="Gio::Application ??">
|
|
<arrowlink COLOR="#224e99" DESTINATION="ID_28088492" ENDARROW="Default" ENDINCLINATION="37;-48;" ID="Arrow_ID_550550684" STARTARROW="None" STARTINCLINATION="-151;-4;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533252898732" ID="ID_28088492" MODIFIED="1576282358030" TEXT="Gio::Application::signal_activate()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
The signal_activate() signal is emitted on the primary instance
|
|
</p>
|
|
<p>
|
|
when an activation occurs. See g_application_activate().
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#224e99" DESTINATION="ID_28088492" ENDARROW="Default" ENDINCLINATION="37;-48;" ID="Arrow_ID_550550684" SOURCE="ID_1891535415" STARTARROW="None" STARTINCLINATION="-151;-4;"/>
|
|
<node CREATED="1533252951945" ID="ID_182447520" MODIFIED="1533252955015">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
g_application_activate()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533301504184" ID="ID_887027939" MODIFIED="1533301509336" TEXT="Fragen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1533301510663" ID="ID_494910709" MODIFIED="1533301520633" TEXT="wer ruft das auf?">
|
|
<node CREATED="1533309175099" ID="ID_574887736" MODIFIED="1533309275410" TEXT="im Framework nur Application::run(Window&)">
|
|
<arrowlink COLOR="#6280a2" DESTINATION="ID_103827073" ENDARROW="Default" ENDINCLINATION="-1131;-99;" ID="Arrow_ID_138401663" STARTARROW="None" STARTINCLINATION="1028;-75;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533309280940" ID="ID_918869201" MODIFIED="1576282358030" TEXT="Stand 8/2018 verifiziert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
suche (case insensitive) nach application_activate
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
treffer auf APPLICATION_ACTIVATE in g_application_activate()
|
|
</li>
|
|
<li>
|
|
die Treffer in Gtk::Application
|
|
</li>
|
|
<li>
|
|
diverse false positives mit anderen "Activation"-Signalen, z.B. in Aktionen oder Buttons
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533301523716" ID="ID_10188406" MODIFIED="1533309824191" TEXT="haben wir eine GApplication?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1533301551049" ID="ID_229745628" MODIFIED="1561827465299" TEXT="was ist GApplication in C++?">
|
|
<node CREATED="1533309723431" ID="ID_47606560" MODIFIED="1533309729450" TEXT="Gio::Application"/>
|
|
</node>
|
|
<node CREATED="1533301567374" ID="ID_34255114" MODIFIED="1561827465300" TEXT="hatte Gtk::Main das?">
|
|
<node CREATED="1533302102181" ID="ID_1070266886" MODIFIED="1533302125340">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Main <b>erbt nicht</b> von Gio::Application
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533302523445" FOLDED="true" ID="ID_1043113531" MODIFIED="1561827483834" TEXT="init">
|
|
<node CREATED="1533303553351" ID="ID_377749143" MODIFIED="1533306139169" TEXT="gtk_init">
|
|
<arrowlink COLOR="#87a8bf" DESTINATION="ID_1850885017" ENDARROW="Default" ENDINCLINATION="-195;-45;" ID="Arrow_ID_960670945" STARTARROW="None" STARTINCLINATION="416;0;"/>
|
|
</node>
|
|
<node CREATED="1533303559495" ID="ID_1106606369" MODIFIED="1533306019466" TEXT="init_gtkmm_nternals">
|
|
<arrowlink COLOR="#679cc6" DESTINATION="ID_681479502" ENDARROW="Default" ENDINCLINATION="-182;-16;" ID="Arrow_ID_1451320473" STARTARROW="None" STARTINCLINATION="273;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533309797149" ID="ID_1211740672" MODIFIED="1533309821531" TEXT="Antwort: wir haben keine">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533309804964" ID="ID_6946585" MODIFIED="1533309813851" TEXT="(und das ist gut so)">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533309837472" HGAP="6" ID="ID_1304218174" MODIFIED="1533309870065" TEXT="Fazit: wir müssen das selber bauen" VSHIFT="5">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532788727680" FOLDED="true" HGAP="81" ID="ID_889790361" MODIFIED="1561827465306" TEXT="Gtk::Main auf aktuellem Stand" VSHIFT="51">
|
|
<linktarget COLOR="#70dcb9" DESTINATION="ID_889790361" ENDARROW="Default" ENDINCLINATION="1185;0;" ID="Arrow_ID_1988524020" SOURCE="ID_1815764983" STARTARROW="Default" STARTINCLINATION="-2084;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1532788737366" ID="ID_1527913663" MODIFIED="1532788745870" TEXT="aktuellen Code bereitlegen in Eclipse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1532788747909" ID="ID_279791197" MODIFIED="1533608413841" TEXT="wir haben kopierten Code">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1532788761699" ID="ID_656345742" MODIFIED="1532788789963" TEXT="in gui::ctrl::ApplicationBase"/>
|
|
<node CREATED="1532788794126" ID="ID_552465239" MODIFIED="1532788875600" TEXT="aus Gtk::Main ctor/dtor">
|
|
<node CREATED="1532788799958" ID="ID_1260151456" MODIFIED="1532788808416" TEXT="Gtk::Main selber ist deprecated"/>
|
|
<node CREATED="1532788809316" ID="ID_1012886969" MODIFIED="1532788822535" TEXT="vorrübergehend aber noch tragbar"/>
|
|
<node CREATED="1532788848927" ID="ID_1931062828" MODIFIED="1532788864482" TEXT="Code steckt in Gtk::Main::init_gtk_internals">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1532789071257" ID="ID_1126586783" MODIFIED="1532789107787" TEXT="Vorsicht: was ist GtkMainConnectionNode?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1532789118850" ID="ID_537169683" MODIFIED="1532789136812" TEXT="taucht (neuerdings?) im dtor auf ~GtkMain()"/>
|
|
<node CREATED="1532789138896" ID="ID_546791531" MODIFIED="1532789188914" TEXT="deaktiviert an Gtk::Main gebundene Signale">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1532789198999" ID="ID_270727305" MODIFIED="1576282358029" TEXT="lt. Kommentar insges. ehr ein Legacy-Feature">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...für Signale, die nicht automatisch detached werden können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1532789833473" ID="ID_1171567949" MODIFIED="1532789838020" TEXT="relevant für...">
|
|
<node CREATED="1532789860594" ID="ID_1189172516" MODIFIED="1561827465306" TEXT="gtk_init_add()">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1532791848873" ID="ID_1957619230" MODIFIED="1532791855539" TEXT="@deprecated seit 2010"/>
|
|
<node CREATED="1532791856200" ID="ID_278153793" LINK="https://mail.gnome.org/archives/commits-list/2010-October/msg04543.html" MODIFIED="1532791895468" TEXT="wurde schon entfernt">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1532789869240" ID="ID_752154716" MODIFIED="1561827465307" TEXT="gtk_key_snooper_install()">
|
|
<node CREATED="1532790015889" ID="ID_1497534470" MODIFIED="1576282358029" TEXT="@deprecated: 3.4">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
@deprecated: 3.4: Key snooping should not be done. Events should  be handled by widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1532790702292" ID="ID_1501770920" MODIFIED="1532790728882" TEXT="GTKmm: KeySnooperSig in main.h / main.cpp">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1532790997780" FOLDED="true" ID="ID_1359312516" MODIFIED="1561827483835" TEXT="ah: KeySnooperSig::connect()">
|
|
<icon BUILTIN="forward"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1532791032935" ID="ID_921226462" MODIFIED="1532791047721" TEXT="installiert eine GtkMainConnectionNode"/>
|
|
<node CREATED="1532791048453" ID="ID_1754300511" MODIFIED="1532791066007" TEXT="packt den Deregisrierungs-callback rein"/>
|
|
</node>
|
|
<node CREATED="1532791334135" ID="ID_669771307" MODIFIED="1576282358028">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wohl <b>einzige verbleibende</b> Verwendung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
finde keine andere mehr, bei suche nach GtkMainConnectionNode
|
|
</li>
|
|
<li>
|
|
auch der Kommentar zur Klasse sagt dieses (gtk_init_add wohl nicht mehr!)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532794546778" ID="ID_1120787097" MODIFIED="1533303442524" TEXT="GTK::Main nochmal geprüft">
|
|
<linktarget COLOR="#469fa6" DESTINATION="ID_1120787097" ENDARROW="Default" ENDINCLINATION="1725;-6805;" ID="Arrow_ID_433910583" SOURCE="ID_236361713" STARTARROW="None" STARTINCLINATION="821;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1533303793015" ID="ID_1894791438" MODIFIED="1533304526458" TEXT="Infos zu Gtk::Main, Gtk::Application und Gio::Application">
|
|
<arrowlink COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-652;20;" ID="Arrow_ID_315633048" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533304463274" HGAP="91" ID="ID_693983942" MODIFIED="1533304538638" TEXT="Initialisierung" VSHIFT="5">
|
|
<node CREATED="1532795620784" ID="ID_1782393731" MODIFIED="1533304483942" TEXT="gtk_init">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1532796724776" ID="ID_1145845020" MODIFIED="1532796729971" TEXT="bleibt weiterhin bestehen"/>
|
|
<node CREATED="1532796730560" ID="ID_1851309737" MODIFIED="1532796741082" TEXT="wird von jeder Applikations-Klasse aufgerufen"/>
|
|
</node>
|
|
<node CREATED="1533304499504" ID="ID_1636222563" MODIFIED="1533304499504" TEXT="Main::init_gtkmm_internals">
|
|
<node CREATED="1532796682566" ID="ID_591452701" MODIFIED="1532796691801" TEXT="Glib, Gio und Pango initialisieren"/>
|
|
<node CREATED="1532796692445" ID="ID_1979586408" MODIFIED="1532796706398" TEXT="Wrapper-Mechanismus für Gtk+-"Objekte" initialisieren"/>
|
|
<node CREATED="1532794561968" ID="ID_235365968" MODIFIED="1561827465308" TEXT="ist das zukunfts-fest?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1532796634853" ID="ID_375193574" MODIFIED="1532796646840" TEXT="in application.cc gibts die gleiche Funktion">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1532796648307" ID="ID_1796239536" MODIFIED="1532796654824" TEXT="kein Grund zur Sorge">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533310237105" ID="ID_937500948" MODIFIED="1576282358028" TEXT="sonst nichts...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist explizit so gewünscht
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
keine Kommandozeilen-Behandlung
|
|
</li>
|
|
<li>
|
|
keine "Registrierung" jedweder Art
|
|
</li>
|
|
<li>
|
|
keine D-Bus-connection
|
|
</li>
|
|
<li>
|
|
kein Application-Lifecycle
|
|
</li>
|
|
<li>
|
|
folglich auch <b>kein Aktivierungs-Signal</b>
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532797168836" ID="ID_1283695968" MODIFIED="1533325339452" TEXT="diesen Stand dokumentieren...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1532797180066" ID="ID_687615166" MODIFIED="1532797192496" TEXT="siehe Ticket #1032">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533218052308" ID="ID_1734927969" LINK="https://lumiera.org/documentation/technical/code/gtk/index.html" MODIFIED="1664481533409" TEXT="neue Kategorie: technical/code base/ GTK">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533218096245" ID="ID_1901487140" MODIFIED="1533325344852" TEXT="dort Seite startup">
|
|
<arrowlink COLOR="#dc217a" DESTINATION="ID_539459561" ENDARROW="Default" ENDINCLINATION="33;201;" ID="Arrow_ID_601982135" STARTARROW="None" STARTINCLINATION="-55;-186;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533218137447" ID="ID_59387223" MODIFIED="1533218142874" TEXT="lose Notizen dorthin"/>
|
|
<node CREATED="1533218147981" ID="ID_1385133985" MODIFIED="1533218153417" TEXT="Main vs Application"/>
|
|
<node CREATED="1533218154141" ID="ID_511849124" MODIFIED="1533218165327" TEXT="unser Ansatz"/>
|
|
<node CREATED="1533218170914" ID="ID_1610394794" MODIFIED="1533218176629" TEXT="was macht Main?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1532793816029" ID="ID_519518808" MODIFIED="1561827465309" TEXT="Glib::Dispatcher">
|
|
<linktarget COLOR="#c1a9ad" DESTINATION="ID_519518808" ENDARROW="Default" ENDINCLINATION="70;0;" ID="Arrow_ID_985135564" SOURCE="ID_1796116534" STARTARROW="None" STARTINCLINATION="149;-223;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1532793842721" ID="ID_1258451078" MODIFIED="1532793868919" TEXT="schon integriert in unseren UiDispatcher">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1532793854287" ID="ID_1072348424" MODIFIED="1532793872744" TEXT="installiert in dem NotificationService">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533310357440" ID="ID_250151476" MODIFIED="1533310362540" TEXT="kommt nicht in Frage">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1533310371726" ID="ID_682159285" MODIFIED="1533310393879" TEXT="signalisiert nur einen Trigger"/>
|
|
<node CREATED="1533310381845" ID="ID_833159461" MODIFIED="1533310389328" TEXT="setzt laufende event-Loop voraus"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533310412185" ID="ID_968448480" MODIFIED="1561827465309" TEXT="Aktivierungs-Signal">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1533310421328" ID="ID_1168151937" MODIFIED="1533310429603" TEXT="Gtk::Application macht das so"/>
|
|
<node CREATED="1533310430167" ID="ID_1809941457" MODIFIED="1533310441873" TEXT="setzt eine GApplication (=Gio::Application) voraus"/>
|
|
<node CREATED="1533310442557" ID="ID_1182449800" MODIFIED="1533310447656" TEXT="und das wollen wir nicht"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533310502420" ID="ID_1045876919" MODIFIED="1533388596803" TEXT="Glib::SignalTimeout nutzen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1532788656585" ID="ID_99363690" MODIFIED="1561827465312" TEXT="geeignet ansiedeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1532794614249" ID="ID_884179844" MODIFIED="1532794617028" TEXT="Plan">
|
|
<node CREATED="1532794617968" ID="ID_1917693631" MODIFIED="1533310766197" TEXT="geeigneten Zugang vom Ctor-Code">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1532794630007" ID="ID_1449747192" MODIFIED="1533310797536" TEXT="dieser installiert unseren Callback">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1532794643461" ID="ID_1862931436" MODIFIED="1532794664726" TEXT="dieser sendet in der Loop das Aktivierungs-Command">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533221103349" FOLDED="true" ID="ID_1053145038" MODIFIED="1533388653067" TEXT="Anker">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533221107205" ID="ID_1202141905" MODIFIED="1533221141349" TEXT="es muß der InteractionDirector sein">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533221115139" ID="ID_1655397510" MODIFIED="1533221117607" TEXT="wer sonst?"/>
|
|
<node CREATED="1533221118267" ID="ID_517862983" MODIFIED="1533221132317" TEXT="er verkörpert "das Globale""/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1533221145295" ID="ID_45639892" MODIFIED="1664059212889" TEXT="Problem: Zugang zum NotificationService">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1533221554888" ID="ID_1545304194" MODIFIED="1533221603239" TEXT="wird explizit erst von UiManager::performMainLoop() installiert">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1533221577485" ID="ID_890031207" MODIFIED="1533221596939" TEXT="Problem für allen Setup-Code aus InteractionDirector et al">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1533221649380" ID="ID_727991171" MODIFIED="1533221669408">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist ein <i>akzidentelles Problem</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1533221681199" ID="ID_979914270" MODIFIED="1576282358027" TEXT="Folge unserer Architektur">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn es ist gradezu der Sinn von Glib::Dispatcher,
|
|
</p>
|
|
<p>
|
|
schon vor der Loop verfügbar zu sein (?)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1533221752837" ID="ID_583598881" MODIFIED="1533310555941" TEXT="verifizieren: ist Glib::Dispatcher die richtige Technik">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1533310564980" ID="ID_1796116534" MODIFIED="1576282358027" TEXT="ist es nicht...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur bei laufender Event-Loop
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#c1a9ad" DESTINATION="ID_519518808" ENDARROW="Default" ENDINCLINATION="70;0;" ID="Arrow_ID_985135564" STARTARROW="None" STARTINCLINATION="149;-223;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533223360183" ID="ID_1309454354" MODIFIED="1561827465315" TEXT="Idee: weiterer Dispatcher">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1533223371534" ID="ID_891597430" MODIFIED="1533310719489" TEXT="UiDispatcher">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1533223377381" ID="ID_1197977205" MODIFIED="1533223383568" TEXT="einfach eine weitere Instanz davon"/>
|
|
<node CREATED="1533223384180" ID="ID_141172630" MODIFIED="1533252147479" TEXT="geht das?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1533252148493" ID="ID_535856197" MODIFIED="1533252155392" TEXT="geht nicht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1533252156737" ID="ID_945337228" MODIFIED="1533252171708" TEXT="Glib::Dispatcher ist nur eine FiFo"/>
|
|
<node CREATED="1533252172584" ID="ID_230437417" MODIFIED="1533252187890" TEXT="setzt zwingend voraus, daß die Event-Loop schon läuft"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533221770859" ID="ID_1962039642" MODIFIED="1561827465319" TEXT="dafür einen dedizierten Service einbauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1533310637466" ID="ID_1772394299" MODIFIED="1533385333187" TEXT="wo?">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533221796823" ID="ID_179436166" MODIFIED="1533310650010" TEXT="im UiManager">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533221813285" ID="ID_1627865297" MODIFIED="1533221816584" TEXT="aus logischen Gründen"/>
|
|
<node CREATED="1533221818572" ID="ID_806537689" MODIFIED="1533221826270" TEXT="paßt auch thematisch dort hin"/>
|
|
</node>
|
|
<node CREATED="1533311253662" ID="ID_704687465" MODIFIED="1533311258358" TEXT="was?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1533311314709" ID="ID_277761751" MODIFIED="1533385647446" TEXT="wirklich in der Loop?">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_277761751" ENDARROW="Default" ENDINCLINATION="-48;213;" ID="Arrow_ID_1127398125" SOURCE="ID_748660217" STARTARROW="None" STARTINCLINATION="256;0;"/>
|
|
<node CREATED="1533311322220" ID="ID_1614182663" MODIFIED="1576282358026" TEXT="Fenster-aktivieren passiert vor der Loop">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist für mich eine neue Einsicht.
|
|
</p>
|
|
<p>
|
|
Die Anzeige eines Fensters und die Event-Verarbeitung sind zunächst einmal unabhängig voneinander.
|
|
</p>
|
|
<p>
|
|
Sie sind aber aufeinander angewiesen. Die Events machen das Fenster reaktiv, aber ohne
|
|
</p>
|
|
<p>
|
|
Fenster gibt es gar keine Benutzer-Events.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533311415455" ID="ID_1211339520" MODIFIED="1533311614570" TEXT="GTK-Aktivierungs-Mechanismus hat andere Gründe">
|
|
<arrowlink COLOR="#949fb4" DESTINATION="ID_1806268533" ENDARROW="Default" ENDINCLINATION="-1845;-608;" ID="Arrow_ID_1146394851" STARTARROW="None" STARTINCLINATION="-474;0;"/>
|
|
</node>
|
|
<node CREATED="1533311655519" ID="ID_946023766" MODIFIED="1561827465319">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber <i>wir</i> brauchen ein <b>laufendes</b> UI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533311682171" ID="ID_1084601430" MODIFIED="1533311693093" TEXT="und zwar für die Antworten aus Proc-Layer"/>
|
|
<node CREATED="1533311693705" ID="ID_152811842" MODIFIED="1533311698877" TEXT="Facade muß offen sein"/>
|
|
<node CREATED="1533311707207" ID="ID_364798350" MODIFIED="1533311732464" TEXT="der Glib::Dispatcher darf nicht ins Leere gehen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533311794860" ID="ID_11666506" MODIFIED="1533311813929" TEXT="ein Command aus der event-Loop heraus">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533311818120" ID="ID_413505030" MODIFIED="1533325891506" TEXT="Forschung: wie machbar?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1533311849484" ID="ID_741726269" MODIFIED="1533311856167" TEXT="Problem: gtk_main blockt"/>
|
|
<node CREATED="1533311863586" ID="ID_1275401100" MODIFIED="1533311895161" TEXT="jeder Aufruf davor könnte zum Race führen"/>
|
|
<node CREATED="1533311922114" ID="ID_542781128" MODIFIED="1533325883642" TEXT="gibt es dazu irgendwelche Doku?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1533311999743" ID="ID_159524494" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-the-constraints.html.de" MODIFIED="1533312023736" TEXT="GTKmm-Tutorial: multithreaded">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533312933850" ID="ID_151434027" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-idle-functions.html.en" MODIFIED="1533312947999" TEXT="Idle / Timeout-Beispiel"/>
|
|
</node>
|
|
<node CREATED="1533312248199" ID="ID_1852545829" MODIFIED="1533314003668" TEXT="was ist mit Glib::SignalIdle und SignalTimeout?">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533314025414" ID="ID_408671915" MODIFIED="1533385371119" TEXT="Glib::signal_timeout()">
|
|
<arrowlink COLOR="#375fa2" DESTINATION="ID_1586631508" ENDARROW="Default" ENDINCLINATION="88;0;" ID="Arrow_ID_258924675" STARTARROW="None" STARTINCLINATION="-87;42;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1533314031621" ID="ID_1030647718" MODIFIED="1533314158876" TEXT="das ist wohl die beste Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1533314040716" ID="ID_314344665" MODIFIED="1533314158876" TEXT="fügt eine minimale Karenz-Zeit ein"/>
|
|
<node CREATED="1533314084613" ID="ID_1361630751" MODIFIED="1533314158876" TEXT="gut für die System-Stabilität">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533385296078" ID="ID_911350305" MODIFIED="1533388643836" TEXT="einfache direkt Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533385305101" ID="ID_1586631508" MODIFIED="1533388506937" TEXT="Glib::signal_timeout() lokal nutzen">
|
|
<arrowlink COLOR="#5568a6" DESTINATION="ID_580405745" ENDARROW="Default" ENDINCLINATION="-472;0;" ID="Arrow_ID_244184105" STARTARROW="None" STARTINCLINATION="-2132;-72;"/>
|
|
<linktarget COLOR="#375fa2" DESTINATION="ID_1586631508" ENDARROW="Default" ENDINCLINATION="88;0;" ID="Arrow_ID_258924675" SOURCE="ID_408671915" STARTARROW="None" STARTINCLINATION="-87;42;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533385573236" ID="ID_220261898" MODIFIED="1533386018084" TEXT="Begründung">
|
|
<node CREATED="1533385581435" ID="ID_613721842" MODIFIED="1533385589533" TEXT="ich glaube, das bleibt ein Einzelfall"/>
|
|
<node CREATED="1533385595528" ID="ID_748660217" MODIFIED="1533385647446" TEXT="es muß wirklich in der Event-Loop laufen">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_277761751" ENDARROW="Default" ENDINCLINATION="-48;213;" ID="Arrow_ID_1127398125" STARTARROW="None" STARTINCLINATION="256;0;"/>
|
|
</node>
|
|
<node CREATED="1533385674860" ID="ID_204825661" MODIFIED="1576282358026" TEXT="minimale Verzögerung nach Prgrammstart ist gut">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dann kann sich das Sytem erst mal <i>beruhigen</i>
|
|
</p>
|
|
<p>
|
|
nach der Lastspitze zum Programmstart, für den viel Code geladen werden mußte.
|
|
</p>
|
|
<p>
|
|
Außerdem hatten dann die anderen Subsysteme schon Zeit, ihre Grunddatenstrukturen aufzubauen;
|
|
</p>
|
|
<p>
|
|
im Besonderen spekulieren wir darauf, daß die Session-Daten bereits geladen sind,
|
|
</p>
|
|
<p>
|
|
und daher der Diff direkt und kompakt in einem Durchgang emittiert werden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533385403578" ID="ID_340344973" MODIFIED="1533388551009" TEXT="direkt im InteractionDirector">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1533388656903" ID="ID_1245171257" MODIFIED="1533388664575" TEXT="verdrahtet im ctor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533388528345" ID="ID_281702031" MODIFIED="1533388548893" TEXT="Trigger-Zeit">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1533388533248" ID="ID_526629253" MODIFIED="1533388538867" TEXT="vorerst fest verdrahtet"/>
|
|
<node CREATED="1533388539455" ID="ID_20867821" MODIFIED="1533388544338" TEXT="wähle 100ms"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533388675213" ID="ID_1893531200" MODIFIED="1533388686365" TEXT="funktioniert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531423784657" ID="ID_1434932428" MODIFIED="1557498707233" TEXT="Inhalts-Empfang wieder deaktivieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1480694550601" ID="ID_501539344" MODIFIED="1557498707233" TEXT="re-populate Content">
|
|
<linktarget COLOR="#fec680" DESTINATION="ID_501539344" ENDARROW="Default" ENDINCLINATION="-1280;-81;" ID="Arrow_ID_938812574" SOURCE="ID_977311190" STARTARROW="None" STARTINCLINATION="335;22;"/>
|
|
<linktarget COLOR="#fec2a0" DESTINATION="ID_501539344" ENDARROW="Default" ENDINCLINATION="-1291;-991;" ID="Arrow_ID_189200159" SOURCE="ID_316046833" STARTARROW="None" STARTINCLINATION="-1328;59;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1538942086509" ID="ID_1492693885" MODIFIED="1557498707233" TEXT="wenn ein UI-Element für eine bestehende Entität wiederaufgebaut wird">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1539134153912" ID="ID_311986051" MODIFIED="1557498707233" TEXT="Grundsatzentscheidung: re-populate">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539134197011" ID="ID_1798515652" MODIFIED="1557498707233" TEXT="mögliche Modelle">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1539134201394" ID="ID_1071210666" MODIFIED="1576282358025" TEXT="UI-Komponente realisiert sich selbst">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Komponente hat eine interne Struktur-Repräsentation
|
|
</li>
|
|
<li>
|
|
traversiert diese Struktur-Beschreibung
|
|
</li>
|
|
<li>
|
|
und übersetzt sie in UI-Widgets
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1539134224759" ID="ID_766070060" MODIFIED="1576282358024" TEXT="Struktur und Realisierung gemeinsam gepusht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
jedes Teilelement wird per Push injiziert
|
|
</li>
|
|
<li>
|
|
es wird in dem Moment sofort und ausschließlich als Widget realisiert
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539134474262" ID="ID_1194066582" MODIFIED="1557498707233" TEXT="Begründung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539134479525" ID="ID_11375493" MODIFIED="1557498707233" TEXT="Selbst-"Verdoppelung" vermeiden"/>
|
|
<node CREATED="1539134556931" ID="ID_876466376" MODIFIED="1557498707233" TEXT="Widgets selber sind "die Struktur""/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539134621210" ID="ID_1536657208" MODIFIED="1557498707233" TEXT="Konsequenz: »populier-mich«">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1539134702831" ID="ID_250983627" MODIFIED="1557498707233" TEXT="Objekt als leere Hülle vorausgesetzt"/>
|
|
<node CREATED="1539134713846" ID="ID_1404883972" MODIFIED="1557498707233" TEXT="schickt alle Details und Inhalte als Diff"/>
|
|
<node CREATED="1539134733747" ID="ID_353086867" MODIFIED="1576282358024">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Basis: <b>DiffConstituent</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
ein selbstbezüglicher substanzloser Strukturkern
|
|
</li>
|
|
<li>
|
|
DiffConstituent -> emanation as diff
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#4e31e2" DESTINATION="ID_1189184036" ENDARROW="Default" ENDINCLINATION="-767;-123;" ID="Arrow_ID_156898929" STARTARROW="None" STARTINCLINATION="-1608;-84;"/>
|
|
<node CREATED="1539138549468" ID="ID_1203696589" MODIFIED="1557498707233" TEXT="existiert "irgendwo""/>
|
|
<node CREATED="1539138556651" ID="ID_1265568834" MODIFIED="1557498707233" TEXT="per Command ansprechbar"/>
|
|
<node CREATED="1539138563657" ID="ID_1727875453" MODIFIED="1557498707233" TEXT="antwortet mit Emanation in Diff-Form"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1477784813895" ID="ID_791449946" MODIFIED="1557498707233">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Aufgabe</u>: <i><font color="#821b58" size="4">inject dummy content</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#f9b709" DESTINATION="ID_791449946" ENDARROW="Default" ENDINCLINATION="-842;-559;" ID="Arrow_ID_1347689482" SOURCE="ID_635303062" STARTARROW="None" STARTINCLINATION="-81;124;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533403103076" ID="ID_294556843" MODIFIED="1557498707233" TEXT="hart gecodetes Diff im Command erzeugen">
|
|
<linktarget COLOR="#e34459" DESTINATION="ID_294556843" ENDARROW="Default" ENDINCLINATION="287;0;" ID="Arrow_ID_1612526412" SOURCE="ID_488294111" STARTARROW="None" STARTINCLINATION="190;339;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533403146566" ID="ID_1948086597" MODIFIED="1557498707233" TEXT="Diff-Empfang im InteractionDirector implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533403169195" ID="ID_1916047269" MODIFIED="1557498707233" TEXT="erst mal nur Platzhalter einfügen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1533403179257" ID="ID_1147163352" MODIFIED="1557498707233" TEXT="noch nicht via ViewLocator platzieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1533403199535" ID="ID_1545782665" MODIFIED="1557498707233" TEXT="sonst wird das nie was...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539270491013" ID="ID_1387553695" MODIFIED="1557498707233" TEXT="Problem der korrekten Diff-Struktur">
|
|
<arrowlink COLOR="#d47366" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="713;-263;" ID="Arrow_ID_971172326" STARTARROW="None" STARTINCLINATION="-1999;120;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1539270491013" ID="ID_19523487" MODIFIED="1557498707233" TEXT="Diff-Fehler-Behandlung">
|
|
<arrowlink COLOR="#d47366" DESTINATION="ID_946219609" ENDARROW="Default" ENDINCLINATION="713;-263;" ID="Arrow_ID_1085344706" STARTARROW="Default" STARTINCLINATION="-1999;120;"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node CREATED="1539388486494" ID="ID_1071396667" MODIFIED="1557498707233" TEXT="was ist sinnvoll?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1539388494261" ID="ID_586705343" MODIFIED="1557498707233" TEXT="Applikation runterfahren"/>
|
|
<node CREATED="1539388507796" ID="ID_1481564093" MODIFIED="1557498707233" TEXT="Zweig neu populieren"/>
|
|
<node CREATED="1539388543735" ID="ID_927207087" MODIFIED="1557498707233" TEXT="Element defekt markieren"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539388552973" ID="ID_559690288" MODIFIED="1557498707233" TEXT="TODO: eigenen Fehler-Handler einbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1539388561357" ID="ID_148293105" MODIFIED="1557498707233" TEXT="im Moment wirkt der default-Fehlerhandler">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1539388573371" ID="ID_163915101" MODIFIED="1557498707233" TEXT="im Dispatcher für den Notification-Service">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1539388588153" ID="ID_215543967" MODIFIED="1557498707233" TEXT="und der fährt die Applikation runter">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541547600640" ID="ID_787025622" MODIFIED="1557498707233" TEXT="Element-IDs müssen eindeutig sein">
|
|
<arrowlink COLOR="#c9876a" DESTINATION="ID_1850412206" ENDARROW="Default" ENDINCLINATION="49;-155;" ID="Arrow_ID_1571993328" STARTARROW="None" STARTINCLINATION="-11;173;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1541807934354" ID="ID_306409593" MODIFIED="1557498707233" TEXT="jedesmal explizit einen zufälligen Hash verwenden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1541807922861" ID="ID_811005250" MODIFIED="1557498707233" TEXT="idi::RandID">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423428942" ID="ID_1847992077" MODIFIED="1557498707233" TEXT="Stop"/>
|
|
</node>
|
|
<node CREATED="1488423436478" ID="ID_1037695008" MODIFIED="1557498707233" TEXT="Einstieg">
|
|
<node CREATED="1488423440629" ID="ID_1295897045" MODIFIED="1561151251774" TEXT="in Timeline">
|
|
<linktarget COLOR="#8d8ba5" DESTINATION="ID_1295897045" ENDARROW="Default" ENDINCLINATION="534;-456;" ID="Arrow_ID_150397161" SOURCE="ID_839909208" STARTARROW="None" STARTINCLINATION="440;114;"/>
|
|
<node CREATED="1488423569203" ID="ID_1753722831" MODIFIED="1612527189081" TEXT="TimelinePane anzeigen">
|
|
<linktarget COLOR="#a1543e" DESTINATION="ID_1753722831" ENDARROW="Default" ENDINCLINATION="1192;-274;" ID="Arrow_ID_912757548" SOURCE="ID_292894978" STARTARROW="None" STARTINCLINATION="408;-90;"/>
|
|
</node>
|
|
<node CREATED="1488423579514" ID="ID_1433755621" MODIFIED="1557498707233" TEXT="TimelineWidget erzeugen"/>
|
|
<node CREATED="1488470479857" ID="ID_978142233" MODIFIED="1557498707233" TEXT="geschieht...">
|
|
<node CREATED="1488470484168" ID="ID_1028709294" MODIFIED="1557498707233" TEXT="explizit auf Anforderung (Window-Menü)"/>
|
|
<node CREATED="1488470499710" ID="ID_1839340183" MODIFIED="1557498707233" TEXT="automatisch durch Laden der Session"/>
|
|
</node>
|
|
<node CREATED="1488470528522" HGAP="38" ID="ID_141494228" MODIFIED="1557498707233" TEXT="Ablauf" VSHIFT="11">
|
|
<node CREATED="1488470538209" ID="ID_1192459841" MODIFIED="1557498707233" TEXT="Controller"/>
|
|
<node CREATED="1488470541432" ID="ID_950213497" MODIFIED="1557498707233" TEXT="holt Model-Repräsentation"/>
|
|
<node CREATED="1488470548848" ID="ID_1686896502" MODIFIED="1557498707233" TEXT="weiß den Ankerpukt / Zielcontainer"/>
|
|
<node CREATED="1488470574388" ID="ID_1331046626" MODIFIED="1557498707233" TEXT="erstellt in diesem ein neues Widget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423443916" ID="ID_1213960259" MODIFIED="1557498707233" TEXT="in Assets"/>
|
|
<node CREATED="1488423446860" ID="ID_1515465474" MODIFIED="1557498707233" TEXT="Viewer"/>
|
|
<node CREATED="1488423478536" ID="ID_1039556823" MODIFIED="1557498707233" TEXT="Projekt"/>
|
|
<node CREATED="1488423482303" ID="ID_1337577946" MODIFIED="1557498707233" TEXT="Optionen"/>
|
|
</node>
|
|
<node CREATED="1488423493014" ID="ID_64529473" MODIFIED="1557498707233" TEXT="Navigation"/>
|
|
<node CREATED="1613329386385" ID="ID_1761463492" MODIFIED="1613329391457" TEXT="Manipulation">
|
|
<node CREATED="1613334019420" ID="ID_273976893" MODIFIED="1613334021390" TEXT="Formen">
|
|
<node CREATED="1613333615153" ID="ID_1085666433" MODIFIED="1613333624019" TEXT="Parameter ändern"/>
|
|
<node CREATED="1613333666090" ID="ID_553562827" MODIFIED="1613333678204" TEXT="expandieren / reduzieren"/>
|
|
<node CREATED="1613334131322" ID="ID_58235423" MODIFIED="1613334141028" TEXT="weitere Navigationsvorgänge"/>
|
|
<node CREATED="1613333624820" ID="ID_563935930" MODIFIED="1613333633188" TEXT="Wiedergabemodus steuern"/>
|
|
<node CREATED="1613333635078" ID="ID_335562573" MODIFIED="1613334024426" TEXT="Edit-Aktionen">
|
|
<node CREATED="1613333732545" ID="ID_1462682314" MODIFIED="1613333745363" TEXT="Clip aus Bin einfügen"/>
|
|
<node CREATED="1613333746464" ID="ID_1372531625" MODIFIED="1613333836699" TEXT="Clip: verschieben (slide)"/>
|
|
<node CREATED="1613333751169" ID="ID_1489464895" MODIFIED="1613349460429" TEXT="Clip: Inhalt verschieben (shuffle)">
|
|
<arrowlink COLOR="#f6b667" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-9;-115;" ID="Arrow_ID_209732384" STARTARROW="None" STARTINCLINATION="220;19;"/>
|
|
</node>
|
|
<node CREATED="1613333842378" ID="ID_381580402" MODIFIED="1613333859963" TEXT="Clip: trimmen"/>
|
|
<node CREATED="1613333860599" ID="ID_1789286116" MODIFIED="1613333863659" TEXT="Clip: rollen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1613334058285" ID="ID_699726141" MODIFIED="1613334067760" TEXT="Konzept">
|
|
<node CREATED="1613334069323" ID="ID_1723320752" MODIFIED="1613334078757" TEXT="die Manipulation wird durch eine Geste eingeleitet"/>
|
|
<node CREATED="1613334079466" ID="ID_1589128984" MODIFIED="1613334088647" TEXT="sie führt in einen Manipulations-Modus"/>
|
|
<node CREATED="1613334091808" ID="ID_1887267653" MODIFIED="1613334098755" TEXT="dieser wird durch eine Befehls-Geste beendet"/>
|
|
<node CREATED="1661695780231" ID="ID_1944954005" MODIFIED="1661695793169" TEXT="klassische Menü-Aktion als einfacher Sonderfall"/>
|
|
</node>
|
|
<node CREATED="1613334160328" ID="ID_1964361228" MODIFIED="1613334167289" TEXT="konstruktives Problem">
|
|
<node CREATED="1613334172704" ID="ID_1733713020" MODIFIED="1613334204445" TEXT="typischerweise wird dieses gemeinsame Schema übersehen"/>
|
|
<node CREATED="1613334205144" ID="ID_1296878721" MODIFIED="1613334219861" TEXT="daher ist es üblich, diese Manipulationen lokal und ad hoc zu implementieren"/>
|
|
<node CREATED="1613334249690" ID="ID_1792797047" MODIFIED="1613334275524" TEXT="⟹ in den Frameworks fehlt der abstrakte gemeiname Einstiegspunkt">
|
|
<node CREATED="1613334316121" ID="ID_1190900510" MODIFIED="1613334356211" TEXT="GTK bietet nur ein copy/move drag-n-drop">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und das zu allem Überfluß auch noch ziemlich hart verdrahtet. Man kann nicht einmal frei über die Modifier-Keys verfügen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1624022146150" ID="ID_76300118" MODIFIED="1624022166911" TEXT="daneben viel zu generischer low-Level Gesten-Controller"/>
|
|
<node CREATED="1613334362547" ID="ID_894562756" MODIFIED="1613334386083" TEXT="andere Gesten sind im Einzelwidget implementiert"/>
|
|
</node>
|
|
<node CREATED="1613334402564" ID="ID_1103909311" MODIFIED="1613349184568" TEXT="wir müssen lauter dezentrale Einstiegspunkte bauen">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#cec3da" CREATED="1613917449274" HGAP="42" ID="ID_1824168791" MODIFIED="1613917680542" VSHIFT="4">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Achtung</u>: <i><font color="#402160">abstrakter Entwurf war Ende 2017 in eine Sackgasse geraten....</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#7b7696" DESTINATION="ID_1743832326" ENDARROW="Default" ENDINCLINATION="321;-3493;" ID="Arrow_ID_741454137" STARTARROW="None" STARTINCLINATION="-1170;44;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1613349240614" FOLDED="true" ID="ID_1472064878" MODIFIED="1679359272732" TEXT="erster Entwurf: drag clip">
|
|
<linktarget COLOR="#fbd7b5" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-1443;-151;" ID="Arrow_ID_1918638969" SOURCE="ID_1784185766" STARTARROW="None" STARTINCLINATION="1644;332;"/>
|
|
<linktarget COLOR="#3a4d88" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-642;-252;" ID="Arrow_ID_1448328801" SOURCE="ID_1520693411" STARTARROW="None" STARTINCLINATION="-826;77;"/>
|
|
<linktarget COLOR="#f6b667" DESTINATION="ID_1472064878" ENDARROW="Default" ENDINCLINATION="-9;-115;" ID="Arrow_ID_209732384" SOURCE="ID_1489464895" STARTARROW="None" STARTINCLINATION="220;19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1613349479473" ID="ID_1618505083" MODIFIED="1613349488782" TEXT="Doku / Tutorials">
|
|
<node CREATED="1613349541627" ID="ID_1745870905" MODIFIED="1613349560713" TEXT="man muß das motion_notify_event beobachten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1613349562305" ID="ID_601856481" MODIFIED="1613349567420" TEXT="das ist ein GDK-Event"/>
|
|
<node CREATED="1613349568104" ID="ID_1883086551" MODIFIED="1613349579450" TEXT="also das Low-level-System"/>
|
|
</node>
|
|
<node CREATED="1613349531741" ID="ID_84820441" LINK="https://gist.github.com/KurtJacobson/57679e5036dc78e6a7a3ba5e0155dad1" MODIFIED="1613349537230" TEXT="Beispiel C"/>
|
|
<node CREATED="1613349637668" ID="ID_1098657356" LINK="http://www.kcjengr.com/programing/2017/10/16/dragable-gtk-widgets.html" MODIFIED="1613349643402" TEXT="Beispiel Python"/>
|
|
</node>
|
|
<node CREATED="1613948743240" ID="ID_493349480" MODIFIED="1613948751697" TEXT="klar ist bisher...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1613948753365" ID="ID_1004192521" MODIFIED="1613948775315" TEXT="das Command-Framework wird das nicht lösen können"/>
|
|
<node CREATED="1613948776291" ID="ID_889206511" MODIFIED="1613948802398" TEXT="es wird irgendwo einen InteractionState geben (einen pro Art der Geste)"/>
|
|
<node CREATED="1613949082860" ID="ID_783934711" MODIFIED="1613949094507" TEXT="die Grundzüge der Interaktion sind klar">
|
|
<node CREATED="1613948886082" ID="ID_715355641" MODIFIED="1613948906861" TEXT="drag-start: wird in einem ClipWidget registriert"/>
|
|
<node CREATED="1613948907784" ID="ID_544273304" MODIFIED="1613948924747" TEXT="..muß aber im InteractionState qualifiziert werden"/>
|
|
<node CREATED="1613948926156" ID="ID_1360301287" MODIFIED="1613948955718" TEXT="dieses Widget empfängt die Bewegungs-Nachrichten"/>
|
|
<node CREATED="1613948956471" ID="ID_16210689" MODIFIED="1613948967678" TEXT="es gibt sie aber nur weiter, wenn eine Geste erwartet wird"/>
|
|
<node CREATED="1613948968503" ID="ID_388032830" MODIFIED="1613948989927" TEXT="außerdem muß der Canvas instruiert werden, das CliipWidget zu verschieben"/>
|
|
<node CREATED="1613949007667" ID="ID_1378086489" MODIFIED="1613949053999" TEXT="die Vollendung der Geste wird am "button up" im ClipWidget erkannt"/>
|
|
<node CREATED="1613949054869" ID="ID_1463749596" MODIFIED="1613949079061" TEXT="daraufhin muß aber der ClipPresenter eine UI-Bus-Nachricht absetzen"/>
|
|
</node>
|
|
<node CREATED="1613948811142" ID="ID_1149934346" MODIFIED="1613948873809" TEXT="Verknüpfung von Widgets und InteractionState erfordert einen generischen Adapter"/>
|
|
<node CREATED="1613949125310" ID="ID_1021022187" MODIFIED="1613949147008" TEXT="die Zustands-Aktualisierungen laufen über direkte Referenzen (nicht den UI-Bus)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1614379765040" FOLDED="true" ID="ID_1624270915" MODIFIED="1665962528052" TEXT="neuer Anlauf für Kontext-bezogene Commands">
|
|
<arrowlink COLOR="#5b4964" DESTINATION="ID_1221036425" ENDARROW="Default" ENDINCLINATION="717;-46;" ID="Arrow_ID_1875882072" STARTARROW="None" STARTINCLINATION="586;34;"/>
|
|
<linktarget COLOR="#425c68" DESTINATION="ID_1624270915" ENDARROW="Default" ENDINCLINATION="-809;-2134;" ID="Arrow_ID_1181760372" SOURCE="ID_719593541" STARTARROW="None" STARTINCLINATION="-299;13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1614380675501" ID="ID_163523275" MODIFIED="1679359214827" TEXT="Leitfrage: was muß ich jetzt konkret anlegen, damit »drag Clip« in dieses Schema paßt?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1614380743899" HGAP="64" ID="ID_715469259" MODIFIED="1614380757248" TEXT="Analyse" VSHIFT="-6">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1614380762451" ID="ID_378231511" MODIFIED="1614380766837" TEXT="Partizipatoren">
|
|
<node CREATED="1614380786753" ID="ID_1862030818" MODIFIED="1614380792732" TEXT="ClipWidget">
|
|
<node CREATED="1614380832080" ID="ID_1797079053" MODIFIED="1614380841322" TEXT="muß drag-Start erkennen"/>
|
|
<node CREATED="1614380867533" ID="ID_833092549" MODIFIED="1614380876261" TEXT="muß dann motion_notify_event weiterleiten"/>
|
|
</node>
|
|
<node CREATED="1614380910877" ID="ID_541454007" MODIFIED="1614380915543" TEXT="Timeline-Canvas">
|
|
<node CREATED="1614380965317" ID="ID_1975329261" MODIFIED="1614380978800" TEXT="muß das betroffene Widget verschieben"/>
|
|
<node CREATED="1614380979369" ID="ID_1760600349" MODIFIED="1614380989600" TEXT="soll hierzu per Callback angebunden sein"/>
|
|
</node>
|
|
<node CREATED="1614381237672" ID="ID_1040735870" MODIFIED="1614381241183" TEXT="ClipPresenter">
|
|
<node CREATED="1614381242128" ID="ID_511883791" MODIFIED="1614381252290" TEXT="muß zumindest das "SELF" beisteuern"/>
|
|
<node CREATED="1614381252903" ID="ID_1069833008" MODIFIED="1614381260737" TEXT="könnte am Ende auch das Command absetzen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614381332132" ID="ID_274933683" MODIFIED="1614381341167" TEXT="noch-unbekannt">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1614381342698" ID="ID_809693332" MODIFIED="1614381384588" TEXT="wer ist für on-demand-Scrolling zuständig?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1614381357868" ID="ID_1867964338" MODIFIED="1614381376540" TEXT="...wenn man einen Clip aus dem sichtbaren Bereich zieht...?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614381416016" ID="ID_1165918043" MODIFIED="1614381421355" TEXT="API-Design-Problem">
|
|
<node CREATED="1614381426919" ID="ID_149858385" MODIFIED="1614381468405" TEXT="der CmdContext ist ein generischer Zugang by-ID"/>
|
|
<node CREATED="1614381470240" ID="ID_1938759210" MODIFIED="1614381512746" TEXT="am Ende aber behandeln wir eine spezifische Interaktion">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1614381552342" ID="ID_134319916" MODIFIED="1614381561843" TEXT="CmdContext wird entweder ein sehr breites Interface"/>
|
|
<node CREATED="1614381562642" ID="ID_972576172" MODIFIED="1614389749670" TEXT="oder es wird ein Metasprache-Interface">
|
|
<arrowlink COLOR="#fbe4a1" DESTINATION="ID_826730643" ENDARROW="Default" ENDINCLINATION="25;-50;" ID="Arrow_ID_354156309" STARTARROW="None" STARTINCLINATION="-239;17;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614382663099" ID="ID_826730643" MODIFIED="1614389739519" TEXT="Lösungsidee: den Kontext als eine Sammlung von Rollen deuten">
|
|
<linktarget COLOR="#fbe4a1" DESTINATION="ID_826730643" ENDARROW="Default" ENDINCLINATION="25;-50;" ID="Arrow_ID_354156309" SOURCE="ID_972576172" STARTARROW="None" STARTINCLINATION="-239;17;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1614384116295" ID="ID_1776177560" MODIFIED="1614384119969" TEXT="Beispiele">
|
|
<node CREATED="1614384121198" ID="ID_2774291" MODIFIED="1614384129725" TEXT="Event-Quelle"/>
|
|
<node CREATED="1614384215162" ID="ID_1829307481" MODIFIED="1614384217061" TEXT="Subjekt"/>
|
|
<node CREATED="1614388125553" ID="ID_1734736450" MODIFIED="1614388160288" TEXT="FeedbackMove(x,y)"/>
|
|
<node CREATED="1614388133920" ID="ID_295955902" MODIFIED="1614388155250" TEXT="FeedbackDisplay(msg)"/>
|
|
<node CREATED="1614388168531" ID="ID_185828283" MODIFIED="1614388187058" TEXT="FeedbackHighlight()"/>
|
|
</node>
|
|
<node CREATED="1614389527598" ID="ID_1604040360" MODIFIED="1614389758762" TEXT="Problem hierbei">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1614389534082" ID="ID_80971854" MODIFIED="1614389541702" TEXT="Verklammerung mit einer Identität"/>
|
|
<node CREATED="1614389542530" ID="ID_318980247" MODIFIED="1614390448104" TEXT="Vielzahl von Subjekten und Identitäten"/>
|
|
</node>
|
|
<node CREATED="1614390858247" ID="ID_1423481025" MODIFIED="1614390883649" TEXT="Kontrast: naive Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1614390886131" ID="ID_1752630658" MODIFIED="1614390896133" TEXT="die Logik wird beim Subjekt untergebracht"/>
|
|
<node CREATED="1614390897026" ID="ID_78418004" MODIFIED="1614390913995" TEXT="Subjekt muß (sich) mit allen Partizipatoren verdrahten"/>
|
|
<node CREATED="1614391053221" ID="ID_285566042" MODIFIED="1614391083520" TEXT="Konsequenz: enge Kopplung, verteilte Logik">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1614391106909" FOLDED="true" ID="ID_829290263" MODIFIED="1679359207898" TEXT="Ausarbeitung dieser Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1614391126643" ID="ID_339143488" MODIFIED="1614391152827" TEXT="Grundlage">
|
|
<node CREATED="1614391153839" ID="ID_1357502282" MODIFIED="1614391168548" TEXT="CmdContext ist ein Metasprache-Interface">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1614391170141" ID="ID_832546901" MODIFIED="1614391190901" TEXT="es erlaubt, eine fest vorgegebene Auswahl an Rollen zu registrieren"/>
|
|
<node CREATED="1614391193833" ID="ID_1074859407" MODIFIED="1616685033738" TEXT="es erlaubt, einzelne Instanzen zu deregistrieren">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616685039180" HGAP="129" ID="ID_378066021" MODIFIED="1616685084561" TEXT="YAGNI?" VSHIFT="5">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614391222237" ID="ID_1021447273" MODIFIED="1614391253965" TEXT="jedes einzelne Interaktionsmuster ist individuell ausprogrammiert">
|
|
<node CREATED="1614391255630" ID="ID_1652285552" MODIFIED="1614391268915" TEXT="das bedeutet: es gibt ein implizites Protokoll"/>
|
|
<node CREATED="1614391269807" ID="ID_236795034" MODIFIED="1614391284866" TEXT="es wird Registrierung der genau passenden Rollen-Adapter unterstellt"/>
|
|
<node CREATED="1614391304259" ID="ID_1592976230" MODIFIED="1614391351824" TEXT="es muß Verdrahtungs-Hooks geben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nachdem sich eine Instanz einer Rolle gemeldet hat, kann der Hook sie individuell verknüpfen, typischerweise als Lambda
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1614391489665" ID="ID_1919040945" MODIFIED="1621013631256" TEXT="Verklammerung">
|
|
<node CREATED="1614391506656" ID="ID_1004859029" MODIFIED="1614391520280" TEXT="Event-Quelle muß mit einem Subjekt ausgezeichnet werden"/>
|
|
<node CREATED="1614391615637" FOLDED="true" ID="ID_1108644497" MODIFIED="1614391627843" TEXT="zur Event-Quelle wird eine Closure gebildet">
|
|
<node CREATED="1614391628734" ID="ID_1671010257" MODIFIED="1614391663130" TEXT="und zwar für den konkreten Typ der Interaktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also nicht generisch, sondern die spezifische Closure für z.B. den Fall drag-Clip
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1614391673368" ID="ID_205779868" MODIFIED="1614391685758" TEXT="diese Closure bestimmt, auf welche Events überhaupt gehört wird"/>
|
|
<node CREATED="1614391691166" ID="ID_367156594" MODIFIED="1614391711156" TEXT="d.h. zur Event-Quelle gibt es ein generisches Element wie z.B. GTK-Widget"/>
|
|
<node CREATED="1614391738263" ID="ID_1536053997" MODIFIED="1614391793230" TEXT="hier entsteht also eine Verquickung mit dem konkreten Framework">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
naja... sie besteht schon von Anfang an, insofern das Event-Konzept, wie auch die konkrete Quelle, ohnehin an das UI-Framework gebunden sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614391836482" ID="ID_1023680019" MODIFIED="1614391943348" TEXT="diese Closure enthält die konkrete Gesten-Erkennung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Beispiel: in dieser Closure wird zunächste eine Verdrahtung auf das button_down-Event angelegt. Wenn diese aktiviert wird, schaltet die die Beobachtung eines ebenfalls vorsorglich verdrahteten motion_notify_event ein, sowie analog das Warten auf ein button_up
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1614460011582" FOLDED="true" ID="ID_952822551" MODIFIED="1614460030108" TEXT="tatsächlich wird auf Dauer nur das Subjekt benötigt">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1614460032928" ID="ID_1290991040" MODIFIED="1614460064068" TEXT="die Event-Quelle dient nur dazu, das Reaktionsmuster zu verdrahten"/>
|
|
<node CREATED="1614460064989" ID="ID_1051234344" MODIFIED="1614460079097" TEXT="als Event-Quelle genügt eine Gtk::Widget-Referenz">
|
|
<node CREATED="1614460082069" ID="ID_1366205359" MODIFIED="1614460235413" TEXT="man kann alles auf Signale aufbauen">
|
|
<arrowlink COLOR="#6c87a6" DESTINATION="ID_1054817075" ENDARROW="Default" ENDINCLINATION="-7;-84;" ID="Arrow_ID_1471465547" STARTARROW="None" STARTINCLINATION="-115;9;"/>
|
|
</node>
|
|
<node CREATED="1614460100690" ID="ID_570431649" MODIFIED="1614460113953" TEXT="dann sorgt Sigc bereits für die Deregistrierung"/>
|
|
<node CREATED="1614460114904" ID="ID_1615356307" MODIFIED="1614460143452" TEXT="und da ein totes Widget keine Events mehr sendet, kann man den Eintrag "hängen" lassen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614460159682" ID="ID_1054817075" MODIFIED="1614460237067" TEXT="das eigentliche Verhaltensmuster ist komplett Event-getrieben">
|
|
<linktarget COLOR="#6c87a6" DESTINATION="ID_1054817075" ENDARROW="Default" ENDINCLINATION="-7;-84;" ID="Arrow_ID_1471465547" SOURCE="ID_1366205359" STARTARROW="None" STARTINCLINATION="-115;9;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1614475571869" FOLDED="true" ID="ID_1751028671" MODIFIED="1614543472364" TEXT="wie kann die Verklammerung realisiert werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1614475601650" ID="ID_205574857" MODIFIED="1614543459768" TEXT="allein über die Signal-Bindung ...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1614475633677" ID="ID_486152583" MODIFIED="1614475643040" TEXT="geht das überhaupt?"/>
|
|
<node CREATED="1614475655498" ID="ID_1837268445" MODIFIED="1614536263567" TEXT="Subjekt müßte dann als Parameter in den Handler mit eingespeist werden">
|
|
<node CREATED="1614475677163" ID="ID_1901993329" MODIFIED="1614475719301" TEXT="d.h. es gäbe nur eine generische Handler-Funktion"/>
|
|
<node CREATED="1614475736604" ID="ID_1260840315" MODIFIED="1614475769271" TEXT="und irgendwo (im Signal-Binding) ist ein Slot mit der Closure gespeichert"/>
|
|
</node>
|
|
<node CREATED="1614475793975" ID="ID_260944164" MODIFIED="1614543467968" TEXT="dann müßte man aber auch alles über den Subject/Adapter machen können">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1614475835082" ID="ID_1955774576" MODIFIED="1614475841413" TEXT="den bisherigen Offset abrufen"/>
|
|
<node CREATED="1614475842001" ID="ID_347860364" MODIFIED="1614475873560" TEXT="das aktuelle Delta aufschlagen"/>
|
|
<node CREATED="1614475874415" ID="ID_797516713" MODIFIED="1614475881762" TEXT="damit einen neuen Offset speichern"/>
|
|
<node CREATED="1614475938076" ID="ID_1703634175" MODIFIED="1614475990529" TEXT="alte Position abrufen"/>
|
|
<node CREATED="1614475991149" ID="ID_384791921" MODIFIED="1614475999767" TEXT="mit dem Offset daraus eine neue Position"/>
|
|
<node CREATED="1614476000827" ID="ID_1072166447" MODIFIED="1614476006449" TEXT="Widget dorthin verschieben"/>
|
|
<node CREATED="1614476007299" ID="ID_1457812219" MODIFIED="1614476017287" TEXT="schließlich den finalen Offset erfassen"/>
|
|
<node CREATED="1614476017872" ID="ID_397556906" MODIFIED="1614476038242" TEXT="diesen umwandeln in den Parameter-Raum (z.B. zeitliche Verschiebung)"/>
|
|
<node CREATED="1614476038998" ID="ID_148450923" MODIFIED="1614476054048" TEXT="und dieses Ergebnis in das Command binden"/>
|
|
<node CREATED="1614476058668" ID="ID_1803344399" MODIFIED="1614476066270" TEXT="das Command an den Bus übergeben"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614536448697" ID="ID_1492057742" MODIFIED="1614543456614" TEXT="ein Kontext pro Subjekt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1614536709750" ID="ID_186439136" MODIFIED="1614536736791" TEXT="in der Closure der Signal-Bindung steckt dann (nur) ein "this"-Pointer"/>
|
|
<node CREATED="1614539609634" ID="ID_603639357" MODIFIED="1614539653942" TEXT="die Daten zur Gesten-Erkennung und -Verfolgung sind in jedem Kontext aufgedoppelt">
|
|
<node CREATED="1614539908164" ID="ID_1719873670" MODIFIED="1614539911410" TEXT="Subjekt"/>
|
|
<node CREATED="1614539912070" ID="ID_246551713" MODIFIED="1614539915273" TEXT="Startposition"/>
|
|
<node CREATED="1614539918495" ID="ID_1406833293" MODIFIED="1614539926951" TEXT="aktuelle Pos oder Delta"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614540333938" ID="ID_498563982" MODIFIED="1614543450376" TEXT="Widget steuert die Drag-Geste selber">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1614540397688" ID="ID_622503022" MODIFIED="1614540432520" TEXT="es verwendet hierfür einen generischen Adapter">
|
|
<node CREATED="1614540445834" ID="ID_1198534535" MODIFIED="1614540458487" TEXT="dieser braucht dann aber einen Backpointer auf das Widget"/>
|
|
<node CREATED="1614540483740" ID="ID_479333673" MODIFIED="1614540507714" TEXT="jeder Adapter hat seine eigenen Zustands-Variablen"/>
|
|
<node CREATED="1614540516104" ID="ID_1112342686" MODIFIED="1614540538846" TEXT="und ein Backpointer auf das Subjekt wird auch noch benötigt"/>
|
|
</node>
|
|
<node CREATED="1614540567402" ID="ID_178069710" MODIFIED="1614540584842" TEXT="oder es enthält die Logik direkt ausprogrammiert"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1614540589382" ID="ID_1190969110" MODIFIED="1614541775944" TEXT="Fazit">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1614540612570" ID="ID_1031352571" MODIFIED="1614540626133" TEXT="Verklammerung über die Signalbindung ist die beste Lösung"/>
|
|
<node CREATED="1614540719919" ID="ID_103729106" MODIFIED="1614540833729" TEXT="spart Storage und hält die Logik zentral"/>
|
|
<node CREATED="1614540912673" ID="ID_1808809074" MODIFIED="1614540942883" TEXT="Subjekt muß aber auch Zugang zum Widget und zur Position bieten"/>
|
|
<node CREATED="1614541813489" ID="ID_1805140351" MODIFIED="1614541823710" TEXT="Installation des Bindings muß vom Subjekt ausgehen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1614543013138" ID="ID_1830318279" MODIFIED="1614543025940" TEXT="problematisch mit der bestehenden Implementierung"/>
|
|
<node CREATED="1614543026767" ID="ID_1302795590" MODIFIED="1614543817770" TEXT="bisher ist das ClipDelegate relativ eigenständig bzgl. Anzeigestil">
|
|
<arrowlink COLOR="#f45679" DESTINATION="ID_1754386766" ENDARROW="Default" ENDINCLINATION="93;-23;" ID="Arrow_ID_367937676" STARTARROW="None" STARTINCLINATION="-164;8;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1614543493162" ID="ID_1473378249" MODIFIED="1679362063109" TEXT="mit der bestehenden Implementierung verbinden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1614543561632" FOLDED="true" ID="ID_1754386766" MODIFIED="1621013612918" TEXT="diverse Widersprüche und Spannungen">
|
|
<linktarget COLOR="#f45679" DESTINATION="ID_1754386766" ENDARROW="Default" ENDINCLINATION="93;-23;" ID="Arrow_ID_367937676" SOURCE="ID_1302795590" STARTARROW="None" STARTINCLINATION="-164;8;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1614543836195" ID="ID_937435961" MODIFIED="1614543924536" TEXT="Koordinaten im Widget dargestellt als Domain-Werte (Zeit)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Umrechnung Zeit → Pixel habe ich im CanvasHook versteckt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#6c97d3" DESTINATION="ID_937435961" ENDARROW="Default" ENDINCLINATION="144;280;" ID="Arrow_ID_1259911083" SOURCE="ID_369222912" STARTARROW="None" STARTINCLINATION="-332;20;"/>
|
|
<node CREATED="1614545300952" ID="ID_1467191869" MODIFIED="1614545455246" TEXT="Lösung-1: per Übersetzungs-Service direkt manipulieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das bedeutet:<br />
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wenn im Event explizite Koordinaten vorkommen, dann müssen diese sofort umgerechnet werden in eine Zeit
|
|
</li>
|
|
<li>
|
|
aus der gegenwärtig im Clip gespeicherten Zeit ergibt sich dann ein Delta
|
|
</li>
|
|
<li>
|
|
dieses Delta wird sofort auf den Clip angewendet
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Am Ende der Geste steht die neue Zeit-Position fertig im Clip und wird von dort per Command in den Steam-Layer gesendet. Später, nach der Verarbeitung in der Session kommt ein Update über den UI-Bus, welches die Position überschreibt und infolgedessen ggfs auch nochmal das Widget verschiebt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1615558216850" ID="ID_351359335" MODIFIED="1615558243862" TEXT="Kennzeichnung: Geste manipuliert UI-Modell; es gibt kein "Zurück"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1614545483516" ID="ID_586854382" MODIFIED="1614545519119" TEXT="Vorsicht: Unterscheide Screen-Koordinaten vs. Canvas-Koordinaten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1614545520061" ID="ID_421638066" MODIFIED="1614545552889" TEXT="das kann eigentlich nur der Canvas implementieren">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614545319978" ID="ID_819484059" MODIFIED="1614546053325" TEXT="Lösung-2: Drag-Geste manipuliert nur die Pixel/Canvas-Koordinaten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, durch die Drag-Geste entstehen vorübergehend lokal inkonsistente Koordinaten; der nächste DisplayEvaluation-Pass würde dies wieder beseitigen. Dieser Ansatz wäre rein logisch der konsistentere Weg, denn erst durch eine Rückmeldung von der Session wird eine neue Position auch offiziell. Allerdings müßte man bei diesem Ansatz vorsichtig vorgehen, und mögliche Interferenzen mit der DisplayEvaluation und dem Layout-Managment bedenken; besonders wenn man eine weite Strecke zurücklegt, könnte es passieren, daß der Clip dann plötzlich aus der Anzeige verschwindet und den Fokus verliert, weil eine DisplayEvaluation ihn wieder an seine gegenwärtig nominelle Position geschoben hat.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#cf927e" DESTINATION="ID_819484059" ENDARROW="Default" ENDINCLINATION="30;162;" ID="Arrow_ID_713111774" SOURCE="ID_1040288867" STARTARROW="None" STARTINCLINATION="-23;-182;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1615558187255" ID="ID_1107620857" MODIFIED="1615558212485" TEXT="Kennzeichnung: Geste als reine Manipulation von UI-Zustand">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1614546132968" ID="ID_1588362914" MODIFIED="1614546175118" TEXT="auch in diesem Fall zumindest eine Übersetzung Screen→Canvas Koordinaten "/>
|
|
<node CREATED="1614546235626" ID="ID_1042308082" MODIFIED="1614546278044" TEXT="am Ende brauchen wir dann auch noch die Metrik vom Layout(Canvas), für das Zeit-Delta"/>
|
|
<node CREATED="1615558270517" ID="ID_295152392" MODIFIED="1615558374895" TEXT="Widersprüchliche Ownership der UI-Position">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gehört diese nun dem Layout-Manager, oder gehört er der Geste?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1615558355906" ID="ID_36290343" MODIFIED="1615558371149" TEXT="Interferenz mit der DisplayEvaluation">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1614543982261" ID="ID_268537549" MODIFIED="1614544001288" TEXT="der ClipPresenter hat keinen direkten Zugriff auf das konkrete ClipDelegate"/>
|
|
<node CREATED="1614544072432" ID="ID_624148025" MODIFIED="1614544294924" TEXT="der Anzeigestil wird relativ autonom im ClipDelegate gewählt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wobei das auch noch halbfertig ist; später einmal muß es hier eine Abstimmung mit dem Layout-Manager geben, aber diese Abstimmung sollte eigentlich nicht über den ClipPresenter laufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1614544489998" ID="ID_1208107119" MODIFIED="1614544503226" TEXT="...und davon hängt aber ab, ob eine Drag-Geste überhaupt möglich ist"/>
|
|
</node>
|
|
<node CREATED="1615558696844" ID="ID_1299483978" MODIFIED="1615558784590" TEXT="Ende der Geste muß zuverlässig erkannt werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sonst bleibt ein inkonsistender Zustand irgendwo "hängen".<br />Leider ist das nun das bekanntermaßen unlösbare Problem eines sicheren Verbindungsabbaus, und wir müssen uns deshalb mit einem Timeout, oder re-check-Mechanismus behelfen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1614547936791" ID="ID_972139852" MODIFIED="1621013665552" TEXT="Lösungskompromiß suchen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1614548567759" FOLDED="true" ID="ID_1502155745" MODIFIED="1621013605879" TEXT="klären welche Entität führt">
|
|
<node CREATED="1614548580160" ID="ID_1068834365" MODIFIED="1614549019860" TEXT="das Subject (Presenter)?">
|
|
<icon BUILTIN="closed"/>
|
|
<node CREATED="1614548621184" ID="ID_313965279" MODIFIED="1614548638025" TEXT="dann muß das ClipDelegate-API entsprechend erweitert werden"/>
|
|
<node CREATED="1614548720714" ID="ID_1355759542" MODIFIED="1614548742103" TEXT="trotzdem ungelöst: Zeitpunkt der Registrierung für den Drag-Mechanismus">
|
|
<linktarget COLOR="#fd6d53" DESTINATION="ID_1355759542" ENDARROW="Default" ENDINCLINATION="968;36;" ID="Arrow_ID_1110351466" SOURCE="ID_334680468" STARTARROW="None" STARTINCLINATION="210;12;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1614548979543" ID="ID_950023949" MODIFIED="1614549014231" TEXT="paßt insgesamt schlecht ins Konzept: Gesten sind reine GUI-Mechanik"/>
|
|
</node>
|
|
<node CREATED="1614548586972" ID="ID_1092961950" MODIFIED="1616684185562" TEXT="oder das Widget?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1614548745039" ID="ID_1301052915" MODIFIED="1616684201445" TEXT="dann ist (mindestens) ein Backlink auf das Subjekt notwendig">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1614548782314" ID="ID_1708909721" MODIFIED="1614548792788" TEXT="ansonsten könnte aber das Widget autonom agieren">
|
|
<node CREATED="1614548816117" ID="ID_934774711" MODIFIED="1614548839550" TEXT="sofern man alles dynamische Positionieren in den Canvas verlagert"/>
|
|
<node CREATED="1614548843386" ID="ID_1197536023" MODIFIED="1614548864523" TEXT="der Canvas müßte sich dann also als Partizipant beim CmdContext registrieren">
|
|
<node CREATED="1614548871925" ID="ID_1738624566" MODIFIED="1614548889914" TEXT="Vorsicht... es gibt nicht nur einen Canvas">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1617454766067" ID="ID_179209651" MODIFIED="1617454788398" TEXT="als Voraussetzung muß also das Subject seinen Canvas kennen"/>
|
|
<node CREATED="1617454793154" ID="ID_133939529" MODIFIED="1617454803637" TEXT="Canvas selber als Abstraktion zu behandeln">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1616684203994" ID="ID_1768434265" MODIFIED="1616684226073" TEXT="dann wäre aber die eigentliche Detail-Logik wieder über die Widgets verstreut">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1616684172294" ID="ID_1075366662" MODIFIED="1616684179286" TEXT="der Gesten-Controller">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#435e98" CREATED="1616684235790" ID="ID_280567268" MODIFIED="1616684329617" TEXT="allerdings wirft das dann wieder das Storage-Problem auf">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616684251451" ID="ID_1302771113" MODIFIED="1616684329623" TEXT="und die Frage: wie kommt man an die Kollaborationspartner">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1615563494951" ID="ID_1886279726" MODIFIED="1616684443111" TEXT="Lösung">
|
|
<linktarget COLOR="#fbf89a" DESTINATION="ID_1886279726" ENDARROW="Default" ENDINCLINATION="37;75;" ID="Arrow_ID_1201469200" SOURCE="ID_135851896" STARTARROW="None" STARTINCLINATION="-345;12;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1616684283858" ID="ID_922873284" MODIFIED="1616684285148" TEXT="das Subject leitet die Geste ein"/>
|
|
<node CREATED="1616684286015" ID="ID_113807772" MODIFIED="1616684309504" TEXT="der Auswertungs-Kontext wird erst dann (late) im Gesten-Controller gebildet"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1614549056549" FOLDED="true" ID="ID_202229623" MODIFIED="1616684814536" TEXT="wieder das lästige Problem mit den vielen Querlinks">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1614549074954" ID="ID_1803715980" MODIFIED="1614549087844" TEXT="hatte das kürzlich erst beim Layout mühsam niedergekämpft"/>
|
|
<node CREATED="1614549303989" ID="ID_228758963" MODIFIED="1614549326657" TEXT="Idee: jeweils beim Beginn einer Geste den Kontext etablieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1614549430019" ID="ID_1189932533" MODIFIED="1614549464686" TEXT="das löst (nur) das Storage-Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insofern wir die Storage nur einmal, im jeweilgen CmdContext der Geste vorsehen müssen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1614549465737" ID="ID_1592517509" MODIFIED="1616684802531" TEXT="bleibt zu lösen...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1614549475656" ID="ID_1108253772" MODIFIED="1614549505036" TEXT="gegeben ein Widget ⟹ wer ist das Subject(Presenter)?"/>
|
|
<node CREATED="1614549505881" ID="ID_1111066543" MODIFIED="1614549522610" TEXT="gegeben ein Widget ⟹ welcher Canvas managt das Layout?"/>
|
|
<node COLOR="#435e98" CREATED="1614865416841" ID="ID_369222912" MODIFIED="1615558812749" TEXT="Entscheidung zur Übersetzung in Domain-Werte">
|
|
<arrowlink COLOR="#6c97d3" DESTINATION="ID_937435961" ENDARROW="Default" ENDINCLINATION="144;280;" ID="Arrow_ID_1259911083" STARTARROW="None" STARTINCLINATION="-332;20;"/>
|
|
<node CREATED="1615558454300" ID="ID_1040288867" MODIFIED="1615558819335" TEXT="Entscheidung fällt gegen Lösung-2">
|
|
<arrowlink COLOR="#cf927e" DESTINATION="ID_819484059" ENDARROW="Default" ENDINCLINATION="30;162;" ID="Arrow_ID_713111774" STARTARROW="None" STARTINCLINATION="-23;-182;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1615558821048" ID="ID_553122702" MODIFIED="1615559148819">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Konsequenz aus Lösung-1 ist aber nicht <i>wirklich abwegig</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Warum möchte man denn überhaupt eine Geste "abbrechen können"?
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
weil sie versehentlich ausgelöst wurde
|
|
</li>
|
|
<li>
|
|
weil man besorgt ist, ein bereits Erreichtes dadurch "kaputt" zu machen
|
|
</li>
|
|
<li>
|
|
weil man ein «UNDO« nicht zuverlässig sieht
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Die Konsequenz daraus ist dann, daß das UI von Lumiera stets offen, non-modal und manipulierbar ist. Und die zweite Konsequenz ist, daß wir ein klar und <b>zuverlässig steuerbares</b> «UNDO» brauchen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616684105407" ID="ID_135851896" MODIFIED="1616684443111" TEXT="Entscheidung Misch-Lösung: Subject leitet ein, Gesten-Controller führt durch die Geste">
|
|
<arrowlink COLOR="#fbf89a" DESTINATION="ID_1331675338" ENDARROW="Default" ENDINCLINATION="-9;-33;" ID="Arrow_ID_646745936" STARTARROW="None" STARTINCLINATION="-345;12;"/>
|
|
<arrowlink COLOR="#fbf89a" DESTINATION="ID_1886279726" ENDARROW="Default" ENDINCLINATION="37;75;" ID="Arrow_ID_1201469200" STARTARROW="None" STARTINCLINATION="-345;12;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1615561656493" ID="ID_1379998024" MODIFIED="1615563798670" TEXT="Analyse und Lösungssuche">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1615561662796" ID="ID_997009920" MODIFIED="1615561681046" TEXT="klar ist...">
|
|
<node CREATED="1615561682058" ID="ID_1964677732" MODIFIED="1615561698859" TEXT="sobald die Geste startet..."/>
|
|
<node CREATED="1615561699447" ID="ID_1546726168" MODIFIED="1615561719329">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
..brauchen wir Widget <i>und </i>Subject <i>und </i>Canvas
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1615561804761" ID="ID_1425406746" MODIFIED="1615561837841" TEXT="und das Event-Binding braucht zumindest den Gesten-Controller"/>
|
|
<node CREATED="1615561875768" ID="ID_989749499" MODIFIED="1615561888969" TEXT="..plus einen Context-Indicator"/>
|
|
</node>
|
|
<node CREATED="1615563494951" ID="ID_1331675338" MODIFIED="1615563508330" TEXT="nun erscheint eine Lösung naheliegend">
|
|
<linktarget COLOR="#fbf89a" DESTINATION="ID_1331675338" ENDARROW="Default" ENDINCLINATION="-9;-33;" ID="Arrow_ID_646745936" SOURCE="ID_135851896" STARTARROW="None" STARTINCLINATION="-345;12;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1615563510172" ID="ID_1273139871" MODIFIED="1615563531003" TEXT="speichere im Binding den Gesten-Controller + das Subject"/>
|
|
<node CREATED="1615563531896" ID="ID_1041794659" MODIFIED="1615563551170" TEXT="bei Start der Geste: das Subjekt bringt den Kontext bei...">
|
|
<node CREATED="1615563552422" ID="ID_276415471" MODIFIED="1615563561233" TEXT="es kennt das Widget"/>
|
|
<node CREATED="1615563561965" ID="ID_765212431" MODIFIED="1615563568584" TEXT="und das Widget kennt den Canvas"/>
|
|
</node>
|
|
<node CREATED="1615563610750" ID="ID_1241019416" MODIFIED="1615563624318" TEXT="der Canvas dient damit nur zur Metrik-Übersetzung"/>
|
|
<node CREATED="1615563630412" ID="ID_1025610010" MODIFIED="1615563683159" TEXT="das Widget wird direkt per CanvasHook verschoben"/>
|
|
</node>
|
|
<node CREATED="1615563869355" ID="ID_411566224" MODIFIED="1615563956504" TEXT="Zeiger verwenden, und keine Registry">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Registry hat zusätzlichen Overhead (sowohl Speicher, alsauch Management) und ist nur sinnvoll, wenn eine ID in mehreren Objekten vorkommt, oder die ID aus mehreren Thread-Kontexten benötigt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1615563757154" ID="ID_1223828386" MODIFIED="1615563849447" TEXT="diese Lösung erscheint tragfähig und kohärent">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern sie genau an die Struktur anbaut, welche ich schon zur Lösung der Querbeziehungen für das Layout genutzt habe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#3363bf" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="36;-129;" ID="Arrow_ID_794903503" STARTARROW="None" STARTINCLINATION="-320;18;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1615563740336" ID="ID_1714668959" MODIFIED="1679362063109" TEXT="Lösungs-Skizze für Clip-Drag erstellen">
|
|
<linktarget COLOR="#3363bf" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="36;-129;" ID="Arrow_ID_794903503" SOURCE="ID_1223828386" STARTARROW="None" STARTINCLINATION="-320;18;"/>
|
|
<linktarget COLOR="#2381d3" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="-533;1807;" ID="Arrow_ID_1818387200" SOURCE="ID_1401408143" STARTARROW="None" STARTINCLINATION="1260;198;"/>
|
|
<linktarget COLOR="#5f7a9f" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="-533;1807;" ID="Arrow_ID_1378120058" SOURCE="ID_1570729566" STARTARROW="None" STARTINCLINATION="1673;76;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1616684903452" ID="ID_1953335093" MODIFIED="1679362063109">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
1.Schritt: <i>irgendwie implementieren</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1616709287996" ID="ID_315052965" MODIFIED="1616709307502" TEXT="CmdContext ist ein Builder">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1616709876647" ID="ID_134820105" MODIFIED="1616709888050" TEXT="(ver)bindet eine UI-Entität"/>
|
|
<node CREATED="1616709888782" ID="ID_1557466321" MODIFIED="1616709896625" TEXT="mit einer Interaktionsform"/>
|
|
<node CREATED="1616709937487" ID="ID_1221710731" MODIFIED="1616709984652" TEXT="idealerweise abstrakt und übergreifend">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das Ideal wäre, daß man das nicht speziell für Maus, Tastatur, Stift und Hardware einrichten muß, sondern lediglich qualifizieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1616710016525" ID="ID_454513850" MODIFIED="1616710159000" TEXT="dies sollte der einzige Ort der Konfiguration sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. es wäre zu vermeiden, daß ein irgendwo vorgegebenes Konfigurations-Setup an anderer Stelle im Code noch passend verankert oder korrespondierend eingerichtet werden muß.<br /><br />Konkret: die drag-Fähigkeit eines Clip wird konfiguriert im Clip-Presenter. Fertig.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1616712549985" ID="ID_1845795661" MODIFIED="1616712552436" TEXT="Methoden">
|
|
<node CREATED="1616712555705" ID="ID_1629230692" MODIFIED="1616713670273" TEXT="linkSubect(subj&)"/>
|
|
<node CREATED="1616713811416" ID="ID_1212233389" MODIFIED="1616713852706" TEXT="setupRelocateDrag()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1616710202252" FOLDED="true" ID="ID_220049730" MODIFIED="1616710247050" TEXT="InteractionState sollte nur intern mit CmdContext interagieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1617454641530" ID="ID_104565280" MODIFIED="1617454704165" TEXT="InteractionState ist ein Adapter zwischen dem Anker (CmdContext) und der konkreten Geste"/>
|
|
<node CREATED="1616710625955" ID="ID_69401594" MODIFIED="1616710644751" TEXT="gemeint ist: die Implementation von InteractionState ist konkret">
|
|
<node CREATED="1616712015758" ID="ID_1460580308" MODIFIED="1616712028383" TEXT="Entscheidung: jede Geste ist konkret">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1616712031119" ID="ID_17685044" MODIFIED="1616712197269" TEXT="also "Clip-Move" vs "Clip-Attach" vs "Clip-Trim""/>
|
|
<node CREATED="1616712201691" ID="ID_1586890794" MODIFIED="1616712288188" TEXT="denn es sind nicht so viele, daß eine zusätzliche Abstraktionsstufe gerechtfertig wäre">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Und außerdem: die Wiederverwendung einer Implementierung z.B. für Dragging kann man per Vererbung oder per nested component lokal in der Implementierung regeln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1616710500336" ID="ID_1572154704" MODIFIED="1616710506215" TEXT="was wird gebraucht?">
|
|
<node CREATED="1616711335594" ID="ID_179541553" MODIFIED="1616711349572" TEXT="den Trigger einrichten">
|
|
<node CREATED="1616711351275" ID="ID_1259806938" MODIFIED="1616711357761" TEXT="linkTrigger(Subject)"/>
|
|
</node>
|
|
<node CREATED="1616711814740" ID="ID_1488797823" MODIFIED="1616711828149" TEXT="einen Modifier festlegen"/>
|
|
<node CREATED="1616711873564" ID="ID_1116020717" MODIFIED="1616711888542" TEXT="eine Zusatzbedingung(Lambda) angeben"/>
|
|
<node CREATED="1616711889538" ID="ID_672191940" MODIFIED="1616711925929" TEXT="Zugang zum slotEnabled()">
|
|
<node CREATED="1616711927102" ID="ID_1174752717" MODIFIED="1616711964852" TEXT="damit läßt sich eine bestimmte Geste aktivieren/deaktivieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616771214558" FOLDED="true" ID="ID_1771867762" MODIFIED="1616852161665" TEXT="Problem: Widget-Existenz wird dynamisch gesteuert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1616771234015" ID="ID_240157641" MODIFIED="1616771254326" TEXT="relativ autonom">
|
|
<node CREATED="1616771255343" ID="ID_620255063" MODIFIED="1616771287475" TEXT="deshalb kann das Subject die Einrichtung nicht fix machen"/>
|
|
<node CREATED="1616771294654" ID="ID_334680468" MODIFIED="1616771818181" TEXT="auch der Zeitpunkt ist nicht absolut festgelegt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
es <i>kann passieren,</i> daß zu Beginn keine Timings gegeben sind, und deshalb erst mal nur ein Platzhalter erstellt wird...
|
|
</li>
|
|
<li>
|
|
es <i>kann passieren,</i> daß die Anzeige sofort in den degradierten-Modus schaltet (z.B. Timeline-Übersicht)...
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fd6d53" DESTINATION="ID_1355759542" ENDARROW="Default" ENDINCLINATION="968;36;" ID="Arrow_ID_1110351466" STARTARROW="None" STARTINCLINATION="210;12;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616771830690" ID="ID_1923283447" MODIFIED="1616852149613" TEXT="Konsequenz: Setup für Dragging muß immer wieder erneut erfolgen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1616771909543" ID="ID_704625942" MODIFIED="1616771922497" TEXT="und zwar genau dann, wenn ein neues Widget geschaffen wurde"/>
|
|
<node CREATED="1616772271009" ID="ID_1822723171" MODIFIED="1616772366205" TEXT="Problem: es ist nicht (einfach) möglich, eine bestehende Gesten-Konfiguration zu erkennen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn ich will ja grade unnötige Storage-Slots für Rückpointer und sonstige Flags vermeiden; daher besteht eine Gesten-Konfiguration nur darin, irgendwo ganz versteckt ein Signal auf das Widget verdrahtet zu haben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616771937519" FOLDED="true" ID="ID_897110549" MODIFIED="1616852141975" TEXT="Aufgabe: diese Änderungen zuverlässig erkennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1616771968190" ID="ID_1961266206" MODIFIED="1616771986228" TEXT="es könnte onLocalChange() passieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1616771987478" ID="ID_1833918929" MODIFIED="1616772006656" TEXT="...denn das ist auch die Stelle, die die Änderung im Anzeigestil möglicherweise auslöst"/>
|
|
<node CREATED="1616772215184" ID="ID_1727128481" MODIFIED="1616772242264" TEXT="wird auch von injectNew() mit getriggert">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1616772374800" ID="ID_898444334" MODIFIED="1616772380678" TEXT="das ist schön..."/>
|
|
<node CREATED="1616772381362" ID="ID_211141572" MODIFIED="1616772481922" TEXT="wirft aber ein Problem der Asymetrie auf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn nach dem Konstruktor-Aufruf existiert das Widget bereits ―<b> </b>und das heißt, diese Funktion im Listener muß nichts mehr tun, und deshalb sieht es lokal dort so aus, als hätte sich das Widget gar nicht geändert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1616772483932" ID="ID_1983461836" MODIFIED="1616772500046" TEXT="das ist auch eine "halbe" Code-Duplikation">
|
|
<node COLOR="#435e98" CREATED="1616772500937" ID="ID_1952528681" MODIFIED="1616803786000" TEXT="kann man das begradigen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1616773381049" ID="ID_1361368724" MODIFIED="1616773396790" TEXT="würde bedeuten: buildDelegate läuft erst on-demand"/>
|
|
<node CREATED="1616773425807" ID="ID_1108287644" MODIFIED="1616773436809" TEXT="Konsequenz">
|
|
<node CREATED="1616773437629" ID="ID_1627883677" MODIFIED="1616773455118" TEXT="entweder die Invariante ist verletzt (widget_ != null)"/>
|
|
<node CREATED="1616773456274" ID="ID_1362418383" MODIFIED="1616773479027" TEXT="oder das switchAppearance muß schon vom ctor aus laufen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616773513426" ID="ID_493085702" MODIFIED="1616803787953" TEXT="Analyse-Aufgabe: was ist der Unteschied?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1616773528369" ID="ID_783515324" MODIFIED="1616773535478" TEXT="buildDelegate">
|
|
<node CREATED="1616773740990" ID="ID_709835603" MODIFIED="1616773753903" TEXT="bekommt die Timings explizit von Außen hereingereicht"/>
|
|
<node CREATED="1616773822417" ID="ID_435836434" MODIFIED="1616773829885" TEXT="ermittelt nur den neuen Stil"/>
|
|
<node CREATED="1616773839167" ID="ID_186857995" MODIFIED="1616773868828" TEXT="baut stets das Delegate from scratch"/>
|
|
<node CREATED="1616773969494" ID="ID_711732245" MODIFIED="1616773998586" TEXT="vereinfachte Logik für den Anzeigestil">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da man verschiedene Fälle hier zu beginn gleich ausschließen kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1616773543578" ID="ID_1381781962" MODIFIED="1616773547522" TEXT="switchAppearance">
|
|
<node CREATED="1616773755299" ID="ID_982537729" MODIFIED="1616773767855" TEXT="zieht sich die Timings vom existierenden Delegate"/>
|
|
<node CREATED="1616773776856" ID="ID_1919770258" MODIFIED="1616773804888" TEXT="entnimmt vom existierenden Deletate einen bisherigen Anzeigestil"/>
|
|
<node CREATED="1616773832223" ID="ID_27000350" MODIFIED="1616773837508" TEXT="ermittelt den neuen Stil"/>
|
|
<node CREATED="1616773805721" ID="ID_1164727185" MODIFIED="1616773819718" TEXT="prüft, ob überhaupt eine Änderung notwendig ist"/>
|
|
<node CREATED="1616773870819" ID="ID_158611366" MODIFIED="1616773891716" TEXT="macht ggfs eine move-Konstruktion (verwendet das bestehende Delegate)"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616803774776" ID="ID_511524095" MODIFIED="1616803986956" TEXT="puh... machbar aber komplex">
|
|
<arrowlink COLOR="#01ae93" DESTINATION="ID_1192722099" ENDARROW="Default" ENDINCLINATION="266;0;" ID="Arrow_ID_1620313417" STARTARROW="None" STARTINCLINATION="145;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616803853431" ID="ID_1036949484" MODIFIED="1616803911454" TEXT="buildDelegate | switchAppearance → selectAppearance">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1616803913136" ID="ID_272741103" MODIFIED="1616803932728" TEXT="jetzt ist nur noch eine einzige Funktion für das ganze Zustandsmanagement verantwortlich"/>
|
|
<node CREATED="1616803933773" ID="ID_1192722099" MODIFIED="1616803982084" TEXT="der code war vorher etwas verworren... und jetzt ist er sauberer, aber sehr komplex">
|
|
<linktarget COLOR="#01ae93" DESTINATION="ID_1192722099" ENDARROW="Default" ENDINCLINATION="266;0;" ID="Arrow_ID_1620313417" SOURCE="ID_511524095" STARTARROW="None" STARTINCLINATION="145;0;"/>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616804300325" ID="ID_480439366" MODIFIED="1616852111077" TEXT="auf dieser Basis nun ein neu erzeugtes Widget erkennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1616804350672" ID="ID_1181865023" MODIFIED="1616804359373" TEXT="Kriterien">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1616804323416" ID="ID_1065320975" MODIFIED="1616804335337" TEXT="immer wenn sich das Delegate ändert"/>
|
|
<node CREATED="1616804336046" ID="ID_438456915" MODIFIED="1616804350049" TEXT="und der neue Stil ein eigentständiges Widget rechtfertigt"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616852094050" ID="ID_1854197256" MODIFIED="1616852126061" TEXT="eingebaut und per Log-Meldung verifiziert">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616852178983" ID="ID_389047439" MODIFIED="1669362063109" TEXT="Strukturen gemäß Konzept anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1616852190829" FOLDED="true" ID="ID_1663212368" MODIFIED="1617377719039" TEXT="CmdContext">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1616859779196" ID="ID_848065191" MODIFIED="1616859786984" TEXT="Dependency-Injection nutzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616859787843" ID="ID_1635546920" MODIFIED="1616947177038" TEXT="Klären: wie wird die CtxID aufgelöst?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1616943046889" ID="ID_1350466164" MODIFIED="1616943061375" TEXT="oder anders herum: was sagt die CtxID aus?"/>
|
|
<node CREATED="1616943103092" ID="ID_1028957642" MODIFIED="1616944099163" TEXT="welche Informationen müssen mitgegeben werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1616943128136" ID="ID_1348629069" MODIFIED="1616943136864" TEXT="die Command-ID selber">
|
|
<node CREATED="1616943138039" ID="ID_183656293" MODIFIED="1616943154225" TEXT="Frage: ist diese ein Bedeutungsträger?"/>
|
|
<node CREATED="1616943154981" ID="ID_687890378" MODIFIED="1616943170211" TEXT="...oder nur ein Wert der nach unten durchgereicht wird?"/>
|
|
</node>
|
|
<node CREATED="1616943184573" ID="ID_318484387" MODIFIED="1616943210017" TEXT="der Umstand daß eine Dragging-Aktion stattfinden soll"/>
|
|
<node CREATED="1616943213342" ID="ID_1854935612" MODIFIED="1616943235062" TEXT="der Umstand daß wir auf einem Canvas arbeiten">
|
|
<node CREATED="1616943236338" ID="ID_233441382" MODIFIED="1616943253094" TEXT="im Sinne meiner Abstraktion CanvasHooked"/>
|
|
<node CREATED="1616943425489" ID="ID_409371890" MODIFIED="1616943450039" TEXT="aber auch die Info, daß die x-Koordinate eine Zeit darstellt"/>
|
|
</node>
|
|
<node CREATED="1616943463635" ID="ID_926220296" MODIFIED="1616943481983" TEXT="Zusätzlich muß die Geste noch im Detail konfiguriert werden">
|
|
<node CREATED="1616943486336" ID="ID_1614368580" MODIFIED="1616943496907" TEXT="sind Modifier notwendig?"/>
|
|
<node CREATED="1616943497591" ID="ID_1693918542" MODIFIED="1616943512497" TEXT="kann der Drag den Canvas verlassen?"/>
|
|
<node CREATED="1616943513205" ID="ID_1329503612" MODIFIED="1616943532774" TEXT="kann der Drag über den bisherigen virtuellen Canvas hinausgehen?"/>
|
|
<node CREATED="1616943533930" ID="ID_1957877957" MODIFIED="1616943546988" TEXT="soll der Canvas automatsich scrollen?"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616943578428" ID="ID_115517003" MODIFIED="1616944103109" TEXT="wie allgemein / generisch muß das System sein?">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1616943995900" ID="ID_999660840" MODIFIED="1616944008942" TEXT="Antwort: anfangs so wenig wie möglich">
|
|
<linktarget COLOR="#2c9eb4" DESTINATION="ID_999660840" ENDARROW="Default" ENDINCLINATION="-136;9;" ID="Arrow_ID_453101984" SOURCE="ID_1611970353" STARTARROW="None" STARTINCLINATION="60;-184;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1616944014145" ID="ID_1496729936" MODIFIED="1616944031389" TEXT="ich deute aber die Verallgemeinerung an">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1616944032896" ID="ID_1402431957" MODIFIED="1616944054424" TEXT="indem...">
|
|
<node CREATED="1616944055492" ID="ID_1975883626" MODIFIED="1616944073921" TEXT="die Kontext-ID strukturiert angelegt wird (mit Scope und Punkt)"/>
|
|
<node CREATED="1616944076448" ID="ID_932332417" MODIFIED="1616944085018" TEXT="die Übersetzung zweistufig erfolgt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616947165410" ID="ID_300128108" MODIFIED="1617377719039" TEXT="also: vorherst ferst verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616854202348" ID="ID_340156587" MODIFIED="1617377719039" TEXT="Auswahl und Zugriff auf den passenden InteractionState">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1617377586150" ID="ID_1611970353" MODIFIED="1617377719039" TEXT="erst mal fest verdrahtet">
|
|
<arrowlink COLOR="#2c9eb4" DESTINATION="ID_999660840" ENDARROW="Default" ENDINCLINATION="-136;9;" ID="Arrow_ID_453101984" STARTARROW="None" STARTINCLINATION="60;-184;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616856060491" FOLDED="true" ID="ID_44406517" MODIFIED="1616859101168" TEXT="einen Manager für den InteractionState schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1616859073891" ID="ID_909388621" MODIFIED="1616859108655" TEXT="Name: GestureState">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616859080858" ID="ID_1168738584" MODIFIED="1616859110568" TEXT="angesiedelt im InteractionDirector">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616859087201" ID="ID_1804482999" MODIFIED="1616859111916" TEXT="zugänglich via lib::Depend<GestureState>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616852275162" FOLDED="true" ID="ID_1272601084" MODIFIED="1617377719039" TEXT="DragRelocateController verwalten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1617377637909" ID="ID_1302268767" MODIFIED="1617377719039" TEXT="Entscheidung: erst mal direkt als PImpl in GestureController">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1617377669085" ID="ID_1519120855" MODIFIED="1617377719039" TEXT="könnte später mal dynamsiche Auswahl nach Regeln sein (je nach Interaction-System)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Maus, Tastenkürzel, Stift, Hardware....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617377650756" ID="ID_735449737" MODIFIED="1617377719039" TEXT="TODO für später im Code hinterlassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617377786842" FOLDED="true" ID="ID_1829220190" MODIFIED="1617471190700" TEXT="Interface Subject definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1617471241490" ID="ID_293482403" MODIFIED="1617471251679" TEXT="implementieren für ClipPresenter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1617471252385" ID="ID_1769679679" MODIFIED="1617471266204" TEXT="Problem: Zugriff auf das Widget">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1617471267594" ID="ID_1351328929" MODIFIED="1617471285896" TEXT="eigentlich kein Problem, sondern nur hässlich"/>
|
|
<node CREATED="1617471305929" ID="ID_663980291" MODIFIED="1617471447147" TEXT="Steht im Widerspruch zum selbständig verwalteten Anzeigestil">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dadurch ensteht hier ein "linke-Tasche-rechte-Tasche-Spiel".
|
|
</p>
|
|
<p>
|
|
Wir müssen annehmen...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
daß der ClipPresenter das Wiring nur dann einrichtet, wenn tatsächlich ein Clip-Widget erzeugt wurde
|
|
</li>
|
|
<li>
|
|
und daß ein deaktiviertes oder aus dem Display herausgenommenes Widget auch keine Signale mehr sendet
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471286628" ID="ID_601378287" MODIFIED="1617471303401" TEXT="in statischer Funktion im ClipDelegate versteckt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471454724" ID="ID_347955053" MODIFIED="1617471465856" TEXT="gründliche Fehlerbehandlung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617377754742" FOLDED="true" ID="ID_1574394085" MODIFIED="1618681141799" TEXT="linkSubject im konkreten Controller">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1617377734341" ID="ID_1697355210" MODIFIED="1617568263119" TEXT="Widget-Signal-Binding anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1617471221445" ID="ID_1213832173" MODIFIED="1617471225697" TEXT="Exceptions fangen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471484385" ID="ID_764496740" MODIFIED="1617471492221" TEXT="hierfür ein Makro erfunden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471493055" ID="ID_1798821612" MODIFIED="1617568252066" TEXT="Makro in einen zentralen Header verlegen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habs in error.hpp untergebracht, direkt unter ERROR_LOG_AND_IGNORE
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617377772355" ID="ID_1391847346" MODIFIED="1617471513483" TEXT="Subject im Signal-Binding binden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1617459517745" ID="ID_1350194192" MODIFIED="1617459539394" TEXT="brauchen wir ein Sigc::Trackable zum Binden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1617459546014" ID="ID_1656180985" MODIFIED="1617459578397" TEXT="konkret: kann der Gesten-Controller vorzeitig zerstört werden?"/>
|
|
<node CREATED="1617459579286" ID="ID_214055342" MODIFIED="1617459650805" TEXT="Nein, sofern er an den Lebenszyklus des InteractionDirectors gebunden ist">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1617459599031" ID="ID_481151247" MODIFIED="1617459613224" TEXT="denn: der UiManager wird erst nach Ende des UI-Thread zerstört"/>
|
|
<node CREATED="1617459627675" ID="ID_1337959173" MODIFIED="1617459642132" TEXT="(solange das UI keine weiteren Threads verwendet sind wir sauber)"/>
|
|
</node>
|
|
<node CREATED="1617459659278" ID="ID_976541024" LINK="#ID_230224690" MODIFIED="1617459721740" TEXT="kann also bequem ein Lambda verwenden..."/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617377798336" ID="ID_1680080732" MODIFIED="1618681140125" TEXT="Signal-Callbacks anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1617471204921" ID="ID_1381735452" MODIFIED="1617471216758" TEXT="Vorläufie Implementierung: Button-Click">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617471543992" ID="ID_1461453973" MODIFIED="1618681138718" TEXT="auch noch die CommandID mit binden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617568275423" FOLDED="true" ID="ID_705403474" MODIFIED="1620913868535" TEXT="Trigger-Bedingung formulieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1617568301466" ID="ID_1738730292" MODIFIED="1617568534103" TEXT="inhaltlich...">
|
|
<node CREATED="1617568311385" ID="ID_120327257" MODIFIED="1617568327148" TEXT=""klicken und ziehen""/>
|
|
<node CREATED="1617568432466" ID="ID_1992031404" MODIFIED="1617568445795" TEXT="der Klick war im Bereich des zu ziehenden Objekts"/>
|
|
<node CREATED="1617568398748" ID="ID_1460645724" MODIFIED="1617568423269" TEXT="Mausbewegung bevor die Maustaste losgelassen wurde"/>
|
|
<node CREATED="1617568452526" ID="ID_1020620586" MODIFIED="1617568457857" TEXT="konfigurierbare Varianten">
|
|
<node CREATED="1617568459021" ID="ID_1056703616" MODIFIED="1617568484821" TEXT="welcher Mausknopf?"/>
|
|
<node CREATED="1617568485487" ID="ID_1125938046" MODIFIED="1617568496877" TEXT="Modifier-Tasten gedrückt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617568504346" ID="ID_261021912" MODIFIED="1617568528369" TEXT="Event-Logik">
|
|
<node CREATED="1617568536923" ID="ID_711862925" MODIFIED="1617568637660" TEXT="Maus-Button-Events beobachten">
|
|
<node CREATED="1617568559447" ID="ID_945977734" MODIFIED="1617568566236" TEXT="sie kommen separat">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1617568567502" ID="ID_420708332" MODIFIED="1617568581548" TEXT="button_press / button_release"/>
|
|
<node CREATED="1617568582983" ID="ID_55959030" MODIFIED="1617568587863" TEXT="brauche also State-Flag"/>
|
|
</node>
|
|
<node CREATED="1617568619294" ID="ID_1632840058" MODIFIED="1617568634721" TEXT="Maus-Bewegungen beobachten">
|
|
<node CREATED="1617568707539" ID="ID_295174792" MODIFIED="1617568780036" TEXT="mit Button-State verknüpfen"/>
|
|
<node CREATED="1617568786464" ID="ID_186028355" MODIFIED="1617568842406" TEXT="fast return falls irrelevant">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617568863750" ID="ID_390541368" MODIFIED="1617568877088" TEXT="Modifier ermitteln">
|
|
<node CREATED="1617568878012" ID="ID_1639356381" MODIFIED="1617568904641" TEXT="sie werden im Button-Event mitgeliefert"/>
|
|
<node CREATED="1617568905353" ID="ID_1257545245" MODIFIED="1617568925825" TEXT="Danke! andere Leute stehen vor der gleichen Aufgabe"/>
|
|
</node>
|
|
<node COLOR="#635891" CREATED="1617568934636" ID="ID_1210824074" MODIFIED="1617912478569" TEXT="Problem: unvollständige Gesten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1617568988701" ID="ID_1692187742" MODIFIED="1617568996132" TEXT="kann man "locker" handhaben"/>
|
|
<node CREATED="1617568997013" ID="ID_651241520" MODIFIED="1617569006963" TEXT="entweder es wird doch noch was"/>
|
|
<node CREATED="1617569007698" ID="ID_415678427" MODIFIED="1617569041770" TEXT="oder ein anderes Subjekt überschreibt"/>
|
|
<node CREATED="1617569057644" ID="ID_1030532541" MODIFIED="1617569060954" TEXT="Beispiele">
|
|
<node CREATED="1617569061629" ID="ID_1273582846" MODIFIED="1617569661108" TEXT="schon außerhalb geklickt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das bekommt dieser Controller dann nicht mit, und die Geste wird insofern auch nicht getriggert. Da hat der User eben Pech gehabt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1617569148000" ID="ID_1188278692" MODIFIED="1617569598605" TEXT="Widget vorübergehend verlassen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wenig problematisch ist dieser Fall, wenn der Button gedrückt bleibt und wir irgendwann zurückkommen; dann setzt sich das Dragging eben an der Stelle fort. Wenn dagegen der Button außerhalb released wurde, handelt es sich tatsächlich um den 3.Fall ― wenn aber eine normale Maus-Bewegung später wieder über das Widget fährt, wird das Dragging fortgesetzt, fälschlicherweise.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1617569170845" ID="ID_1128795128" MODIFIED="1617888975813" TEXT="Widget verlassen und Release außerhalb">
|
|
<arrowlink COLOR="#5274c4" DESTINATION="ID_670270677" ENDARROW="Default" ENDINCLINATION="-142;-46;" ID="Arrow_ID_1779430894" STARTARROW="None" STARTINCLINATION="-54;103;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1617569229030" ID="ID_601910999" MODIFIED="1617569234719" TEXT="echtes Problem"/>
|
|
<node CREATED="1617569235666" ID="ID_1093451410" MODIFIED="1617569408809" TEXT="betrachte ich als Unfall">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn das <i>Dragging </i>funktioniert, sollte es eigentlich rein logisch unmöglich sein, das Widget zu verlassen, weil dieses sich ja mitbewegt. Allerdings sind vielerlei undlückliche Umstände denkbar, z.B. verspätete Reaktion der Software, sehr schnelle Mausbewegungen, limitierte Bewegung am Rand eines Containers.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617569409798" ID="ID_1474484984" MODIFIED="1617569431870" TEXT="Puh! sprengt das Konzept">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617569687944" ID="ID_109351275" MODIFIED="1620913776693" TEXT="Modifier sollten konfigurierbar sein">
|
|
<arrowlink COLOR="#d54526" DESTINATION="ID_914526002" ENDARROW="Default" ENDINCLINATION="-19;-306;" ID="Arrow_ID_1156051405" STARTARROW="None" STARTINCLINATION="-130;185;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1617570674708" ID="ID_1037850042" MODIFIED="1617570685158" TEXT="Zugang / Definitionen">
|
|
<node CREATED="1617570694344" ID="ID_752689969" MODIFIED="1617570698161" TEXT="gdkevents.h">
|
|
<node CREATED="1617570706079" ID="ID_1486587603" MODIFIED="1617913056949" TEXT="_GdkEventMotion"/>
|
|
<node CREATED="1617570898727" ID="ID_116829584" MODIFIED="1617913060361" TEXT="_GdkEventButton"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617570908580" ID="ID_104139138" MODIFIED="1617912332831" TEXT="zu klären">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1617570913996" ID="ID_1217512191" MODIFIED="1617889193688" TEXT="was ist ein "grab"?">
|
|
<arrowlink COLOR="#3f56d9" DESTINATION="ID_366430158" ENDARROW="Default" ENDINCLINATION="-1512;175;" ID="Arrow_ID_1894977369" STARTARROW="None" STARTINCLINATION="-5374;669;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1617888877662" ID="ID_670270677" MODIFIED="1617912236623" TEXT="das ist genau die Lösung für das Problem hier">
|
|
<arrowlink COLOR="#5c9fd8" DESTINATION="ID_1612782952" ENDARROW="Default" ENDINCLINATION="201;0;" ID="Arrow_ID_1004134548" STARTARROW="None" STARTINCLINATION="246;0;"/>
|
|
<linktarget COLOR="#5274c4" DESTINATION="ID_670270677" ENDARROW="Default" ENDINCLINATION="-142;-46;" ID="Arrow_ID_1779430894" SOURCE="ID_1128795128" STARTARROW="None" STARTINCLINATION="-54;103;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1617898534818" ID="ID_315802107" MODIFIED="1617898613561" TEXT="und zwar gibt es demnach sogar zwei Lösungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Lösung auf X-Display / GDK-Ebene für die Maus und das grab-widget von GTK, welches alle Events fangen kann.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1617898615759" ID="ID_1865733725" MODIFIED="1617898713481" TEXT="hier erscheint die GTK-Lösung angemessen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1617898649667" ID="ID_1080170926" MODIFIED="1617898706244" TEXT="weil man damit auch die Tastatur "fangen" kann">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1617898661671" ID="ID_1301082143" MODIFIED="1617898703204" TEXT="allerdings ist diese Lösung auch schon ein starker Eintriff">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617898678071" ID="ID_1991806520" MODIFIED="1617898698197" TEXT="...muß also sauber und defensiv genutzt werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617912342820" ID="ID_131592994" MODIFIED="1617912428285" TEXT="noch besser... gar nichts zu tun">
|
|
<arrowlink COLOR="#7098c7" DESTINATION="ID_1996728887" ENDARROW="Default" ENDINCLINATION="10;-39;" ID="Arrow_ID_952711609" STARTARROW="None" STARTINCLINATION="-63;5;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1617570926506" ID="ID_803602163" MODIFIED="1617912330239" TEXT="was ist ein "implicit grab"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1617570946843" ID="ID_90860434" MODIFIED="1617570988184" TEXT="siehe _GdkEventGrabBroken">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
 * Generated when a pointer or keyboard grab is broken. On X11, this happens
|
|
</p>
|
|
<p>
|
|
 * when the grab window becomes unviewable (i.e. it or one of its ancestors
|
|
</p>
|
|
<p>
|
|
 * is unmapped), or if the same application grabs the pointer or keyboard
|
|
</p>
|
|
<p>
|
|
 * again. Note that implicit grabs (which are initiated by button presses)
|
|
</p>
|
|
<p>
|
|
 * can also cause #GdkEventGrabBroken events.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1617912124088" ID="ID_1996728887" MODIFIED="1617912425749" TEXT="Nach Maus- und Touch-Events gehen Folge-Events an das gleiche Widget">
|
|
<linktarget COLOR="#7098c7" DESTINATION="ID_1996728887" ENDARROW="Default" ENDINCLINATION="10;-39;" ID="Arrow_ID_952711609" SOURCE="ID_131592994" STARTARROW="None" STARTINCLINATION="-63;5;"/>
|
|
</node>
|
|
<node CREATED="1617912195242" ID="ID_1612782952" MODIFIED="1617912230315" TEXT="GTK implementiert also ohnehin die Lösung für mein Problem hier">
|
|
<linktarget COLOR="#5c9fd8" DESTINATION="ID_1612782952" ENDARROW="Default" ENDINCLINATION="201;0;" ID="Arrow_ID_1004134548" SOURCE="ID_670270677" STARTARROW="None" STARTINCLINATION="246;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1617912240372" ID="ID_1225920019" MODIFIED="1617912288730" TEXT="GdkEventButtonPress ⟹ empfangenes Widget bekommt den "implicit grab""/>
|
|
<node CREATED="1617912289933" ID="ID_1605333590" MODIFIED="1617912313582" TEXT="dieser bleibt bestehen bis GdkEventButtonRelease"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617913164868" ID="ID_113135132" MODIFIED="1618690916629" TEXT="einzurichten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1617913214193" ID="ID_51699428" MODIFIED="1617919672112" TEXT="state flags">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617913172095" ID="ID_389454227" MODIFIED="1617919654631" TEXT="Callbacks für Button-Events">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617913205146" ID="ID_1972128766" MODIFIED="1618690918521" TEXT="Callback für Motion-Events">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1617919712790" ID="ID_886546906" MODIFIED="1617919741084" TEXT="sehe hier die Motion-Events">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1617919725773" ID="ID_309690589" MODIFIED="1617919738379" TEXT="implicit grab funktioniert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618499488724" ID="ID_1241205333" MODIFIED="1618690930013" TEXT="Basis schaffen für eine Hysterese">
|
|
<linktarget COLOR="#22d66c" DESTINATION="ID_1241205333" ENDARROW="Default" ENDINCLINATION="35;105;" ID="Arrow_ID_1887863096" SOURCE="ID_1184207694" STARTARROW="None" STARTINCLINATION="348;20;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1618499514672" ID="ID_934736120" MODIFIED="1618499526802" TEXT="nicht jede minimale Bewegung soll eine Dragging-Geste auslösen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1618499530732" ID="ID_1305245635" MODIFIED="1618690910469" TEXT="das bedeutet: Gestenerkennung vorläufig beginnen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618498875079" ID="ID_1267546019" MODIFIED="1618499117546" TEXT="(Draft) Framework-Anforderungen beachten">
|
|
<linktarget COLOR="#5c4052" DESTINATION="ID_1267546019" ENDARROW="Default" ENDINCLINATION="-834;0;" ID="Arrow_ID_1826514843" SOURCE="ID_420683622" STARTARROW="None" STARTINCLINATION="-58;-277;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618499152610" ID="ID_1853176159" MODIFIED="1618504461568" TEXT="die Aktion beim Triggern muß konfigurierbar sein">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618499163912" ID="ID_21588422" MODIFIED="1618499182405" TEXT="Alternative-1: ein Command auslösen (auf dem Subject)"/>
|
|
<node CREATED="1618499184805" ID="ID_1304825104" MODIFIED="1618499247024" TEXT="Alternative-2: Erfolg-Rückmeldung an eine übergeordnete Geste"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618504436926" ID="ID_1670097568" MODIFIED="1618504458159" TEXT="die Geste muß generell deaktivierbar sein">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618504468418" ID="ID_1575120322" MODIFIED="1618504482540" TEXT="und zwar erst mal vom Subjekt aus">
|
|
<node CREATED="1618504487367" ID="ID_1202198317" MODIFIED="1618504512315" TEXT="Clip und Sequenz können fixiert sein"/>
|
|
<node CREATED="1618504518013" ID="ID_1762835695" MODIFIED="1618504554622" TEXT="es ist besser, dies unmittelbar im UI erfahrbar zu machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...anstatt bloß die Ausführung entsprechender Commands zurückzuweisen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618672697029" ID="ID_1737377416" MODIFIED="1618672706489" TEXT="Verfolgung und Pos-Updates">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1618675384464" ID="ID_381912051" MODIFIED="1618675399330" TEXT="Zustandslogik der Gesten-Erkennung selber">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618672711536" ID="ID_1916597982" MODIFIED="1619881347856" TEXT="Verbindung zum Canvas herstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619881349481" ID="ID_1566054765" MODIFIED="1619881362478" TEXT="nutze das CanvasHooked">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619881363596" ID="ID_120077248" MODIFIED="1619882215112" TEXT="CanvasHook exponiert jetzt DisplayMetric">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1619881405244" ID="ID_1235657284" MODIFIED="1619881421990" TEXT="das passiert dann aber alles bereits im Subject"/>
|
|
<node CREATED="1619882166616" ID="ID_1792609740" MODIFIED="1619882178102" TEXT="Subject::gestureOffset(cmd, deltaX, deltaY)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618672732077" ID="ID_949915263" MODIFIED="1624113877375" TEXT="Logik zur Positions-Übersetzung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1618676950908" ID="ID_69237451" MODIFIED="1618677116146" TEXT="hier deutet sich ein mehrstufiger Ansatz an">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Demnach wäre die Übersetzung von Pixel-Koordinaten in <i>irgend etwas modell-Releavantes</i> komplet in das Subject eingekapselt; der Gesten-Controller würde dann einen Screen-relativen Offset aggregieren. Aber auf der zweiten Stufe bleiben wir bei dem Ansatz, daß die Geste direkt das Modell manipuliert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618676975232" ID="ID_196334292" MODIFIED="1618677288680" TEXT="es erscheint vorläufig sinnvoll, dieser Richtung zu Folgen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...Auch wenn ich ein ungutes Bauchgefühl habe, alle Argumente sprechen im Moment dafür, diesem Hinweis zu folgen und das Design in dieser Richtung auszubauen. Im Besonderen würde nämlich ein konsequentes Umsetzen meines ursprünglichen Konzepts bedeuten, daß das Subject-Interface etwas von der Metrik im Modell, und im Besonderen von eine Zeit-Parameter wissen müßte ― es ist aber absehbar, daß in anderen Situationen gänzlich andere Parameter relevant sein könnten ... man denke bloß an die "Position im Fork"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1618752912540" FOLDED="true" ID="ID_709707680" MODIFIED="1624114454822" TEXT="konkrete Schwierigkeiten für den Clip">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1618752984873" ID="ID_126063856" MODIFIED="1624113957884" TEXT="muß ein Delta in ein Zeit-Delta übersetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1618753017759" ID="ID_1766339786" MODIFIED="1618753019825" TEXT="gegeben">
|
|
<node CREATED="1618753020812" ID="ID_958370173" MODIFIED="1618753025665" TEXT="eine Basis-Zeit"/>
|
|
<node CREATED="1618753026451" ID="ID_1831542689" MODIFIED="1618753035110" TEXT="ein Delta in UI-Koordinaten"/>
|
|
</node>
|
|
<node CREATED="1618753071285" ID="ID_1208729894" MODIFIED="1618753082199" TEXT="bei homogener Metrik sollte das aber möglich sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1618778672386" ID="ID_1242087872" MODIFIED="1618778698205" TEXT="Bisher in BodyCanvasWidget angelegt">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618778688276" ID="ID_1895003083" MODIFIED="1618778695704" TEXT="aber überhaupt noch nicht implementiert">
|
|
<arrowlink COLOR="#fe576f" DESTINATION="ID_400013153" ENDARROW="Default" ENDINCLINATION="2435;0;" ID="Arrow_ID_858529243" STARTARROW="None" STARTINCLINATION="240;261;"/>
|
|
<linktarget COLOR="#fdd8c6" DESTINATION="ID_1895003083" ENDARROW="Default" ENDINCLINATION="-729;49;" ID="Arrow_ID_547396305" SOURCE="ID_783305795" STARTARROW="None" STARTINCLINATION="218;15;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1620922762073" ID="ID_878659189" MODIFIED="1620922781290" TEXT="vorläufige Dummy-Implementierung in TimelineLayout"/>
|
|
<node CREATED="1620922782734" ID="ID_1695744984" MODIFIED="1620922815553">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verwendet hart gedrahtete Konstante <font color="#b42e2e">TODO_px_per_second</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620922817299" ID="ID_849178366" MODIFIED="1620922830205" TEXT="der Rest der Berechnung ist aber hiermit schon mal korrekt ausgeführt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619104316816" FOLDED="true" ID="ID_907598549" MODIFIED="1619880556650" TEXT="zu Klären: Rolle und Zugang zum Layout-Manager">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1619880229221" ID="ID_667002483" MODIFIED="1619880246203" TEXT="der Belang wird von einer eigenen Komponente behandelt"/>
|
|
<node CREATED="1619880246897" ID="ID_1360417037" MODIFIED="1619880264379" TEXT="diese wird Teil des DisplayManager-Interface"/>
|
|
<node CREATED="1619880345173" ID="ID_1065721692" MODIFIED="1619880538264" TEXT="später mal: Integration mit ZoomWindow">
|
|
<arrowlink COLOR="#8e7ba1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="171;760;" ID="Arrow_ID_1707924491" STARTARROW="None" STARTINCLINATION="-1855;126;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1619104748998" ID="ID_1862152665" MODIFIED="1619106836504" TEXT="zu Klären: Skala für Screen-Koordinaten und/oder Pixel">
|
|
<arrowlink COLOR="#6084b9" DESTINATION="ID_206049495" ENDARROW="Default" ENDINCLINATION="-1698;230;" ID="Arrow_ID_1554039358" STARTARROW="None" STARTINCLINATION="-5611;254;"/>
|
|
<linktarget COLOR="#de5c6e" DESTINATION="ID_1862152665" ENDARROW="Default" ENDINCLINATION="139;212;" ID="Arrow_ID_1129738995" SOURCE="ID_671218820" STARTARROW="None" STARTINCLINATION="686;61;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1619104774025" ID="ID_1244834056" MODIFIED="1619105073946" TEXT="habe mir darüber nie Gedanken gemacht">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1619104785553" ID="ID_1913808351" MODIFIED="1619104792020" TEXT="Cairo und GDK liefern doubles"/>
|
|
<node CREATED="1619104793778" ID="ID_988488039" MODIFIED="1619105005937" TEXT="die Maus-Events haben typischerweise eine Nachkommastelle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
BUTT true flag=«GdkEventType»
|
|
</p>
|
|
<p>
|
|
MOVE x=18.4 y=12.5
|
|
</p>
|
|
<p>
|
|
ANCHOR at x=18.4 y=12.5 ('scope_moveRelocateClip')
|
|
</p>
|
|
<p>
|
|
MOVE x=18.8 y=12.5
|
|
</p>
|
|
<p>
|
|
MOVE x=19.3 y=12.5
|
|
</p>
|
|
<p>
|
|
MOVE x=19.8 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=20.2 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=20.5 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=20.9 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=21.4 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=21.9 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=22.3 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=23.0 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=23.9 y=13.0
|
|
</p>
|
|
<p>
|
|
MOVE x=24.8 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (6.4,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=25.8 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (7.4,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=26.7 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (8.3,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=27.3 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (8.9,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=27.9 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (9.5,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=28.6 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (10.2,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=29.0 y=13.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (10.6,0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=30.6 y=12.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (12.2,-0.5)
|
|
</p>
|
|
<p>
|
|
MOVE x=31.5 y=12.0
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (13.1,-0.5)
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
MOVE x=97.8 y=97.9
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (79.4,85.4)
|
|
</p>
|
|
<p>
|
|
MOVE x=97.8 y=98.7
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (79.4,86.2)
|
|
</p>
|
|
<p>
|
|
MOVE x=97.8 y=100.6
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (79.4,88.1)
|
|
</p>
|
|
<p>
|
|
MOVE x=97.8 y=102.6
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (79.4,90.1)
|
|
</p>
|
|
<p>
|
|
MOVE x=97.8 y=103.6
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (79.4,91.1)
|
|
</p>
|
|
<p>
|
|
MOVE x=98.6 y=104.4
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (80.2,91.9)
|
|
</p>
|
|
<p>
|
|
MOVE x=98.6 y=105.2
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (80.2,92.7)
|
|
</p>
|
|
<p>
|
|
MOVE x=98.6 y=106.2
|
|
</p>
|
|
<p>
|
|
Gesture(scope_moveRelocateClip) --> Δ := (80.2,93.7)
|
|
</p>
|
|
<p>
|
|
!!BANG!! Gesture-Cmd 'scope_moveRelocateClip'
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664031608178" ID="ID_1388493107" MODIFIED="1664031621917" TEXT="aber Widgets arbeiten typischerweise mit Integer"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619697245422" ID="ID_1061197338" MODIFIED="1619804310109" TEXT="Forwarding über mehrere Schritte">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
der clipHook() delegiert an seinen jeweiligen refHook_
|
|
</li>
|
|
<li>
|
|
dieser wird bei der Konstruktion tatsächlich jweils auf den Anchor-Hook des Parent-Hook gesetzt
|
|
</li>
|
|
<li>
|
|
damit steht im refHook_ effektiv der top-level Canvas, und die jeweilige Blatt-Ebene fügt ihren Offset hinzu
|
|
</li>
|
|
<li>
|
|
allerdings würde nun zur Übersetzung der Koordinaten der top-Level-Canvas nochmal an den Layout-Manager delegieren
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1619697735697" ID="ID_1610716398" MODIFIED="1619697746057" TEXT="effektiv 2-Schritt-Forwarding für jeden Aufruf"/>
|
|
<node COLOR="#338800" CREATED="1619697793583" FOLDED="true" ID="ID_800939749" MODIFIED="1619804558065" TEXT="kann man (opaque) direkt aufrufen?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619698100329" ID="ID_1983859376" MODIFIED="1619698109360" TEXT="ja: wenn es ein VTable-Slot ist">
|
|
<node CREATED="1619698280744" ID="ID_1197467052" MODIFIED="1619698299342" TEXT="dazu müßte das Delegate ein Sub-Interface implementieren"/>
|
|
<node CREATED="1619698300242" ID="ID_498514293" MODIFIED="1619698315566" TEXT="und der Wrapper ebenfalls"/>
|
|
<node CREATED="1619698316317" ID="ID_629600190" MODIFIED="1619698329643" TEXT="dann kann der Wrapper seine Sub-Komponente vom Delegate initialisieren"/>
|
|
</node>
|
|
<node CREATED="1619697887065" ID="ID_1694064911" MODIFIED="1619788146033" TEXT="RelativeCanvasHook">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1619698448530" ID="ID_231932844" MODIFIED="1619698455469" TEXT="ist zu 100% ein Dekorator"/>
|
|
<node CREATED="1619698460320" ID="ID_1397414962" MODIFIED="1619698473284" TEXT="erbt zudem vom gleichen Interface wie sein Delegate"/>
|
|
<node CREATED="1619698474655" ID="ID_609667543" MODIFIED="1619698501783" TEXT="⟹ klassishe linearisierte Vererbung"/>
|
|
<node CREATED="1619787501628" ID="ID_1894601265" MODIFIED="1619787526640" TEXT="trotzdem wird es stets zwei indirekte Aufrufe geben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1619787529209" ID="ID_1165327118" MODIFIED="1619787547480" TEXT="kann man einen davon einsparen?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1619787550612" ID="ID_1297192304" MODIFIED="1619787577240" TEXT="jaa man kannnn...">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1619787584274" FOLDED="true" ID="ID_1256984812" MODIFIED="1619788141013" TEXT="das wird aber durchaus komplex">
|
|
<linktarget COLOR="#9f5337" DESTINATION="ID_1256984812" ENDARROW="Default" ENDINCLINATION="-812;-59;" ID="Arrow_ID_1128030260" SOURCE="ID_263543815" STARTARROW="None" STARTINCLINATION="2097;137;"/>
|
|
<icon BUILTIN="flag-orange"/>
|
|
<node CREATED="1619787756234" ID="ID_566753329" MODIFIED="1619787782836" TEXT="das konkrete Body-Canvas-Widget müßte umgeschrieben werden"/>
|
|
<node CREATED="1619787783758" ID="ID_955157823" MODIFIED="1619787838923" TEXT="die eigentliche Implementierung des CanvasHook müßte per Mix-In realisiert werden"/>
|
|
<node CREATED="1619787839607" ID="ID_736108938" MODIFIED="1619787853365" TEXT="und zwar ein konkretes Implementieruns-Mix-in"/>
|
|
<node CREATED="1619787854247" ID="ID_1799143382" MODIFIED="1619787870551" TEXT="dieses bekommt einen konkreten GTK-Canvas als Referenz"/>
|
|
<node CREATED="1619787894264" ID="ID_982929479" MODIFIED="1619787918928" TEXT="und außerdem müßte es bereits den Offset als Ctor-Parameter mitbekommen"/>
|
|
<node CREATED="1619787926203" ID="ID_166173193" MODIFIED="1619788009055" TEXT="und der Nutzer (DisplayFrame im TrackPresenter) müßte dieses konkrete Objekt-API sehen"/>
|
|
<node CREATED="1619788024275" ID="ID_1728948599" MODIFIED="1619788043839" TEXT="allerdings könnte man trotzdem die Impl. in einem separaten Translation-Unit "verbergen""/>
|
|
<node CREATED="1619788065160" ID="ID_1004040494" MODIFIED="1619788100395" TEXT="Ergebnis: alle Aufrufe gehen direkt durch die VTable in dieses konkrete Canvas-Mixin"/>
|
|
</node>
|
|
<node CREATED="1619787626757" ID="ID_1522870458" MODIFIED="1619799442131" TEXT="und ist hier nicht gerechtfertigt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Platzieren auf den Canvas ist <b>keine</b> high-Performance-Operation;<br />vielmehr ist es sogar <i>vernachlässigbar im Vergleich </i>zum Aufwand der Zeichen-Operationen; und letztere werden eben genau aus Performance-Gründen gebatcht und gebündelt....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#6775b4" DESTINATION="ID_1522870458" ENDARROW="Default" ENDINCLINATION="125;10;" ID="Arrow_ID_565826448" SOURCE="ID_1388699771" STARTARROW="None" STARTINCLINATION="290;14;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619698512378" ID="ID_333159714" MODIFIED="1619804302859" TEXT="Metrik-Übersetzung">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1619698551205" ID="ID_994295604" MODIFIED="1619698871778" TEXT="sieht nach einem isolierten Belang aus">
|
|
<arrowlink COLOR="#fef4ac" DESTINATION="ID_560285819" ENDARROW="Default" ENDINCLINATION="150;-12;" ID="Arrow_ID_514924311" STARTARROW="None" STARTINCLINATION="-370;27;"/>
|
|
</node>
|
|
<node CREATED="1619698570431" ID="ID_1571275788" MODIFIED="1619698582909" TEXT="wird durch den RelativeCanvasHook nur durchgereicht"/>
|
|
<node CREATED="1619698583671" ID="ID_1092960475" MODIFIED="1619698623962" TEXT="ein Sub-Interface würde das Design versbessern">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1619799300329" ID="ID_170912303" MODIFIED="1619799331661" TEXT="direkt im Gesture-Controller nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1619799349705" ID="ID_281542411" MODIFIED="1619799359972" TEXT="in diesem Fall dann nur noch eine Indirektion"/>
|
|
<node CREATED="1619799367600" ID="ID_1388699771" MODIFIED="1619799442130">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Gegensatz zum CanvasHook ist <i>das hier durchaus relevant</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6775b4" DESTINATION="ID_1522870458" ENDARROW="Default" ENDINCLINATION="125;10;" ID="Arrow_ID_565826448" STARTARROW="None" STARTINCLINATION="290;14;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619698607118" ID="ID_239118181" MODIFIED="1619804296540" TEXT="Umbau sehr wünschenswert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619104345461" ID="ID_414006920" MODIFIED="1620922860429" TEXT="Aufgabe: API">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619104353964" ID="ID_1748021574" MODIFIED="1619104378116" TEXT="vorhanden: translateTimeToPixels(TimeValue startTimePoint)"/>
|
|
<node CREATED="1619132261261" ID="ID_1989281789" MODIFIED="1619132284186" TEXT="erst mal nach Bedarf ― aber genau">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1619132344961" ID="ID_168747829" MODIFIED="1619132509806" TEXT="konkret hier...">
|
|
<node COLOR="#435e98" CREATED="1619132510942" ID="ID_1513485460" MODIFIED="1620922851937" TEXT="applyScreenDelta(TimeValue, deltaPx)"/>
|
|
<node COLOR="#435e98" CREATED="1619132513720" ID="ID_718240764" MODIFIED="1619132619351" TEXT="translateScreenDeltaToTime(deltaPx)"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619698634099" ID="ID_1185723124" MODIFIED="1619804547408" TEXT="Sub-Interface einführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619698644218" ID="ID_560285819" MODIFIED="1619698871778" TEXT="es ist ein komplett isolierter Belang">
|
|
<linktarget COLOR="#fef4ac" DESTINATION="ID_560285819" ENDARROW="Default" ENDINCLINATION="150;-12;" ID="Arrow_ID_514924311" SOURCE="ID_994295604" STARTARROW="None" STARTINCLINATION="-370;27;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1619698681269" ID="ID_969574933" LINK="#ID_1202075896" MODIFIED="1666476922140">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Name: <b>DisplayMetric</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1619698722008" FOLDED="true" ID="ID_755674225" MODIFIED="1619804539751" TEXT="wird (parametrisierbare) Komponente im LayoutManager">
|
|
<arrowlink COLOR="#fe576f" DESTINATION="ID_400013153" ENDARROW="Default" ENDINCLINATION="2062;0;" ID="Arrow_ID_920475961" STARTARROW="None" STARTINCLINATION="160;125;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1619804516182" ID="ID_303795305" MODIFIED="1619804534566" TEXT="vorläufige Dummy-Implementierung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619804525392" ID="ID_1563089049" MODIFIED="1619804538286" TEXT="in timeline-layout.cpp, Zeile 123"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619698793375" ID="ID_127168366" MODIFIED="1619804320757" TEXT="und Mix-In für die CanvasHook-Hierarchie">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619132645927" ID="ID_3614055" MODIFIED="1624023436030" TEXT="Umgang mit Zeit-Werten (immutable)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#990000" CREATED="1620913903207" ID="ID_236784465" MODIFIED="1624023359388" TEXT="Lösung time::Control (Mutator)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das time::Control lebt dann wohl im Observer, und dieser muß eine Schnittstelle haben, über die das time::Control auf das eigentliche Zielfeld gesetzt wird...<br /><br />...das klingt alles gefährlich indirekt...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1624023373631" ID="ID_145048922" MODIFIED="1624023427379" TEXT="besser TimeVar im Gui-Modell (=Widget) verwenden">
|
|
<arrowlink COLOR="#5488c6" DESTINATION="ID_504607651" ENDARROW="Default" ENDINCLINATION="471;-37;" ID="Arrow_ID_952881957" STARTARROW="None" STARTINCLINATION="311;17;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618753085285" ID="ID_560686142" MODIFIED="1618753216324" TEXT="noch keinerlei Infrastruktur für die vertikale Anordnung">
|
|
<linktarget COLOR="#fdd8c6" DESTINATION="ID_560686142" ENDARROW="Default" ENDINCLINATION="-13;13;" ID="Arrow_ID_1300202813" SOURCE="ID_783305795" STARTARROW="None" STARTINCLINATION="150;10;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1618753226088" ID="ID_338199340" MODIFIED="1618753660191" TEXT="die notwendigen Daten können aus dem TrackPofil abgeleitet werden"/>
|
|
<node CREATED="1618753661418" ID="ID_1032426032" MODIFIED="1618753679006" TEXT="der TrackBody hat eine startLine_"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1624113834120" ID="ID_783305795" MODIFIED="1624114136410">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Stand: funktioniert ― ist aber <i>halbfertig</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fdd8c6" DESTINATION="ID_1895003083" ENDARROW="Default" ENDINCLINATION="-729;49;" ID="Arrow_ID_547396305" STARTARROW="None" STARTINCLINATION="218;15;"/>
|
|
<arrowlink COLOR="#fdd8c6" DESTINATION="ID_560686142" ENDARROW="Default" ENDINCLINATION="-13;13;" ID="Arrow_ID_1300202813" STARTARROW="None" STARTINCLINATION="150;10;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618672754370" ID="ID_1707555267" MODIFIED="1618678693304" TEXT="Deta ermitteln und speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1618677375507" ID="ID_1988208665" MODIFIED="1618677380678" TEXT="Frage: in welchem Typ">
|
|
<node CREATED="1618677381682" ID="ID_1297330759" MODIFIED="1618677391341" TEXT="GTK führt hier einen "gdouble" ein"/>
|
|
<node CREATED="1618677393499" ID="ID_1949606460" MODIFIED="1618677453343" TEXT="Grund ist Portabilität">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>(gtypes.h)</u>: Provide type definitions for commonly used types.
|
|
</p>
|
|
<p>
|
|
These are useful because a "gint8" can be adjusted  to be 1 byte (8 bits) on all platforms. Similarly and more importantly, "gint32" can be adjusted to be 4 bytes (32 bits) on all platforms.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618677455637" ID="ID_1287724015" MODIFIED="1618678210573" TEXT="Beschluß: Pixel-Koordinaten bleiben in gdouble">
|
|
<arrowlink COLOR="#798bb0" DESTINATION="ID_389115801" ENDARROW="Default" ENDINCLINATION="1665;148;" ID="Arrow_ID_267819706" STARTARROW="None" STARTINCLINATION="2440;141;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1618680945551" FOLDED="true" HGAP="87" ID="ID_1888024059" MODIFIED="1618691004190" TEXT="Problem: erfordert GTK-Include" VSHIFT="10">
|
|
<edge COLOR="#ef844b"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1618680980802" ID="ID_1858177352" MODIFIED="1618680998860" TEXT="zumindest für den CmdContext_test ist das ein Problem"/>
|
|
<node COLOR="#435e98" CREATED="1618690973298" ID="ID_37829159" MODIFIED="1618690986175" TEXT="daher: nicht auf das Subject-Interface">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1618690987320" ID="ID_1868741682" MODIFIED="1618690998458" TEXT="nur für framework-nahen-Code">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618678631049" ID="ID_416362140" MODIFIED="1618678643480" TEXT="Delta wird gar nicht gespeichert"/>
|
|
<node CREATED="1618678644600" ID="ID_246060471" MODIFIED="1618678652922" TEXT="Delta wird on-the-fly errechnet"/>
|
|
<node CREATED="1618678668124" ID="ID_284887160" MODIFIED="1618678688381" TEXT="Konsequenz: Scroll-Adjustment muß "downstream" erfolgen">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618672778615" ID="ID_623020020" MODIFIED="1624113806456" TEXT="Position aktualisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1618681116488" ID="ID_1434451478" MODIFIED="1618681123602" TEXT="Daten an das Subject weitergeben"/>
|
|
<node COLOR="#435e98" CREATED="1618681157532" ID="ID_905364501" MODIFIED="1618690878227" TEXT="Gestenerkennungs-Logik funktioniert noch nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sehe nur die MOVE-Meldungen.<br />eigentlich sollte das Subject ebenfalls Meldungen ausspucken
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
⟹ mehrere Gründe...<br />
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
bekomme überhaupt kein motion_event, wenn kein Button gedrückt ist. Liegt das daran, daß ich ein Button-Widget zum Testen verwende??
|
|
</li>
|
|
<li>
|
|
unabhängig davon war die Logik auch sonst kaputt. Die Flag isInFormation_ wurde nicht gesetetzt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618690884114" ID="ID_1184207694" MODIFIED="1618690935797" TEXT="Logik jetzt repariert und Hysterese eingebaut">
|
|
<arrowlink COLOR="#22d66c" DESTINATION="ID_1241205333" ENDARROW="Default" ENDINCLINATION="35;105;" ID="Arrow_ID_1887863096" STARTARROW="None" STARTINCLINATION="348;20;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618691013997" ID="ID_429908834" MODIFIED="1620922873764" TEXT="Delta an das Subject weitergeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1619887175393" FOLDED="true" ID="ID_54981427" MODIFIED="1619887223546" TEXT="Problem: Aufwand für Gesten-Verfolgung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1619887230011" ID="ID_1178141750" MODIFIED="1619887552418" TEXT="Push von low-Level-Events erzeugt Übersetzungsaufwand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
typischerweise liefern die low-level-Events gerätespezifische Koordinaten ab, und deren Übersetzung in die Modell/Domänenwerte erfordert Hilfsmittel, die man sich mehrstufig beschaffen muß. Da aber die einzelnen Events unverbunden daherkommen, muß die Verarbeitung vereinzelt erfolgen. Und das heißt, man leistet diesen Einrichtungs-Aufwand für jedes einzelne Event; dies geht zu Lasten der »Reaktivität«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1619887281662" ID="ID_843790040" MODIFIED="1619887627626" TEXT="Spezial-Konventionen blähen das API auf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn man nun eine fest-vorbereitete Lösung für jeden Fall vorsieht, wird die Schnittstelle bereit, unübersichtlich und könnte im Lauf der Zeit verwuchern. Zudem muß eine komplexe Konvention errichtet werden, wer wann für wen welche Variante aufruft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1619887333950" ID="ID_1150224022" MODIFIED="1619887725547" TEXT="ein Übersetzungs-Funktor braucht Platz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Daher erscheint ein Adapter sinnvoll, der jeweils für eine einzelne Gesten-Instanz erzeugt wird. Dies erfordert jedoch Storage, welche ohne großen Overhead bereitgestellt und effizient genutzt sein will
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619887730416" FOLDED="true" ID="ID_915000313" MODIFIED="1620913945733" TEXT="Lösung: Subject zu einem Protokoll ausbauen">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1619887769934" ID="ID_15885968" MODIFIED="1620565933367" TEXT="Schnittstelle zum Verdrahten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619887785265" ID="ID_194430924" MODIFIED="1620913562059" TEXT="ein Adapter für die Gesten-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619887907477" ID="ID_580784250" MODIFIED="1619887914507" TEXT="wird vom Subject konkret bereitgestellt"/>
|
|
<node CREATED="1619887915592" ID="ID_1016019139" MODIFIED="1619887925546" TEXT="wird in der Storage des Gesten-Controllers abgelegt"/>
|
|
<node CREATED="1619887926542" ID="ID_234628540" MODIFIED="1619887933409" TEXT="lebt bis zum Ende der Geste"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1619888087712" ID="ID_279012098" MODIFIED="1619903390115" TEXT="Anforderung: Generische Implementierung mit konkretem Typ">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1619888991781" ID="ID_1808059433" MODIFIED="1619888994864" TEXT="warum?">
|
|
<node CREATED="1619888150728" ID="ID_1072043025" MODIFIED="1619888160161" TEXT="yet-another-indirection vermeiden"/>
|
|
<node CREATED="1619888165743" ID="ID_1820882158" MODIFIED="1619888172801" TEXT="Inlining ermöglichen"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1619889004742" ID="ID_962466680" MODIFIED="1619903372110" TEXT="geht das überhaupt?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1619893616079" ID="ID_1820351141" MODIFIED="1619894138543" TEXT="ehr nicht....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sobald irgendwo eine Abstraktionsbarriere errichtet wird, muß mindestens ein Call indirekt oder virtuell sein....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Abstraktion zwischen Widget und Canvas muß ich erhalten, weil die Timeline-Anzeige noch ziemlich komplex wird
|
|
</li>
|
|
<li>
|
|
sofern der Gesten-Controller mit beliebigen Widgets umgehen soll, gibt es eine weitere Abstraktion
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1619903180827" ID="ID_250477630" MODIFIED="1619903245581" TEXT="darüber muß ich wohl (zunächst?) großzügig hinwegsehen"/>
|
|
<node CREATED="1619903259743" ID="ID_872225515" MODIFIED="1619903353944" TEXT="zu Vieles ist noch nicht klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
im Bezug auf die Performance weiß ich nicht, wo die Meßlatte liegt
|
|
</li>
|
|
<li>
|
|
die tatsächlich benötigte Abstraktion kann sich noch als ganz anders herausstellen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619967216789" ID="ID_1503155358" MODIFIED="1620913547263" TEXT="aber an der Idee mit dem Adapter halte ich fest...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1619967266842" ID="ID_1478677945" MODIFIED="1619967373917">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die konkrete Interpretation der Mausbewegung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1619967375039" ID="ID_1955578195" MODIFIED="1619967379379" TEXT="...aus dem Gesten-Controller herauszuhalten"/>
|
|
<node CREATED="1619967252543" ID="ID_630081269" MODIFIED="1619967547078" TEXT="ich sehe keinen anderen Weg....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sonst würde entweder das Subject selber ad hoc etwas bereitstellen müssen und dafür zusätzliche Storage brauchen (<b>Hebel</b>, es gibt sehr viele Subjekte!), oder das Interface "Subject" würde löchrig und zu einer Kodifizierung von Einzelfällen. Die Lösung mit dem Adapter stattdessen fällt unter das Prinzip <i>Inversion of Control</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1619972768498" ID="ID_1614732760" MODIFIED="1620419721948" TEXT="das bedeutet: opaque buffer verwenden">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1619972787360" FOLDED="true" ID="ID_82004044" MODIFIED="1620419687276" TEXT="PlantingHandle">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1619972797494" ID="ID_1468885512" MODIFIED="1619972821488" TEXT="nebenbei: Operation "create" → "emplace"">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619976082135" ID="ID_416166359" MODIFIED="1619976677236" TEXT="Variante für placement-new einbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1619976099788" ID="ID_1451882006" MODIFIED="1620419375147" TEXT="Problem: DEFAULT-Typ und SIZE-Parameter in das Handle einbetten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619976624404" ID="ID_1394264630" MODIFIED="1619976674356" TEXT="DEFAULT-Typ kann als Typ-Parameter weiteregeben werden">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1619976641856" ID="ID_960415515" MODIFIED="1619976671474" TEXT="dann wird eben auch der Typ vom Handle komplexer">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619976655262" ID="ID_411012847" MODIFIED="1619976666398" TEXT="dafür in InPlaceBuffer einen Typ-Konstruktor anbieten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1619976688954" ID="ID_1451984496" MODIFIED="1620406002701" TEXT="nochmal über den Size-Parameter nachdenken...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#990000" CREATED="1619976702067" ID="ID_1433875229" MODIFIED="1620406026837" TEXT="kann man den dann auch zur Compile-Zeit weitergeben?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1620406047028" ID="ID_433743632" MODIFIED="1620406164545" TEXT="definitiv nicht, denn dann wird der Client-Code dafür zuständig">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1620406133809" ID="ID_370253197" MODIFIED="1620406152098" TEXT="InPlaceBuffer == Implementierung"/>
|
|
<node CREATED="1620406153388" ID="ID_664190536" MODIFIED="1620406159849" TEXT="PlantingHandle == Schnittstelle"/>
|
|
</node>
|
|
<node CREATED="1620406074960" ID="ID_1455403417" MODIFIED="1620406114628">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn wir trotzdem einen Overrun-Check haben wollen,
|
|
</p>
|
|
<p>
|
|
kommen wir an einem zur Laufzeit verfügbaren Wert nicht vorbei
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1620406031439" ID="ID_481915593" MODIFIED="1620406248233" TEXT="das hatte ich mir früher schon mal überlegt....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...jetzt nach einigem Überlegen dämmert mir die Erinnerung...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1620406188961" ID="ID_1221022666" MODIFIED="1620406231393" TEXT="man kann ihn nicht einmal constexpr machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...auch daran kann ich mich jetzt wieder erinnern...<br />Dann wäre nämlich das Handle nicht mehr kopierbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1619976718142" ID="ID_210847961" MODIFIED="1620406270405" TEXT="wie sieht's mit Assignments aus?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1620406271998" ID="ID_870285433" MODIFIED="1620406308773" TEXT="für das Handle: möglich und explizit erwünscht">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620406283493" ID="ID_302408091" MODIFIED="1620406290904" TEXT="nun sogar im Test mit abgedeckt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620406315000" ID="ID_492931720" MODIFIED="1620419379057" TEXT="Test erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1620406319933" ID="ID_710376106" MODIFIED="1620406337957" TEXT="emplace hat so seine Tücken">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1620406339380" ID="ID_154149353" MODIFIED="1620409041229" TEXT="wieder das Problem mit perfect-forwarding + Varargs + ctor-Overload">
|
|
<arrowlink COLOR="#9a74a0" DESTINATION="ID_1554664514" ENDARROW="Default" ENDINCLINATION="1930;405;" ID="Arrow_ID_1066770776" STARTARROW="None" STARTINCLINATION="-6776;285;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1620409042922" ID="ID_1128192662" MODIFIED="1620409049869" TEXT="nein... oder vielleicht..."/>
|
|
<node CREATED="1620409051737" ID="ID_889061911" MODIFIED="1620409075166" TEXT="das Problem sind implizit definierte Konstruktoren in der Vererbuns-Hierarchie"/>
|
|
<node CREATED="1620409076118" ID="ID_1437249592" MODIFIED="1620409089599" TEXT="sobald ich alle Move-Konstruktoren explizit definiere, funktionieren alle Fälle"/>
|
|
<node CREATED="1620409290592" ID="ID_1921177921" MODIFIED="1620409322983" TEXT="gabs da nicht eine Regel, daß explizit definierte dtor einen impliziten move-ctor unterdrückt">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1620419440753" ID="ID_88675651" LINK="https://lumiera.org/documentation/technical/code/c++11.html" MODIFIED="1620419505615" TEXT="dokumentiert...."/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620406576782" ID="ID_791550280" MODIFIED="1620419382240" TEXT="also doch besser eine dedizierte emplace()-Funktion auch auf dem InPlaceBuffer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620419383512" ID="ID_30151801" MODIFIED="1620419404721" TEXT="Genzfälle + Handle-Kopie">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620419779271" ID="ID_64726693" MODIFIED="1620565782987" TEXT="brauche Fallback-Adapter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1620419793888" ID="ID_1040008985" MODIFIED="1620419938844" TEXT="Einschränkung von InPlaceBuffer / PlantingHandle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
diese verwalten nicht aktiv den Typ und Zustand im Buffer.
|
|
</p>
|
|
<p>
|
|
Daher muß stets ein Objekt im Buffer (default)-konstruiert sein; ein reines (abstraktes) Interface genügt nicht. An dieser Stelle bietet sich ein "NULL-Ojbekt" an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620419964630" ID="ID_1402318337" MODIFIED="1620565784596" TEXT="dieser bewirkt, daß keine Geste erkannt werden kann">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1620565871398" ID="ID_574697565" MODIFIED="1620565887201">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Name: <b>GestureObserver</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620419708341" ID="ID_53797308" MODIFIED="1620565786800" TEXT="Subject-API erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1620565789665" ID="ID_515994897" MODIFIED="1620913405382" TEXT="Implementierung schwenken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1620913417225" ID="ID_1322371180" MODIFIED="1620913542016" TEXT="cmd-ID kann in den Observer verlegt werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1620913426512" ID="ID_1802612620" MODIFIED="1620913444069" TEXT="Pointer auf das Subject könne eigentlich auch dorthin">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1620913445509" ID="ID_1831141576" MODIFIED="1620913451984" TEXT="bringt aber nix"/>
|
|
<node CREATED="1620913452692" ID="ID_339655971" MODIFIED="1620913529933" TEXT="und außerdem benutze ich den Pointer auch als Flag">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist eleganter, als jede der denkbaren Alternativen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
stattdessen eine virtuelle Funktion für diesen State verwenden<br />
|
|
</li>
|
|
<li>
|
|
stattdessen einen "magischen wert" in den Anker-Koordinaten speichern
|
|
</li>
|
|
<li>
|
|
<br />
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618691023427" ID="ID_1396949384" MODIFIED="1620922896886" TEXT="im Subject in Modell-Koordinaten transformieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
funktioniert... Zeit-Werte werden an der Konsole ausgegeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1618691042073" ID="ID_1909659922" MODIFIED="1621013334123" TEXT="tatsächlich im Canvas verschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1621010969579" ID="ID_226757951" MODIFIED="1621011049406" TEXT="Frage: wann wird der Wert im GUI-Model geändert?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1621011000382" ID="ID_1931186164" MODIFIED="1621011011561" TEXT="konkret: GUI-Model == Daten im Clip-Widget"/>
|
|
<node CREATED="1621011012379" ID="ID_456544957" MODIFIED="1621011043485" TEXT="Variante-1: erst beim Bang!">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1621011155018" ID="ID_1965916269" MODIFIED="1621011188855" TEXT="Vorteil: Abbruch der Geste wäre einfach">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nein.... nicht wirklich, weil man ja doch noch die Position korrigieren muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1621011025347" ID="ID_833583889" MODIFIED="1621011040553" TEXT="Variante-2: inkrementell">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1621011125061" ID="ID_1728131930" MODIFIED="1621011137840" TEXT="Vorteil: GUI-Position und interne Daten konsistent"/>
|
|
<node CREATED="1621011138669" ID="ID_1744077157" MODIFIED="1621011148646" TEXT="Vorteil: verwende nur eine updatePosition()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1621011053631" ID="ID_336933112" MODIFIED="1621011076192" TEXT="ClipData speichert bereits in zwei TimeVar">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1621011078108" ID="ID_1533766777" MODIFIED="1621011080673" TEXT="macht Sinn"/>
|
|
<node CREATED="1621011195716" ID="ID_504607651" MODIFIED="1621011206066" TEXT="hier brauchen wir kein time::Control">
|
|
<linktarget COLOR="#5488c6" DESTINATION="ID_504607651" ENDARROW="Default" ENDINCLINATION="471;-37;" ID="Arrow_ID_952881957" SOURCE="ID_145048922" STARTARROW="None" STARTINCLINATION="311;17;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1621011209299" ID="ID_26838929" MODIFIED="1621011219916" TEXT="Quantisierung passiert bereits im Session-Modell"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621011086402" ID="ID_1715852739" MODIFIED="1621013328247" TEXT="dann müssen diese aber auch auf das ClipWidget-Interface">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
letztlich kein Problem.
|
|
</p>
|
|
<p>
|
|
Das ClipWidget-Interface ist nur für den Clip-Presenter gedacht, um von der konkreten GUI-Repräsentation (abdriged, extended) zu abstrahieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1621011225712" ID="ID_1506268791" MODIFIED="1621013320534" TEXT="getStart fällt dafür weg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621011235478" ID="ID_1478696622" MODIFIED="1621013319072" TEXT="und changeTimings ebenfalls">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621013307550" ID="ID_1002878072" MODIFIED="1621013317717" TEXT="Accessor heißen jetzt access*">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621013334938" ID="ID_492704684" MODIFIED="1621097715872" TEXT="Metrik korrekt übersetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1621013341929" ID="ID_417943116" MODIFIED="1621097397187" TEXT="Clip ist nicht an der Maus-Position">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1621013385355" ID="ID_1141346152" MODIFIED="1621097399578" TEXT="sondern etwa nur das halbe Delta">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1621013395618" ID="ID_671218820" MODIFIED="1621097408033" TEXT="dh. Canvas-Pixel ≠ GDK-Pixel">
|
|
<arrowlink COLOR="#de5c6e" DESTINATION="ID_1862152665" ENDARROW="Default" ENDINCLINATION="139;212;" ID="Arrow_ID_1129738995" STARTARROW="None" STARTINCLINATION="686;61;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#5e4398" CREATED="1621097410434" HGAP="30" ID="ID_222549022" MODIFIED="1621097540645" TEXT="nein: es ist exakt" VSHIFT="-6">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sobald man globale Screen-Koordinaten für die Delta-Berechnung verwendet; der Button <i>klebt jetzt exakt </i>an der Stelle, an der zuerst geklickt wurde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#c0709e"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621013349165" ID="ID_1048588084" MODIFIED="1621097392781">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Clip <i>zappelt</i> ― warum?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1621021141659" ID="ID_1023253092" MODIFIED="1621021229959" TEXT="Vermutung: weil GDK die Maus-Koordinaten relativ zum GDK-window liefert">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1621021182357" ID="ID_22597166" MODIFIED="1621021189124" TEXT="und das Window verschieben wir ja nun"/>
|
|
<node CREATED="1621021241365" ID="ID_426282812" MODIFIED="1621021322131" TEXT="Beobachtung: erst wenn wir verschieben, springen die Koordinaten alternierend">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bevor die Trigger-Schwelle erreicht ist, wachsen sie schön monoton<br />...auch ist das Springen exakt alternierend, ein Schritt vor, ein Schritt zurück
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1621095826074" ID="ID_68931867" MODIFIED="1621097299895" TEXT="Aufgabe: den Anker-Punkt korrigieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1621095839443" ID="ID_995526022" MODIFIED="1621095889081" TEXT="Begründung: das Delta sollte im Gesten-Controller bereinigt werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber das von GDK gelieferte Delta hängt eben vom GDK-Window des widgets ab
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1621096361136" ID="ID_1786120643" MODIFIED="1621096366693" TEXT="Gdk::Window::get_root_origin">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1621096851542" ID="ID_1348295641" MODIFIED="1621096876772" TEXT="Ha! das _GdkEventMotion liefert das GDK-Window mit">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1621096924735" ID="ID_1758702106" MODIFIED="1621096946994" TEXT="Ha² !! sogar die absoluten Koordinaten werden geliefert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621097276187" ID="ID_728413168" MODIFIED="1621097289156" TEXT="also stattdessen gleich die absoluten Koordinaten verwenden und gut is">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621013468896" ID="ID_129803095" MODIFIED="1621097712197" TEXT="prüfen: Anzeigegrenzen?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1621097549712" ID="ID_428075392" MODIFIED="1621097591467" TEXT="nach Umstellung auf Root-Koordinaten: Dragging stößt einfach an den Fensterrändern an"/>
|
|
<node COLOR="#435e98" CREATED="1621097633428" ID="ID_1248069599" MODIFIED="1621097643755" TEXT="let's keep it that way!">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1621097661601" ID="ID_1771351130" MODIFIED="1621097708271">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Gesten-Controller sollte hier nicht mitmischen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1621097664561" ID="ID_1891416270" MODIFIED="1621097705220" TEXT="das Subject könnte eine Beschränkung durchsetzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1621097686285" ID="ID_1677326508" MODIFIED="1621097701987" TEXT="aber besser, das wird in der Session gehandhabt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621096649593" ID="ID_316242168" MODIFIED="1621096653418" TEXT="Ergänzungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1621096654578" FOLDED="true" ID="ID_95750773" MODIFIED="1666368478091" TEXT="geht das mit allen Maus-Buttons?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1621096664860" ID="ID_957867261" MODIFIED="1624106696252" TEXT="verwende einen GTK::Button">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1621096673590" ID="ID_30538599" MODIFIED="1624106725084" TEXT="damit geht es nur im Moment mit Mittel-/Links-Button">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1621096684820" ID="ID_1886922228" LINK="https://stackoverflow.com/a/50127393" MODIFIED="1621096704345" TEXT="Hinweis auf Stackoverflow">
|
|
<node CREATED="1621096710666" ID="ID_482262631" MODIFIED="1621096715535" TEXT="demnach brauchen wir auch noch ButtonPressMask"/>
|
|
<node CREATED="1624106133858" ID="ID_576015548" MODIFIED="1624106184939" TEXT="paßt nicht wirklich ― wir müssen gar keine Events mer Mask freischalten">
|
|
<node CREATED="1624106186082" ID="ID_1560334421" MODIFIED="1624106199075" TEXT="GTKmm macht diese low-level-Verdrahtung"/>
|
|
<node CREATED="1624106199862" ID="ID_737437905" MODIFIED="1624106225480" TEXT="und zwar bereits korrekt, denn wir bekommen die motion_notify-Events"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1624106236054" ID="ID_859963027" MODIFIED="1624106261516" TEXT="ich glaube ehr, es liegt an dem Button, der bereits die linke Taste "greift""/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1624106269815" ID="ID_474563596" MODIFIED="1666368403135" TEXT="stattdessen könnte man schon mal das ElementBoxWidget anlegen">
|
|
<arrowlink COLOR="#2082a9" DESTINATION="ID_485594461" ENDARROW="Default" ENDINCLINATION="872;71;" ID="Arrow_ID_1204090343" STARTARROW="None" STARTINCLINATION="2306;92;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666368351190" ID="ID_231206120" MODIFIED="1666368387117" TEXT="ElementBoxWidget erbt von Gtk::EventBox ⟹ Events funktionieren nun wie erwartet">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1621097334389" ID="ID_37937061" MODIFIED="1624113776851" TEXT="kären: woher kommt die blaue Linie im Canvas, die mit Clip-2 mitwandert?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1624112312302" ID="ID_527659472" MODIFIED="1624112345913" TEXT="Genese unklar"/>
|
|
<node CREATED="1624112346753" ID="ID_1577761232" MODIFIED="1624112350129" TEXT="Beobachtungen">
|
|
<node CREATED="1624112351401" ID="ID_1554867729" MODIFIED="1624112475687" TEXT="hängt ab vom Test-zeichen-Code in TimelineCanvas::drawOverlays(cox)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dieser zeichnet die Kreise mit Ausdehnung der Allocation, und auch genau mit dieser Farbe und Linienbreite
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1624112476928" ID="ID_10007256" MODIFIED="1624112497845" TEXT="aber allem Anschein nach handelt es sich um eine Linie, nicht um einen Kreisbogen (arc)"/>
|
|
<node CREATED="1624112504484" ID="ID_585066990" MODIFIED="1624112524179" TEXT="deaktivieren der anderen Test-zeichen-Funktion (Grounding) beweirkt nichts"/>
|
|
<node CREATED="1624112533168" ID="ID_1573289000" MODIFIED="1624113075023" TEXT="der berechnete Radius ist stets konsistent und variiert nicht, wenn man den Clip verschiebt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein cout in genau diesem Testcode gibt stets nur alternierend den Allocation-Wert für den Ruler-Canvas (konstant 5px) und dann den Main-Canvas (variiert mit Fensterhöhe) aus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1624112560412" ID="ID_38361266" MODIFIED="1624112583301" TEXT="die Linie geht vom Ende des Kreises zum Anfang des Textes des zuletzt hinzugefügten Clip"/>
|
|
<node CREATED="1624113091220" ID="ID_522586131" MODIFIED="1624113111062" TEXT="die Linie wird nicht gezeichnet, wenn die arc(..)-Funktion nicht aufgerufen wird"/>
|
|
<node CREATED="1624113113393" ID="ID_666334880" MODIFIED="1624113134403" TEXT="Auskommentieren aller anderen Zeichenfunktionen in der Codebasis ändert nichts"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1624113136798" ID="ID_705175220" MODIFIED="1624113773596" TEXT="⟹ Schlußfolgerung">
|
|
<arrowlink COLOR="#6980d1" DESTINATION="ID_727104900" ENDARROW="Default" ENDINCLINATION="-1870;290;" ID="Arrow_ID_1515795020" STARTARROW="None" STARTINCLINATION="-2646;354;"/>
|
|
<node CREATED="1624113167761" ID="ID_1626319182" MODIFIED="1624113229429" TEXT="Cairo zeichnet eine Linienfolge"/>
|
|
<node CREATED="1624113230924" ID="ID_391833497" MODIFIED="1624113256653">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
jede Zeichen-Primitive zeichnet von der <i>aktuellen Position</i> weg
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1624113257517" ID="ID_70759730" MODIFIED="1624113272119" TEXT="diese muß man mit move_to explizit setzen"/>
|
|
<node CREATED="1624113272939" ID="ID_318150010" MODIFIED="1624113302609">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sonst <b>verschleppt</b> man eine <b>zufällig</b> vorher gegebene Position
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616684916746" ID="ID_571239713" MODIFIED="1616684947088">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
2.Schritt: <i>rektifizieren</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#478ab0" DESTINATION="ID_571239713" ENDARROW="Default" ENDINCLINATION="-346;39;" ID="Arrow_ID_265967702" SOURCE="ID_895795423" STARTARROW="None" STARTINCLINATION="99;8;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618573848753" ID="ID_1175000803" MODIFIED="1618575118786" TEXT="Re-Design als State-Machine">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1618573871374" ID="ID_716003171" MODIFIED="1618574116896" TEXT="Ziel: Entwicklungspfad zur vollständigen Lösung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Gesten-Controller sollen später einmal Teile eines umfangreicheren Frameworks werden; im Besonderen wollen wir abstrahierte Gesten, die verschiedene Eingabesysteme übergreifen können. Für dieses Ziel muß der konkrete Gesten-Controller soweit schematisiert sein, daß man im Zuge der weiteren Entwicklung sich ergebende Erweiterungspunkte einführen kann, auch in schon bestehende Implementierungen. Als naheliegendes Schema bietet sich die State-Machine an, da die Gesten-Erkennung auf theoretischer Ebene ohnehin ein (ggfs nichdeterministischer) FSA ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618574127123" ID="ID_1684392869" MODIFIED="1618574459686" TEXT="hierarchische Gesten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Multi-Touch<br />
|
|
</li>
|
|
<li>
|
|
Zusammensetzen einer komplexen Geste aus bereits implementierten Elementar-Gesten<br />
|
|
</li>
|
|
<li>
|
|
Einbinden eines bestehenden Gesten-Controller-Systems (z.B. in GTK) per Adapter
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618574134031" ID="ID_448471388" MODIFIED="1618574349745" TEXT="konkurrierende Gesten erkennen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
einfachers Dragging mit der Maus? oder kommt zum Abschluß eine spezielle Taste? oder eine spezielle Mausgeste?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618574145104" ID="ID_1569426176" MODIFIED="1618574244273" TEXT="Gesten über mehrere Eingabesysteme hinweg">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Linke Hand: Hardware-Controller; Rechte Hand: Maus
|
|
</li>
|
|
<li>
|
|
Modus per Tastenkombination ausgelöst; Geste dann per Maus oder Stift abgeschlossen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618575194230" ID="ID_144431144" MODIFIED="1618575227970" TEXT="Planung: State-Machine für Gesten">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617919674980" ID="ID_1535616039" MODIFIED="1620913818152" TEXT="TODO: spezielle Buttons und Modifier konfigurierbar machen">
|
|
<linktarget COLOR="#eb4353" DESTINATION="ID_1535616039" ENDARROW="Default" ENDINCLINATION="-48;51;" ID="Arrow_ID_695007412" SOURCE="ID_914526002" STARTARROW="None" STARTINCLINATION="275;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618499388465" ID="ID_540657197" MODIFIED="1618499424481" TEXT="Problem: wie kann man dies einkapseln?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist total an das Framework gebunden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1620913676837" ID="ID_1104135051" MODIFIED="1620913687082" TEXT="Weiterungen(ungelöst)">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617569687944" ID="ID_914526002" MODIFIED="1620913823880" TEXT="Modifier sollten konfigurierbar sein">
|
|
<arrowlink COLOR="#eb4353" DESTINATION="ID_1535616039" ENDARROW="Default" ENDINCLINATION="-48;51;" ID="Arrow_ID_695007412" STARTARROW="None" STARTINCLINATION="275;0;"/>
|
|
<linktarget COLOR="#d54526" DESTINATION="ID_914526002" ENDARROW="Default" ENDINCLINATION="-19;-306;" ID="Arrow_ID_1156051405" SOURCE="ID_109351275" STARTARROW="None" STARTINCLINATION="-130;185;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1617569722132" ID="ID_1004932792" MODIFIED="1617569729653" TEXT="Einschränkung der Maustaste"/>
|
|
<node CREATED="1617569730283" ID="ID_1098298417" MODIFIED="1617569798116" TEXT="Modifier-Key auf der Tastatur"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1617569873288" ID="ID_32172316" MODIFIED="1617569973233" TEXT="Modus durch Tastenfolge aktiviert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel: das "grab" von Blender ist ein praktisches Konzept. Dort kann man ein Element überhaupt nur bewegen, wenn man vorher die "g"-Taste gedrückt hatte. So etwas will ich in Lumiera auch haben... ist aber nicht so ganz einfach
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1617570608516" ID="ID_1536648683" MODIFIED="1617570619960" TEXT="Vorsicht: das ist ein Riesen-Thema">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1617570633938" ID="ID_1636227122" MODIFIED="1617570654929" TEXT="Stichwort: globale und konsistente Tastenkürzel">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1618499304789" ID="ID_636470529" MODIFIED="1618499325642" TEXT="das sollte besser durch Komposition gelöst werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Hierarchische Gesten-Controller
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1624114196431" ID="ID_400013153" MODIFIED="1679359046667" TEXT="brauche DisplayMetric im Layout-Manager">
|
|
<arrowlink COLOR="#9f3f5e" DESTINATION="ID_489715422" ENDARROW="Default" ENDINCLINATION="-2561;184;" ID="Arrow_ID_597075385" STARTARROW="None" STARTINCLINATION="-1907;-124;"/>
|
|
<linktarget COLOR="#fe576f" DESTINATION="ID_400013153" ENDARROW="Default" ENDINCLINATION="2435;0;" ID="Arrow_ID_858529243" SOURCE="ID_1895003083" STARTARROW="None" STARTINCLINATION="240;261;"/>
|
|
<linktarget COLOR="#fe576f" DESTINATION="ID_400013153" ENDARROW="Default" ENDINCLINATION="2062;0;" ID="Arrow_ID_920475961" SOURCE="ID_755674225" STARTARROW="None" STARTINCLINATION="160;125;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1679359094871" ID="ID_895795423" MODIFIED="1679359187122">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Stand</u>: Konzeptstudie erfolgreich
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Sollte als Nächstes versäubert und verallgemeinert werden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#478ab0" DESTINATION="ID_571239713" ENDARROW="Default" ENDINCLINATION="-346;39;" ID="Arrow_ID_265967702" STARTARROW="None" STARTINCLINATION="99;8;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661695805867" ID="ID_1948510442" MODIFIED="1661695811742" TEXT="klassische Aktionen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1661695813570" ID="ID_847601277" MODIFIED="1661696199675" TEXT="Pop-up-Menü">
|
|
<linktarget COLOR="#b75976" DESTINATION="ID_847601277" ENDARROW="Default" ENDINCLINATION="599;-2197;" ID="Arrow_ID_579055023" SOURCE="ID_1764427475" STARTARROW="None" STARTINCLINATION="945;81;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1661696222283" ID="ID_1568591637" MODIFIED="1661696237648" TEXT="übergreifendes Thema: Konzept fehlt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1661696243936" ID="ID_323696283" MODIFIED="1661696248139" TEXT="Anforderungen">
|
|
<node CREATED="1661696249705" ID="ID_504989161" MODIFIED="1661696270808" TEXT="wird ausgelöst über lokales Widget-Binding"/>
|
|
<node CREATED="1661696271684" ID="ID_1004582513" MODIFIED="1661696338493" TEXT="könnte auch durch ein generisches Fallback-Binding ausgelöst werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich meine rechts-Klick; typischerweise implementiert man den Handler dafür auf einem Canvas; aber dann ist das Problem: wie findet der Handler das konkrete Widget, und von diesem den Kontext für das pop-Up?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1661696344091" ID="ID_1244762978" MODIFIED="1661696359080" TEXT="muß aber spezifisch passend für jedes Element bestückt werden"/>
|
|
<node CREATED="1661696374631" ID="ID_94228587" MODIFIED="1661696389416" TEXT="aber ein Teil ist generisch ⟹ wir brauchen Schablonen"/>
|
|
<node CREATED="1661696398507" ID="ID_912582971" MODIFIED="1661696544568" TEXT="in das Action-Binding muß die jeweilige Element-ID injiziert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
genauer, das Action-Binding sendet eine Nachricht in den UI-Bus, aber diese muß an das korrespondierende Modell-Element addressiert werden; zwar gibt es unten im Steam-Layer einen gemeinsamen Command-Handler, und für jeden Command-Typ ist ein Skript hinterlegt — welches jedoch dann eine Element-ID als Parameter bekommen muß (oder besser sogar schon eine direkte Dependency-Injection?)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1661695822737" ID="ID_1370769282" MODIFIED="1661695834347" TEXT="Toolbar-Buttons"/>
|
|
<node CREATED="1661695835007" ID="ID_1327781873" MODIFIED="1661695841666" TEXT="Manipulation per Property-Box"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488423514355" ID="ID_917891687" MODIFIED="1557498707233" TEXT="Steuerelemente">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1541858529489" FOLDED="true" ID="ID_838803024" MODIFIED="1664058686704" TEXT="ZoomWindow">
|
|
<linktarget COLOR="#5b5ca1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="-519;-1168;" ID="Arrow_ID_1674512697" SOURCE="ID_1949450244" STARTARROW="None" STARTINCLINATION="518;31;"/>
|
|
<linktarget COLOR="#5b5ca1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="-599;-1344;" ID="Arrow_ID_842684168" SOURCE="ID_1828075998" STARTARROW="None" STARTINCLINATION="426;56;"/>
|
|
<linktarget COLOR="#8e7ba1" DESTINATION="ID_838803024" ENDARROW="Default" ENDINCLINATION="171;760;" ID="Arrow_ID_1707924491" SOURCE="ID_1065721692" STARTARROW="None" STARTINCLINATION="-1855;126;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541858541550" ID="ID_1912142591" MODIFIED="1557498707233" TEXT="generische Abstraktionskomponente">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1541858585095" FOLDED="true" ID="ID_1823259238" MODIFIED="1557498707233" TEXT="zwei strikt getrennte Dimensionen">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1541858615893" FOLDED="true" ID="ID_301185249" MODIFIED="1672672266675" TEXT="Struktur">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1541858624972" ID="ID_342899879" MODIFIED="1557498707233" TEXT="Ort im Struktur-Graph">
|
|
<node CREATED="1541860265441" ID="ID_969408137" MODIFIED="1557498707233" TEXT="topologisch"/>
|
|
<node CREATED="1541860270378" ID="ID_927127002" MODIFIED="1557498707233" TEXT="im UI-window">
|
|
<node CREATED="1541860297740" ID="ID_185643503" MODIFIED="1557498707233" TEXT="eindimensional (=vertikal)"/>
|
|
<node CREATED="1541860305651" ID="ID_485148653" MODIFIED="1557498707233" TEXT="zweidimensional (Y down, X right)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541858647423" ID="ID_1731335932" MODIFIED="1557498707233" TEXT="Detaillierungsgrad">
|
|
<node CREATED="1541860465918" ID="ID_1278123804" MODIFIED="1557498707233" TEXT="topologisch"/>
|
|
<node CREATED="1541860469414" ID="ID_801313216" MODIFIED="1557498707233" TEXT="geometrisch">
|
|
<node CREATED="1541860476375" ID="ID_837020603" MODIFIED="1557498707233" TEXT="zumeist ausgeschlossen"/>
|
|
<node CREATED="1541860508135" ID="ID_1006267067" MODIFIED="1557498707233" TEXT="Ausnahme: Kurven und Graphen"/>
|
|
<node CREATED="1541860592548" ID="ID_1610724743" MODIFIED="1557498707233" TEXT="object coord <-> display coord"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1672672176925" ID="ID_738927743" MODIFIED="1672672262113" TEXT="noch nicht klar ob diese Dimensionen sinnvoll hier zu integrieren sind">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541858620165" ID="ID_946004941" MODIFIED="1557498707233" TEXT="Zeit">
|
|
<node CREATED="1541858706787" ID="ID_1161729387" MODIFIED="1557498707233" TEXT="ZoomAnchor">
|
|
<node CREATED="1541858712898" ID="ID_156836023" MODIFIED="1557498707233" TEXT="Control-Entity">
|
|
<node CREATED="1541859273199" ID="ID_1187678929" MODIFIED="1557498707233" TEXT="edit point"/>
|
|
<node CREATED="1541859280000" ID="ID_1932782561" MODIFIED="1557498707233" TEXT="playhead"/>
|
|
<node CREATED="1541859284069" ID="ID_299608050" MODIFIED="1557498707233" TEXT="mouse"/>
|
|
</node>
|
|
<node CREATED="1541859608646" ID="ID_412475230" MODIFIED="1557498707233" TEXT="time translation anchor point">
|
|
<node CREATED="1542384728240" ID="ID_538080146" MODIFIED="1557498707233" TEXT="nicht der Nullpunkt derZeitskala"/>
|
|
<node CREATED="1542384738364" ID="ID_922112299" MODIFIED="1557498707233" TEXT="sondern der Bezugspunkt für die Übersetzung Zeit -> Pixel"/>
|
|
</node>
|
|
<node CREATED="1541860174509" ID="ID_983216306" MODIFIED="1557498707233" TEXT="position within window">
|
|
<node CREATED="1541860195426" ID="ID_1143510761" MODIFIED="1557498707233" TEXT="relative"/>
|
|
<node CREATED="1541860198222" ID="ID_847832000" MODIFIED="1557498707233" TEXT="absolute">
|
|
<node CREATED="1544126105472" ID="ID_1636490570" MODIFIED="1576282358023" TEXT="relative-absolute">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
a fixed absolute number of tick units,
|
|
</p>
|
|
<p>
|
|
where 1 tick unit depends on the current zoom level
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1672672729523" ID="ID_204825395" MODIFIED="1672672853253" TEXT="vorerst durch generische Regel im Code festgelegt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...später möchte ich diesen als eigenen zusätzlichen Freiheitsgrad einführen; dazu muß aber bereits mehr über den Verwendungszusammenhang bekannt sein; insofern habe ich vorerst eine generische Regel implementiert, die den Zoom-Anchor anhand der Position zum Gesamt-Canvas festlegt (ganz am Anfgang liegt er ganz links, am Ende ganz rechts)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542384160498" ID="ID_1252241860" MODIFIED="1557498707233" TEXT="TimeWindow">
|
|
<node CREATED="1542384165737" ID="ID_705415129" MODIFIED="1557498707233" TEXT="die konkret sichbare TimeSpan"/>
|
|
<node CREATED="1542384188438" ID="ID_444895141" MODIFIED="1576282358023" TEXT="stets in realem relativem Zeitmaß">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
real, d.h. in Zeit (Mikroticks) und nicht in Bildschirm-Pixeln
|
|
</li>
|
|
<li>
|
|
relativ, d.h. im Bezug auf die nominelle Zeitskala dieser Timeline;<br />entsprechend der Angabe auf dem Time-Ruler
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541859633805" ID="ID_304890799" MODIFIED="1557498707233" TEXT="Scale">
|
|
<node CREATED="1541859805246" ID="ID_1619845581" MODIFIED="1557498707233" TEXT="temporal extension of one unit"/>
|
|
<node CREATED="1542384386446" ID="ID_1472241358" MODIFIED="1576282358022" TEXT="minval / maxval or unlimited?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beachte: nicht verwechseln mit absoluten Angaben.
|
|
</p>
|
|
<p>
|
|
Diese Skala <b>legt überhaupt nicht</b> fest, wo ihr Nullpunkt liegt
|
|
</p>
|
|
<p>
|
|
im Bezug auf eine globale absolute Zeitskala (denn das macht das betreffende Placement)
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Theoretisch könnte eine Skala auf einer Seite oder auf beiden Seiten limitiert sein....?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1542384604062" ID="ID_900384720" MODIFIED="1542384632672" TEXT="grundsätzlich niemals beschränkt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1542384636665" ID="ID_1760262238" MODIFIED="1542384648936" TEXT="Beschränkungen realisiert Lumiera als Placement">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1672672309323" ID="ID_903266469" MODIFIED="1672672619791" TEXT="es gibt technische Beschränkungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bedingt durch die interne Repräsesntation (als 64bit µ-Ticks bzw. signed fraction)...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die absoluten internen Zeitwerte in µ-Ticks sind beschränkt ±Time::MAX (=<font face="Monospaced">numeric_limits<int64_t>::max() / 30</font>)
|
|
</li>
|
|
<li>
|
|
die größtmögliche Zoomstufe wurde (mehr oder weniger willkürlich) festgelegt auf 2px / µ-Tick
|
|
</li>
|
|
<li>
|
|
ein Fenster mit weniger als 560px kann nicht die gesamte Zeit-Domäne darstellen (da sonst die rationale Arithmetik entgleist)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541859854902" ID="ID_614778835" MODIFIED="1557498707233" TEXT="display pixels per unit"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541860744327" HGAP="-42" ID="ID_462654912" MODIFIED="1557498707233" TEXT="Bezug / im Verhältnis zu" VSHIFT="27">
|
|
<node CREATED="1541860785369" ID="ID_1062556789" MODIFIED="1557498707233" TEXT="Display Window">
|
|
<node CREATED="1541860790726" ID="ID_1447889403" MODIFIED="1557498707233" TEXT="zweidimensional">
|
|
<node CREATED="1541860801663" ID="ID_622150499" MODIFIED="1557498707233" TEXT="horizontale Dimension wählbar">
|
|
<node CREATED="1541860828603" ID="ID_111513506" MODIFIED="1557498707233" TEXT="Zeit"/>
|
|
<node CREATED="1541860831875" ID="ID_1775831703" MODIFIED="1557498707233" TEXT="Extension"/>
|
|
</node>
|
|
<node CREATED="1541860818012" ID="ID_814200290" MODIFIED="1561827465320" TEXT="vertikale Dimension stets topologisch">
|
|
<node CREATED="1544127119809" ID="ID_431805088" MODIFIED="1544127122858" TEXT="nicht immer...."/>
|
|
<node CREATED="1544127123803" ID="ID_1360167609" MODIFIED="1544127127665" TEXT="Ausnahme: Kurven"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541859890231" ID="ID_1462660195" MODIFIED="1557498707233" TEXT="window size">
|
|
<node CREATED="1541859893555" ID="ID_1561827620" MODIFIED="1557498707233" TEXT="units within window"/>
|
|
<node CREATED="1541860100246" ID="ID_1049947511" MODIFIED="1557498707233" TEXT="typically dictated by external constraints"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542384851045" ID="ID_362962483" MODIFIED="1557498707233" TEXT="Display Strategy">
|
|
<node CREATED="1542384871403" ID="ID_1092715541" MODIFIED="1557498707233" TEXT="nur ein Ausschnitt der Achse wird gerendert"/>
|
|
<node CREATED="1542384880497" ID="ID_82218999" MODIFIED="1557498707234" TEXT="stets mehr als der sichbare Bereich"/>
|
|
<node CREATED="1542385000986" ID="ID_1721448517" MODIFIED="1557498707234" TEXT="strategy change">
|
|
<node CREATED="1542385006024" ID="ID_58293224" MODIFIED="1557498707234" TEXT="breaking">
|
|
<node CREATED="1542385016529" ID="ID_697267034" MODIFIED="1557498707234" TEXT="Pixel-Koordinaten aller Elemente ändern sich"/>
|
|
<node CREATED="1542385445821" ID="ID_1078665627" MODIFIED="1557498707234" TEXT="außerdem kommen ggfs neue Elemente hinzu und Elemente fallen weg"/>
|
|
<node COLOR="#435e98" CREATED="1542385042987" ID="ID_1543492584" MODIFIED="1672671739825" TEXT="Push oder Pull?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1542385063860" ID="ID_1262945101" MODIFIED="1557498707234" TEXT="Abwägung">
|
|
<node CREATED="1542385081282" ID="ID_342384221" MODIFIED="1557498707234" TEXT="Push">
|
|
<node CREATED="1542385084334" ID="ID_194494898" MODIFIED="1557498707234" TEXT="Display-Manager muß alle Elemente kennen"/>
|
|
<node CREATED="1542385115962" ID="ID_984451994" MODIFIED="1557498707234" TEXT="Notification-Mechanismus"/>
|
|
</node>
|
|
<node CREATED="1542385122521" ID="ID_1454454135" MODIFIED="1557498707234" TEXT="Pull">
|
|
<node CREATED="1542385155517" ID="ID_609874542" MODIFIED="1557498707234" TEXT="Element muß erkennen können, ob es noch valide ist"/>
|
|
<node CREATED="1542385259471" ID="ID_513541561" MODIFIED="1557498707234" TEXT="Element muß sich seine Pixel-Koordinaten abholen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666740774742" ID="ID_363144624" MODIFIED="1666740786352" TEXT="durch konkrete Architektur bereits festgelegt">
|
|
<node CREATED="1666740792273" ID="ID_1830217394" MODIFIED="1666740804730" TEXT="Elemente sind an CanvasHook angeheftet"/>
|
|
<node CREATED="1666740808999" ID="ID_1283381454" MODIFIED="1666740820970" TEXT="Display-Manager soll keine Gott-Klasse werden"/>
|
|
<node CREATED="1666740839898" ID="ID_774727516" MODIFIED="1666740850468" TEXT="Gtk gibt Rolle der Widgets bereits vor"/>
|
|
<node CREATED="1666740853072" ID="ID_772665062" MODIFIED="1666740884257" TEXT="⟹ Pull">
|
|
<node CREATED="1666740887357" ID="ID_774450727" MODIFIED="1666740927995" TEXT="Elemente werden durch "invalidation" von GTK aktiviert"/>
|
|
<node CREATED="1666740953298" ID="ID_681117853" MODIFIED="1666740965269" TEXT="dies wiederum löst Display-Evaluation-Pass aus"/>
|
|
<node CREATED="1666740966473" ID="ID_1449245417" MODIFIED="1666740995521" TEXT="Timeline-Elements re-attach children"/>
|
|
<node CREATED="1666741015283" ID="ID_177537427" MODIFIED="1666741029602" TEXT="CanvasHooked übersetzt seine Position in Pixel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542385008235" ID="ID_713582235" MODIFIED="1557498707234" TEXT="non-breaking">
|
|
<node CREATED="1542385321347" ID="ID_1672263647" MODIFIED="1557498707234" TEXT="TimeWindow-»Canvas« wird erweitert"/>
|
|
<node CREATED="1542385335372" ID="ID_1139488626" MODIFIED="1557498707234" TEXT="aber Pixel-Nullpunkt bleibt gleich"/>
|
|
<node CREATED="1542385350195" ID="ID_1892916657" MODIFIED="1557498707234" TEXT="alle Pixel-Koordinaten bleiben gültig"/>
|
|
<node CREATED="1542385433191" ID="ID_823514825" MODIFIED="1557498707234" TEXT="es kommen ggfs neue Elemente hinzu">
|
|
<node CREATED="1666741069270" ID="ID_126323667" MODIFIED="1666741234366" TEXT="Gtk::Layout bietet keinen sinnvollen Mechanismus zum Entfernen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Entfernen eines Widget bewirkt lineare Suche im Container auf Pointer-Match ⟹ ineffizient
|
|
</li>
|
|
<li>
|
|
ohne aufwendige Index-Struktur haben wir keine Möglichkeit, alle Widgets in einem bestimmten Bereich zu finden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672695373913" ID="ID_601278848" MODIFIED="1672695382563" TEXT="»Canvas«">
|
|
<node CREATED="1672695388079" ID="ID_611481658" MODIFIED="1672695399833" TEXT="implizite Zeitchenfläche mit einheitlichen Koordinaten"/>
|
|
<node CREATED="1672695405293" ID="ID_1476246688" MODIFIED="1672695425045" TEXT="der sichtbare Ausschnitt ist irgendwo darin enthalten"/>
|
|
<node CREATED="1672695431696" ID="ID_1878306836" MODIFIED="1672695451577" TEXT="kann durch Zoom/Scroll-Aktionen implizit vergrößert werden"/>
|
|
<node CREATED="1672695458020" ID="ID_350857288" MODIFIED="1672695546890" TEXT="verwaltet einen Pixel-Ursprung">
|
|
<linktarget COLOR="#868ca5" DESTINATION="ID_350857288" ENDARROW="Default" ENDINCLINATION="1491;0;" ID="Arrow_ID_265889059" SOURCE="ID_785032228" STARTARROW="None" STARTINCLINATION="-1670;93;"/>
|
|
<node CREATED="1672695565677" ID="ID_74750688" MODIFIED="1672695578855" TEXT="dieser gilt ausnahmslos für alle Zeichen-Operationen"/>
|
|
<node CREATED="1672695580626" ID="ID_1609686459" MODIFIED="1672695694973" TEXT="Lage kann sich durch Änderungen im Zoom-Window verschieben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beispielsweise wenn nach links über den bisherigen Ursprung hinaus gescrollt wird — dann wird (in Maßen) der Canvas vergrößert; dies invalidiert alle Koordinaten und das gesamte Layout, und anschließend bekommen aber alle Widgets und Zeichen-Routinen konsistent eine neue Canvas-Übersetzung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1541859255448" ID="ID_1251550945" MODIFIED="1672672870505" TEXT="hat seine eigene Historie">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1672672872277" ID="ID_1511854867" MODIFIED="1672672879900" TEXT="geplant..."/>
|
|
<node CREATED="1672672880622" ID="ID_1994765001" MODIFIED="1672672913962" TEXT="wohl erst viel später zu implementieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gesamt-Integration der Applikation ist derzeit (2023) viel wichtiger
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1666961652530" ID="ID_1551608483" MODIFIED="1666961657079" TEXT="Anforderungen">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1666961922242" ID="ID_1841861801" MODIFIED="1666961924990" TEXT="Nutzer">
|
|
<node CREATED="1666961939961" ID="ID_1450461751" MODIFIED="1666964219794">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
CanvasHook /
|
|
</p>
|
|
<p>
|
|
DisplayMetric
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1666964107682" ID="ID_987173896" MODIFIED="1666964109614" TEXT="info">
|
|
<node CREATED="1666964110858" ID="ID_1532390725" MODIFIED="1666964112213" TEXT="pull">
|
|
<node CREATED="1666962009910" ID="ID_529672706" MODIFIED="1666962010867" TEXT="Pixel / sec"/>
|
|
<node CREATED="1666962011710" ID="ID_414340764" MODIFIED="1666963008416" TEXT="Time ⟼ Pixel">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_414340764" ENDARROW="Default" ENDINCLINATION="69;0;" ID="Arrow_ID_1434161517" SOURCE="ID_1881628552" STARTARROW="None" STARTINCLINATION="69;0;"/>
|
|
</node>
|
|
<node CREATED="1666962045507" ID="ID_1981297904" MODIFIED="1666964118381" TEXT="Pixel ⟼ Time-Offset"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666962948140" ID="ID_1637428541" MODIFIED="1666962951762" TEXT="BodyCanvas">
|
|
<node CREATED="1666962967612" ID="ID_449651932" MODIFIED="1666962970528" TEXT="info">
|
|
<node CREATED="1666962972110" ID="ID_394919753" MODIFIED="1666963848689" TEXT="pull">
|
|
<linktarget COLOR="#845fa8" DESTINATION="ID_394919753" ENDARROW="Default" ENDINCLINATION="-2;42;" ID="Arrow_ID_803019531" SOURCE="ID_647016441" STARTARROW="None" STARTINCLINATION="-87;9;"/>
|
|
<node CREATED="1666962983298" ID="ID_1421218984" MODIFIED="1666962989245" TEXT="window offset"/>
|
|
<node CREATED="1666962998128" ID="ID_1881628552" MODIFIED="1666963008416" TEXT="Time ⟼ Pixel">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_414340764" ENDARROW="Default" ENDINCLINATION="69;0;" ID="Arrow_ID_1434161517" STARTARROW="None" STARTINCLINATION="69;0;"/>
|
|
</node>
|
|
<node CREATED="1666963029028" ID="ID_1761637588" MODIFIED="1666963032537" TEXT="overall range"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666963161996" ID="ID_1959770633" MODIFIED="1666963165721" TEXT="TimelineLayout">
|
|
<node CREATED="1666963168179" ID="ID_1043980998" MODIFIED="1666963170055" TEXT="info">
|
|
<node CREATED="1666963053313" ID="ID_1467716107" MODIFIED="1666963055117" TEXT="push">
|
|
<node CREATED="1666963473113" ID="ID_1083610832" MODIFIED="1666963797516" TEXT="change to scale factor ⟶ zoom slider"/>
|
|
<node CREATED="1666963056273" ID="ID_93260719" MODIFIED="1666963073411" TEXT="any change to">
|
|
<node CREATED="1666963074711" ID="ID_509368190" MODIFIED="1666963076010" TEXT="visible window"/>
|
|
<node CREATED="1666963076796" ID="ID_246937524" MODIFIED="1666963108407" TEXT="scale factor"/>
|
|
<node CREATED="1666963936464" ID="ID_1932975512" MODIFIED="1666963939268" TEXT="overall range"/>
|
|
</node>
|
|
<node CREATED="1666963799466" ID="ID_647016441" LINK="#ID_1896159832" MODIFIED="1666963854969" TEXT="⟹ trigger DisplayEvaluation">
|
|
<arrowlink COLOR="#845fa8" DESTINATION="ID_394919753" ENDARROW="Default" ENDINCLINATION="-2;42;" ID="Arrow_ID_803019531" STARTARROW="None" STARTINCLINATION="-87;9;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666963111674" ID="ID_366938946" MODIFIED="1666963138899" TEXT="mutate">
|
|
<node CREATED="1666963244169" ID="ID_1844613988" MODIFIED="1666963246949" TEXT="in response to scrollbar">
|
|
<node CREATED="1666963183793" ID="ID_1981655411" MODIFIED="1666963250103" TEXT="nudge"/>
|
|
<node CREATED="1666963216853" ID="ID_508890288" MODIFIED="1666963255428" TEXT="move window"/>
|
|
</node>
|
|
<node CREATED="1666963419931" ID="ID_1583456327" MODIFIED="1666963425054" TEXT="in response to zoom slider">
|
|
<node CREATED="1666963439348" ID="ID_1075634262" MODIFIED="1666963471723" TEXT="change scale"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666963980515" ID="ID_513917153" MODIFIED="1666963984166" TEXT="TimelineController">
|
|
<node CREATED="1666964000088" ID="ID_375195151" MODIFIED="1666964003076" TEXT="mutate">
|
|
<node CREATED="1666964004207" ID="ID_1180711772" MODIFIED="1666964011435" TEXT="overall range"/>
|
|
<node CREATED="1666964012037" ID="ID_1236595109" MODIFIED="1666964022457" TEXT="window parameters (persistent UI state)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666964041691" ID="ID_190646112" MODIFIED="1666964239733">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p style="text-align: center">
|
|
Menu
|
|
</p>
|
|
<p style="text-align: center">
|
|
Actions
|
|
</p>
|
|
<p style="text-align: center">
|
|
SpotLocator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1666964045890" ID="ID_967504479" MODIFIED="1666964047758" TEXT="mutate">
|
|
<node CREATED="1666964049178" ID="ID_400278283" MODIFIED="1666964054021" TEXT="zoom factor explicit"/>
|
|
<node CREATED="1666964054817" ID="ID_13822198" MODIFIED="1666964062332" TEXT="zoom in / out"/>
|
|
<node CREATED="1666964136828" ID="ID_1945694373" MODIFIED="1666964147513" TEXT="Zoom history"/>
|
|
<node CREATED="1666964064097" ID="ID_476690066" MODIFIED="1666964065796" TEXT="goto"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666963512247" ID="ID_346536876" MODIFIED="1666964491444">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gestures
|
|
</p>
|
|
<p>
|
|
<font size="2">(Controller)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1666963587166" ID="ID_442423017" MODIFIED="1666963593121" TEXT="mutate">
|
|
<node CREATED="1666963695760" ID="ID_81275579" MODIFIED="1666963720097" TEXT="move window"/>
|
|
<node CREATED="1666963721304" ID="ID_454787677" MODIFIED="1666963725688" TEXT="set window new"/>
|
|
<node CREATED="1666963726700" ID="ID_1014020184" MODIFIED="1666963749165" TEXT="nudge / navigate scale"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666964525427" ID="ID_1415774511" MODIFIED="1666964532142" TEXT="Use-Cases">
|
|
<node CREATED="1666964535050" ID="ID_1763230201" MODIFIED="1666964538702" TEXT="initial setup">
|
|
<node CREATED="1666964596634" ID="ID_787404148" MODIFIED="1666964610730" TEXT="UI-state ➩ set metric"/>
|
|
<node CREATED="1666964550288" ID="ID_923399586" MODIFIED="1666964581818" TEXT="TimelineController ➩ set overall range"/>
|
|
<node CREATED="1666964631061" ID="ID_1738511451" MODIFIED="1666964652646" TEXT="BodyCanvas ⟵ window params"/>
|
|
<node CREATED="1666964657466" ID="ID_284701056" MODIFIED="1666964672146" TEXT="DisplayMetric ⟵ metric params"/>
|
|
</node>
|
|
<node CREATED="1666964685556" ID="ID_1149861099" MODIFIED="1666964696392" TEXT="reposition">
|
|
<node CREATED="1666964704346" ID="ID_1335047774" MODIFIED="1666964706053" TEXT="actors">
|
|
<node CREATED="1666964713328" ID="ID_547389237" MODIFIED="1666964722173" TEXT="TimelineLayout ⟵ scrollbar"/>
|
|
<node CREATED="1666964723703" ID="ID_369768444" MODIFIED="1666964730506" TEXT="TimelineLayout ⟵ zoom slider"/>
|
|
<node CREATED="1666964759337" ID="ID_1195706073" MODIFIED="1666964769244" TEXT="Menu/Locator ⟵ intentional settings"/>
|
|
<node CREATED="1666964789807" ID="ID_1584775566" MODIFIED="1666964800070" TEXT="Gestures ⟵ move"/>
|
|
<node CREATED="1666964800731" ID="ID_842054315" MODIFIED="1666964813053" TEXT="Gestures ⟵ select"/>
|
|
<node CREATED="1666964813737" ID="ID_251122612" MODIFIED="1666964819044" TEXT="Gestures ⟵ nudge"/>
|
|
</node>
|
|
<node CREATED="1666964837550" ID="ID_1317851498" MODIFIED="1666964853954" TEXT="push ⟶ TimelineLayout"/>
|
|
<node CREATED="1666964631061" ID="ID_471374188" MODIFIED="1666964652646" TEXT="BodyCanvas ⟵ window params"/>
|
|
<node CREATED="1666964657466" ID="ID_640554342" MODIFIED="1666964672146" TEXT="DisplayMetric ⟵ metric params"/>
|
|
</node>
|
|
<node CREATED="1666964906595" ID="ID_414880469" MODIFIED="1666964913822" TEXT="model/Content">
|
|
<node CREATED="1666964550288" ID="ID_207665547" MODIFIED="1666964581818" TEXT="TimelineController ➩ set overall range"/>
|
|
<node CREATED="1666964837550" ID="ID_510736258" MODIFIED="1672673922037" TEXT="push ⟶ TimelineLayout(⟹Display-Evaluation)"/>
|
|
<node CREATED="1666964631061" ID="ID_1856222450" MODIFIED="1666964652646" TEXT="BodyCanvas ⟵ window params"/>
|
|
<node CREATED="1666964657466" ID="ID_1703226781" MODIFIED="1666964672146" TEXT="DisplayMetric ⟵ metric params"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666965004641" ID="ID_748757781" MODIFIED="1666965813264" TEXT="Interaction Procedure">
|
|
<linktarget COLOR="#955977" DESTINATION="ID_748757781" ENDARROW="Default" ENDINCLINATION="-318;688;" ID="Arrow_ID_1882192055" SOURCE="ID_867107887" STARTARROW="None" STARTINCLINATION="-49;-276;"/>
|
|
<node CREATED="1666965028506" ID="ID_1718237033" MODIFIED="1666965700555" TEXT="mutators">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1666965070532" ID="ID_466715389" MODIFIED="1666965073074" TEXT="set metric"/>
|
|
<node CREATED="1666965122916" ID="ID_1552912945" MODIFIED="1666965127135" TEXT="nudge metric"/>
|
|
<node CREATED="1666965076899" ID="ID_1566749815" MODIFIED="1666965082213" TEXT="set overall range"/>
|
|
<node CREATED="1666965248114" ID="ID_1129946807" MODIFIED="1666965252637" TEXT="set position visible"/>
|
|
<node CREATED="1666965253777" ID="ID_170374754" MODIFIED="1666965260590" TEXT="offset position"/>
|
|
<node CREATED="1666965363498" ID="ID_122767081" MODIFIED="1666965371954" TEXT="nudge position"/>
|
|
<node CREATED="1666965443495" ID="ID_963746010" MODIFIED="1666965450746" TEXT="select/set window"/>
|
|
<node CREATED="1666965624006" ID="ID_1012108139" MODIFIED="1666965628305" TEXT="nav History"/>
|
|
</node>
|
|
<node CREATED="1666965815796" ID="ID_923514380" MODIFIED="1666965835315" TEXT="coordinated adjustment">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1666965640435" ID="ID_1286173115" MODIFIED="1666965838899" TEXT="any change ⟹ trigger TimelineLayout ⟶ DisplayEvaluation">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1666965707418" ID="ID_934685858" MODIFIED="1666965842700" TEXT="read state">
|
|
<icon BUILTIN="full-4"/>
|
|
<node CREATED="1666965729794" ID="ID_745785368" MODIFIED="1666965732035" TEXT="metric"/>
|
|
<node CREATED="1666965732767" ID="ID_193127162" MODIFIED="1666965737818" TEXT="translations"/>
|
|
<node CREATED="1666965745869" ID="ID_1594628227" MODIFIED="1666965748929" TEXT="window offset"/>
|
|
<node CREATED="1666965749637" ID="ID_1024412644" MODIFIED="1666965752128" TEXT="overall range"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667253467195" ID="ID_583983335" MODIFIED="1667253470876" TEXT="Semantics">
|
|
<node CREATED="1667254016236" ID="ID_1599338404" MODIFIED="1667260350202" TEXT="zwei mögliche Auslegungen">
|
|
<linktarget COLOR="#5cbca7" DESTINATION="ID_1599338404" ENDARROW="Default" ENDINCLINATION="-266;683;" ID="Arrow_ID_1992699101" SOURCE="ID_1789035337" STARTARROW="None" STARTINCLINATION="-195;-13;"/>
|
|
<node CREATED="1667254281663" ID="ID_931025074" MODIFIED="1667254961650" TEXT="overallSpan ≙ Timeline">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1667254042344" ID="ID_1886040600" MODIFIED="1667254193233" TEXT="visualWindow ≙ was sichtbar ist"/>
|
|
<node CREATED="1667254330394" ID="ID_192603163" MODIFIED="1667254344380" TEXT="⟹ visualWindow kann darüber hinausreichen"/>
|
|
<node CREATED="1667254349351" ID="ID_1260830853" MODIFIED="1667254356411" TEXT="Canvas ergibt sich implizit"/>
|
|
</node>
|
|
<node CREATED="1667253493640" ID="ID_29660572" MODIFIED="1667254964809" TEXT="overallSpan ≙ Canvas">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1667254042344" ID="ID_6801078" MODIFIED="1667254193233" TEXT="visualWindow ≙ was sichtbar ist"/>
|
|
<node CREATED="1667254132888" ID="ID_907807797" MODIFIED="1667254189985" TEXT="⟹ visualWindow ∈ Canvas"/>
|
|
<node CREATED="1667254209434" ID="ID_1299162840" MODIFIED="1667254216213" TEXT="stößt am Rand des Canvas an"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667254983055" FOLDED="true" ID="ID_1939856323" MODIFIED="1668176401891" TEXT="Eichung der Metrik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667254988850" ID="ID_627529918" MODIFIED="1667255165088" TEXT="muß (initial) explizit gesezt werden">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1667255003826" ID="ID_457439715" MODIFIED="1667255160405" TEXT="soll der Ausdehnung im Interface entsprechen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667255062416" ID="ID_888315158" MODIFIED="1668176391632" TEXT="Erwartung: erhält sich von selbst numerisch konstant">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667255198638" ID="ID_1458374199" MODIFIED="1667255216695" TEXT="da wir Integer-Arithmetik machen"/>
|
|
<node CREATED="1667255218491" ID="ID_1646057612" MODIFIED="1667255227637" TEXT="und stets logisch-konsistent vorgehen"/>
|
|
</node>
|
|
<node CREATED="1667255234369" ID="ID_713280456" MODIFIED="1667255281215" TEXT="falls das nicht klappt....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dann müssen wir die Vorgabe speichern, und in jedem Schritt korrigierend eingreifen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1668176223375" ID="ID_386415995" MODIFIED="1668176380384" TEXT="...habe es gar nicht darauf ankommen lassen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1668176234367" ID="ID_762072729" MODIFIED="1668176354941" TEXT="...sondern an allen potentiell gefährlichen Rechenschritten explizit auf Wert-Erhalt abgestellt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
alten Pixel-Wert berechnet
|
|
</li>
|
|
<li>
|
|
Neue Metrik draus per fractional-Integer-Arithmetik errechnet
|
|
</li>
|
|
<li>
|
|
Assertion daß sich daraus wieder die gleiche Pixel-Zahl ergibt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668176355944" ID="ID_421203855" MODIFIED="1668176376274" TEXT="Pixel-Wert selber muß nicht persistent gespeichert werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668176368364" ID="ID_1536037495" MODIFIED="1668176373232" TEXT="im Test bestätigt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541860963705" ID="ID_13414263" MODIFIED="1557498707234" TEXT="Design">
|
|
<node CREATED="1541860967281" ID="ID_1676646773" MODIFIED="1557498707234" TEXT="manipulativ - mutable">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1541860985526" ID="ID_640984391" MODIFIED="1666965921616" TEXT="Klasse mit...">
|
|
<node CREATED="1666965922557" ID="ID_1117003417" MODIFIED="1666965925216" TEXT="mutatoren"/>
|
|
<node CREATED="1666965925828" ID="ID_1319511593" MODIFIED="1666965930200" TEXT="internem State"/>
|
|
<node CREATED="1666965930804" ID="ID_821140216" MODIFIED="1666965935583" TEXT="Listener-Registrierung"/>
|
|
</node>
|
|
<node CREATED="1541861314456" ID="ID_267107783" MODIFIED="1666965892587" TEXT="generisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Liegt in unserem gui::model
|
|
</p>
|
|
<p>
|
|
analog zu gui::model::Tangible
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1666965873443" ID="ID_689086000" MODIFIED="1666965875623" TEXT="nix GTK"/>
|
|
<node CREATED="1666965876091" ID="ID_60793784" MODIFIED="1666965880156" TEXT="allgemeiner als Timeline"/>
|
|
</node>
|
|
<node CREATED="1541861061984" HGAP="23" ID="ID_426757987" MODIFIED="1557498707234" TEXT="Anwendung" VSHIFT="10">
|
|
<node CREATED="1666965986884" ID="ID_1348737219" MODIFIED="1666966001747" TEXT="dedizierte zweickgebundene Setter"/>
|
|
<node CREATED="1541861069577" ID="ID_1233713010" MODIFIED="1666965974618" TEXT="wird stets insgesamt harmonisiert"/>
|
|
<node CREATED="1541861281854" ID="ID_1332627357" MODIFIED="1666966014212" TEXT="Notification vom LayoutManager auf Widgets übersetzt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666741319202" ID="ID_64525813" MODIFIED="1666741321886" TEXT="Einbindung">
|
|
<node COLOR="#435e98" CREATED="1666741323047" ID="ID_1994767675" MODIFIED="1666912635580" TEXT="wer "hat" ein ZoomWindow?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666741476982" ID="ID_325619597" MODIFIED="1666824575081" TEXT="jeweils für eine View gibt's ein ZoomWindow"/>
|
|
<node CREATED="1666741455465" ID="ID_1574485076" MODIFIED="1666741469596" TEXT="derjenige, der eine Navigation und Zoom-Steuerung realisiert"/>
|
|
<node CREATED="1666824594960" ID="ID_1905497481" MODIFIED="1666824608874" TEXT="wer ist das?">
|
|
<node CREATED="1666741481789" ID="ID_1047670368" MODIFIED="1666741501886" TEXT="⟹ für Timeline ist das der Timeline-Controller"/>
|
|
<node CREATED="1666824619509" ID="ID_1980185134" MODIFIED="1666824682980" TEXT="⟹ oder das TimelineLayout, das die Widgets kontrolliert"/>
|
|
</node>
|
|
<node CREATED="1666824690348" ID="ID_1087315879" MODIFIED="1666824695311" TEXT="Entscheidung">
|
|
<node CREATED="1666824696443" ID="ID_460181440" MODIFIED="1666824874757" TEXT="den jeweils anderen muß man stets verdrahten, also letztlich wählbar">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1666824722392" ID="ID_386126354" MODIFIED="1666824862873" TEXT="Unterbringung direkt im TimelineLayout würde direkte Zugriffe ermöglichen">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1666824794990" ID="ID_1978333313" MODIFIED="1666824860086" TEXT="das ZoomWindow könnte dann direkt in einem Metric-Mix-in untergebracht werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666912636672" ID="ID_693136797" MODIFIED="1666966124725" TEXT="wie kann man ZoomWindow nutzen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666912660076" ID="ID_1930000724" MODIFIED="1666912681102" TEXT="dynamische Änderungen vornehmen"/>
|
|
<node CREATED="1666912682282" ID="ID_1683687274" MODIFIED="1666966070412" TEXT="Änderungs-Benachrichtigung (Listener)">
|
|
<node CREATED="1668176481848" ID="ID_1029152707" MODIFIED="1668176485296" TEXT="einfacher Trigger"/>
|
|
<node CREATED="1668176485655" ID="ID_1241434698" MODIFIED="1668176499366" TEXT="Empfänger zieht sich selber die aktuellen Werte"/>
|
|
<node CREATED="1668176501266" ID="ID_1187154193" MODIFIED="1668176520856" TEXT="vorerst nur ein Empfänger (=TimelineLayout)"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666913019821" ID="ID_1177711704" MODIFIED="1666966123770" TEXT="Art der Anbindung?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1666913118791" ID="ID_228116720" MODIFIED="1666913124339" TEXT="per Referenz erreichbar"/>
|
|
<node CREATED="1666913124995" ID="ID_1928528678" MODIFIED="1666913131873" TEXT="man kann Wert manipulieren"/>
|
|
<node CREATED="1666913138933" ID="ID_784393870" MODIFIED="1666966103824" TEXT="man kann Kenn-Parameter lesen"/>
|
|
<node CREATED="1666966104484" ID="ID_1051593434" MODIFIED="1666966112377" TEXT="man kann Listener registrieren"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666913178575" ID="ID_391252153" MODIFIED="1666913185255" TEXT="Implementierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1666913226225" ID="ID_1795877085" MODIFIED="1666913232673" TEXT="1196 draft zoom handling in the Timeline">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666913246670" ID="ID_818523431" MODIFIED="1666913251598" TEXT="1214 ZoomWindow">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1666913256394" ID="ID_562681542" MODIFIED="1666913269396" TEXT="erster Entwurf 10/2022">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#690f14" CREATED="1666913293560" FOLDED="true" ID="ID_1249096607" MODIFIED="1666966326093" TEXT="das time::Control verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1666913316709" ID="ID_134581234" MODIFIED="1666913343061" TEXT="Kenn-Parameter wären damit zwei TimeSpan"/>
|
|
<node CREATED="1666913354384" ID="ID_1823681184" MODIFIED="1666913364242" TEXT="die API-Methoden bauen direkt darauf auf"/>
|
|
<node CREATED="1666966147486" ID="ID_45964930" MODIFIED="1666966157681" TEXT="würde sich selbst als Listener registrieren"/>
|
|
<node CREATED="1666966161556" ID="ID_327156044" MODIFIED="1666966331839" TEXT="Probleme">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1666966164548" ID="ID_1667782386" MODIFIED="1666966185522" TEXT="nicht alle Parameter sind Zeiten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber time::Control ist nur auf Zeiten ausgelegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666966186762" ID="ID_1824326405" MODIFIED="1666966230396" TEXT="Nutzer wollen oft speziellere Dinge tun">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
müßten also dann jeweils selber dies in die Kenn-Parameter übersetzen ⟹ Gefahr von Code-Duplikation und inkonsistentem Verhalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666966240650" ID="ID_248937535" MODIFIED="1666966303328" TEXT="es gäbe mehrfach-Benachrichtigung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn aufgrund der ersten (ggfs sogar <b>falschen</b> Benachrichtigung) würde das ZoomWindow selber die Parameter glattziehen, was erneute Benachrichtigung zur Folge hätte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666966304273" ID="ID_1096389407" MODIFIED="1666966312732" TEXT="API-Nutzung insgesamt nicht selbsterklärend"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1666913370781" ID="ID_1691713188" MODIFIED="1667787385844" TEXT="klassisches Klassen-Design">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1666913375117" ID="ID_1377108042" MODIFIED="1667158257168" TEXT="ZoomWindow ist unkopierbare Klasse mit internem State"/>
|
|
<node CREATED="1666913471725" ID="ID_1373767277" MODIFIED="1666966473259" TEXT="Master-Setter führen die Range-Chacks durch"/>
|
|
<node CREATED="1666966477745" ID="ID_1255941758" MODIFIED="1666966489636" TEXT="sekundäre / convenience-Setter bieten"/>
|
|
<node CREATED="1666966493207" ID="ID_872298278" MODIFIED="1666966503634" TEXT="interner State in 4 TimeVar"/>
|
|
<node CREATED="1666966543009" ID="ID_1212064261" MODIFIED="1666966550739" TEXT="vorerst nur einen Listener vorsehen">
|
|
<node CREATED="1666966571021" ID="ID_166595354" MODIFIED="1666966588771" TEXT="derzeit muß nur TimelineLayout benachrichtigt werden"/>
|
|
<node CREATED="1666966555495" ID="ID_1498916070" MODIFIED="1666966567113" TEXT="Overflow wenn später mehr dazukommen"/>
|
|
</node>
|
|
<node CREATED="1666966629661" ID="ID_341880226" MODIFIED="1666966661849">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
getter liefern Time-<b>Values</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1671324422426" ID="ID_1192793970" MODIFIED="1671324572988">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zoom-Metrik verwendet <b>integer-Brüche</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#435e98" CREATED="1671324446051" ID="ID_1112836860" MODIFIED="1671324565631" TEXT="kann damit auch unebene Teilungen der Zeitskala sauber handhaben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671324465573" ID="ID_186471302" MODIFIED="1671324563688" TEXT="erfordert Sicherheitsmaßnahmen für sehr große Zahlen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1671324522229" ID="ID_1590349109" MODIFIED="1671324559550" TEXT="Gefahr von numeric-wrap">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671324535163" ID="ID_298282383" MODIFIED="1671324555746" TEXT="Lösung: re-Quantisierung (minimalen Fehler einführen)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1666966669487" FOLDED="true" ID="ID_1477573565" MODIFIED="1671324271010" TEXT="testgetrieben entwickelt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667093097050" ID="ID_1662709264" MODIFIED="1667093103756" TEXT="verify_simpleUsage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667093106907" ID="ID_1255657275" MODIFIED="1667093118644" TEXT="nudge Zoom-Faktor"/>
|
|
<node CREATED="1667093120846" ID="ID_1405458968" MODIFIED="1667093134771" TEXT="⟹ doppelte Auflösung"/>
|
|
<node CREATED="1667093136007" ID="ID_1309995367" MODIFIED="1667093153233" TEXT="⟹ visible Window liegt in der Mitte und hat hable Länge"/>
|
|
<node CREATED="1667163315776" ID="ID_1054488196" MODIFIED="1667163336658" TEXT="nudge Position ⟵"/>
|
|
<node CREATED="1667093136007" ID="ID_1861991162" MODIFIED="1667163359264" TEXT="⟹ visible Window liegt nun genau am Anfang"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667155790783" ID="ID_1921165636" MODIFIED="1667155805398" TEXT="Frage: Basis für Rechnungen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1667155806980" ID="ID_250578278" MODIFIED="1667156041888">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>FSecs</b> ≙ <font face="Monospaced">boost::rational<int64_t></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667156043109" ID="ID_234377752" MODIFIED="1667156067733" TEXT="ist sogar noch präziser als µs — und exakt"/>
|
|
<node COLOR="#338800" CREATED="1667156072512" FOLDED="true" ID="ID_951906064" MODIFIED="1667787375816" TEXT="TimeVar für Konversionen "aufbohren"">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1667156098084" ID="ID_1341404738" MODIFIED="1667156104554" TEXT="potentiell gefährlich">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667156192072" ID="ID_957228038" MODIFIED="1667156232815" TEXT="es gibt implizit int64_t ⟶ rational">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1667156246932" ID="ID_306732730" MODIFIED="1667156379883" TEXT="int64_t kann aus TimeVar "entkommen" und in FSecs "reingeraten"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Resultat</u>:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
man hat einen Faktor 1e+6 im Ergebnis
|
|
</li>
|
|
<li>
|
|
ist mir tatsächlich passiert, und zwar ziemlich überraschend
|
|
</li>
|
|
<li>
|
|
Abhilfe: FSecs-ctor explizit anschreiben
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667156105827" ID="ID_142853354" MODIFIED="1667156141584" TEXT="durch explicit-conversions schützen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1667156117746" ID="ID_748178975" MODIFIED="1667156124357" TEXT="geht nicht wie gewünscht"/>
|
|
<node CREATED="1667156125589" ID="ID_1640624377" MODIFIED="1667156139947" TEXT="weil wir nicht über den FSecs-ctor verfügen"/>
|
|
<node CREATED="1667156145590" ID="ID_1139847097" MODIFIED="1667156168191" TEXT="und explicit-conversion-operator ⟹ static_cast"/>
|
|
<node CREATED="1667156173714" ID="ID_1596347322" MODIFIED="1667156188388" TEXT="das würde der fluiden Verwendung schaden"/>
|
|
<node CREATED="1667156513645" ID="ID_1002330972" MODIFIED="1667156696839" TEXT="mäßig gefährlich, solange TimeVar ehr selten und lokal begrenzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und so ist es auch gedacht: TimeVar sollte nicht auf APIs auftauchen!
|
|
</p>
|
|
<p>
|
|
Wenn man sich daran hält, tritt TimeVar immer nur in einem lokalen Universum auf, wie hier im ZoomWindow, und man weiß genau, wo und warum man dem eine <i>reine Zahl </i>zuweist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#ec2dc2" DESTINATION="ID_1002330972" ENDARROW="Default" ENDINCLINATION="-1;56;" ID="Arrow_ID_116751884" SOURCE="ID_907527366" STARTARROW="None" STARTINCLINATION="65;4;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#d132ba" CREATED="1667156391029" ID="ID_907527366" MODIFIED="1667156702025" TEXT="nicht glücklich — aber geht wohl nicht besser">
|
|
<arrowlink COLOR="#ec2dc2" DESTINATION="ID_1002330972" ENDARROW="Default" ENDINCLINATION="-1;56;" ID="Arrow_ID_116751884" STARTARROW="None" STARTINCLINATION="65;4;"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260101665" FOLDED="true" ID="ID_1250580560" MODIFIED="1668132037114" TEXT="muß die Ausdehnung in Pixel beachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667260119686" ID="ID_1154266769" MODIFIED="1667780434377" TEXT="neuer Getter dafür">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667260284128" ID="ID_1789035337" MODIFIED="1667260350202" TEXT="Frage nach der Semantik?">
|
|
<arrowlink COLOR="#5cbca7" DESTINATION="ID_1599338404" ENDARROW="Default" ENDINCLINATION="-266;683;" ID="Arrow_ID_1992699101" STARTARROW="None" STARTINCLINATION="-195;-13;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260130116" ID="ID_299421938" MODIFIED="1668132034834" TEXT="sollte stets konstant bleiben ⟹ im Test beobachten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667349674019" FOLDED="true" ID="ID_723979887" MODIFIED="1667780424969" TEXT="Problem: Rechnung geht nicht auf">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1667349751008" ID="ID_952333352" MODIFIED="1667349762431" TEXT="runde auf nächsten Pixel">
|
|
<node CREATED="1667349764204" ID="ID_1815738825" MODIFIED="1667349818467" TEXT="Konsequenz ⟹ visible Window anpassen"/>
|
|
<node CREATED="1667349788035" ID="ID_281010107" MODIFIED="1667349803183" TEXT="Problem: Window kann größer werden als Canvas">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1667349853811" ID="ID_1951953580" MODIFIED="1667350032602" TEXT="Canvas vergrößern? oder visible Window verkleinern?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Canvas vergrößern ⟹ führt zu kontinuierliecher Drift; der Canvas wird fortlaufend größer
|
|
</li>
|
|
<li>
|
|
Window verkleinern ⟹ heißt daß man u.U den ganzen Canvas nicht ohne Rest darstellen kann
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667350040338" ID="ID_1862995353" MODIFIED="1667350064695" TEXT="eigentliches Problem: diese Effekte sind relativ stark">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667349713685" ID="ID_47270921" MODIFIED="1667780377917" TEXT="Metrik-Definition ist zu grobgranular">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667350180367" ID="ID_494068879" MODIFIED="1667350205920" TEXT="Sekunden sind eine ziemlich beliebige Basiseinheit"/>
|
|
<node COLOR="#990033" CREATED="1667350206652" ID="ID_918270163" MODIFIED="1667528235333" TEXT="stattdessen: µ-Tick pro Pixel?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1667350440373" ID="ID_1896628944" MODIFIED="1667350460022" TEXT="Vorsicht... Minimum wäre dann 1µT/px"/>
|
|
<node CREATED="1667350475136" ID="ID_1672716361" MODIFIED="1667350817413" TEXT="⟹ Sound-Samples lassen sich nicht sauber darstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle 20 Schritte ein Sprung, bzw. sogar nur alle 10 Schritte bei 96kHz, denn 1/96000 = 10.41666666 µTick
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667350536992" ID="ID_1838246834" MODIFIED="1667476855366" TEXT="das stellt die Implementierungs-Basis in Frage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die µ-Ticks hatten wir seinerzeit gewählt, weil sie einerseits hinreichend genau sind, andererseits sehr einfach zu implementieren, und dennoch die Darstellung extrem großer Zeitspannen ermöglichen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#af1a4c" DESTINATION="ID_767502481" ENDARROW="Default" ENDINCLINATION="96;-430;" ID="Arrow_ID_1672039685" STARTARROW="None" STARTINCLINATION="-670;38;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667487735017" ID="ID_67642064" MODIFIED="1667487922535" TEXT="schwerwiegende Diskusison auf später verschoben (#1258)">
|
|
<linktarget COLOR="#415eb7" DESTINATION="ID_67642064" ENDARROW="Default" ENDINCLINATION="-134;58;" ID="Arrow_ID_720683002" SOURCE="ID_745987096" STARTARROW="None" STARTINCLINATION="296;-90;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1667487765399" ID="ID_1902275269" MODIFIED="1667487918703" TEXT="denn das Problem tritt nur stellenweise auf und ist halb-theoretisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Tatsächlich kann ein µTick-Grid auch Sound-Samples korrekt addressieren — man darf dann nur nicht diese Zeit-Werte für weitere Berechnungen verwenden (denn sonst sammeln sich Rundungsfehler an). Es könnte also eine Implementierung eben <i>wissen, </i>daß hier Sound-Samples dargestellt/verarbeitet werden, und intern mit der exakten Skala arbeiten. Im Grunde ist das ein Lösungsvorgriff auf die 3.Lösungsvariante (Problem ignorieren und per Metadaten tunneln)... siehe Diskussion in #1258
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667487705856" ID="ID_1110286196" MODIFIED="1667780271388" TEXT="fraktionale µ-Tick pro Pixel">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1667487984471" ID="ID_1826402546" MODIFIED="1667487992109" TEXT="intern also eine Bruchzahl speichern"/>
|
|
<node CREATED="1667487993113" ID="ID_452961268" MODIFIED="1667488005420" TEXT="Zahlen wären auch numerisch viel gutmütiger"/>
|
|
<node CREATED="1667488026717" ID="ID_267648014" MODIFIED="1667488073400" TEXT="man könnte dennoch den grobgranularen Getter bestehen lassen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1667488090679" ID="ID_829965437" MODIFIED="1667488105799" TEXT="Gefahr: die Werte sind nur nahezu exakt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1667488074367" ID="ID_710829210" MODIFIED="1667488114221" TEXT="Nein! das verlockt gradezu zu falscher Verwendung">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1667489964330" ID="ID_15160345" MODIFIED="1667491231003" TEXT="wenn schon: dann muß er einen Bruch liefern">
|
|
<arrowlink COLOR="#685b9d" DESTINATION="ID_1961281272" ENDARROW="Default" ENDINCLINATION="48;-77;" ID="Arrow_ID_1581272535" STARTARROW="None" STARTINCLINATION="-422;27;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667491005864" ID="ID_822261439" MODIFIED="1667780365646" TEXT="Metrik als Bruch behaldeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667491014630" ID="ID_1961281272" MODIFIED="1667491231004" TEXT="bleibe aber beim Schema px_per_sec">
|
|
<linktarget COLOR="#685b9d" DESTINATION="ID_1961281272" ENDARROW="Default" ENDINCLINATION="48;-77;" ID="Arrow_ID_1581272535" SOURCE="ID_15160345" STARTARROW="None" STARTINCLINATION="-422;27;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1667491099595" ID="ID_1763425828" MODIFIED="1667491114813" TEXT="konkret erwarte ich da handliche Werte"/>
|
|
<node CREATED="1667491115829" ID="ID_650357166" MODIFIED="1667491143008" TEXT="µ-Ticks sind immer ziemlich große Zahlen"/>
|
|
<node CREATED="1667491149381" ID="ID_1912148103" MODIFIED="1667491191987" TEXT="besser: Kurz-Notation einführen (user-defined-literal)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667592413859" ID="ID_745987096" LINK="#ID_1398816169" MODIFIED="1667780421126" TEXT="brauche dazu einen offiziellen Zugang zu einer fraktionalen Repräsentation">
|
|
<arrowlink COLOR="#415eb7" DESTINATION="ID_67642064" ENDARROW="Default" ENDINCLINATION="-134;58;" ID="Arrow_ID_720683002" STARTARROW="None" STARTINCLINATION="296;-90;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1667592510702" ID="ID_669892678" MODIFIED="1667592532079" TEXT="Duration ⟶ FSec"/>
|
|
<node CREATED="1667592539018" ID="ID_1283310585" MODIFIED="1667592544568" TEXT="Offset ⟶ FSec"/>
|
|
<node CREATED="1667592532973" ID="ID_31952265" MODIFIED="1667592538214" TEXT="Time ⟶ FSec"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667593654463" ID="ID_1694088540" MODIFIED="1667593677324" TEXT="vorläufige Zwischenlösung: _FSecs() direkt in ZoomWindow-Header">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1667488158059" ID="ID_898168096" MODIFIED="1667491200716" TEXT="neue Zielvorgabe: Pixel-Angaben sind stets präzise">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1667593710047" ID="ID_920638973" MODIFIED="1667780371436" TEXT="kein Runden mehr, sondern nur noch truncate">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667593719313" ID="ID_317494909" MODIFIED="1667780372742" TEXT="dafür die Toleranz senken auf der Metrik">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667517436741" ID="ID_1018648571" MODIFIED="1667780388626" TEXT="Bruch-Notation einführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667517450483" ID="ID_854101466" MODIFIED="1667517461957" TEXT="Rat = boost::rational<int64_t>"/>
|
|
<node CREATED="1667517463369" ID="ID_1946096292" MODIFIED="1667517490241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
user-defined Literal: <font face="Monospaced" color="#5618bd">_r</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667603662334" ID="ID_162164091" MODIFIED="1667780457450" TEXT="drehe mich mit den geforderten Randbedingungen im Kreis">
|
|
<arrowlink COLOR="#5c3488" DESTINATION="ID_1507636517" ENDARROW="Default" ENDINCLINATION="27;-47;" ID="Arrow_ID_49426086" STARTARROW="None" STARTINCLINATION="-122;6;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667603756089" ID="ID_1802881683" MODIFIED="1667603844726" TEXT="möchte einen maximal-Zoom-Faktor vorgeben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667603784445" ID="ID_1006588421" MODIFIED="1667603844726" TEXT="Fenster soll immer im Canvas bleiben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667603813378" ID="ID_1979403390" MODIFIED="1667603844727" TEXT="Pixel-Vorgaben stets einzuhalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667603646312" FOLDED="true" ID="ID_1507636517" MODIFIED="1671237057680" TEXT="muß Invarianten sicherstellen">
|
|
<linktarget COLOR="#5c3488" DESTINATION="ID_1507636517" ENDARROW="Default" ENDINCLINATION="27;-47;" ID="Arrow_ID_49426086" SOURCE="ID_162164091" STARTARROW="None" STARTINCLINATION="-122;6;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#6a1790" CREATED="1667603900358" FOLDED="true" ID="ID_353785530" MODIFIED="1667780480867" TEXT="das zunächt (naiv) gewählte Implementierungs-Schema ist nicht beherrschbar">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1667603974758" ID="ID_1895105732" MODIFIED="1667603997149" TEXT="Konstuktor legt sichere Startwerte fest"/>
|
|
<node CREATED="1667603997785" ID="ID_1559828104" MODIFIED="1667604014827" TEXT="von dort weiter, mit Einzelfall-bezogenen Regeln"/>
|
|
</node>
|
|
<node CREATED="1667604115641" ID="ID_340228791" MODIFIED="1667604155428">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mein Anspruch ist, hier eine <b>absolut fehlerfrei</b> arbeitende Komponente zu schreiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1667604025125" ID="ID_573471794" MODIFIED="1667604225117" TEXT="die Korrektur-Regeln zum Einhalten der Constraints sind komplex (im Allgemeinen)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar, wenn man <i>wirklich alle</i> Eingangswerte zuläßt, und sich eben nicht nur auf <i>vernünftige </i>Eingaben <i>verläßt.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667604082603" ID="ID_1966401065" MODIFIED="1667604109981" TEXT="ich muß letztlich Vergößerung des Canvas zulassen (oder beliebig starken Zoom)">
|
|
<node CREATED="1667604258315" ID="ID_539837281" MODIFIED="1667604273064" TEXT="Canvas-Vergrößerung erscheint mir pragmatischer"/>
|
|
<node CREATED="1667604319406" ID="ID_169844915" MODIFIED="1667604346784" TEXT="ich möchte den Zoom-Faktor auf eine technisch realisierbare Spanne beschränken"/>
|
|
<node CREATED="1667604407474" ID="ID_1964908869" MODIFIED="1667609918926" TEXT="diese Spanne kann in der logarithmischen Skala vergleichsweise rasch durchschritten werden.">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
so ±15 2er-Potenz-Schritte genügen, um von der maximalen Auflösung in den Minuten-Bereich zu kommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667610042409" ID="ID_1645790878" MODIFIED="1667610212422" TEXT="es kann nicht die Aufgabe des ZoomWindow sein, sinnvolle Speicher-Limits einzuhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insofern muß es dann aber auch mit maximal großen Integer-Zahlen noch sauber funktionieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667610216018" ID="ID_399148751" MODIFIED="1667610253025" TEXT="insofern ist das hier auch eine sportliche Herausforderung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...einmal wirklich sicheren Code schreiben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667610259517" ID="ID_738196107" MODIFIED="1667610281605" TEXT="andere Code-Struktur als Lösung?">
|
|
<node CREATED="1667610283233" ID="ID_1965026515" MODIFIED="1667610294374" TEXT="Konstruktur initialisiert nur"/>
|
|
<node CREATED="1667610295059" ID="ID_15303386" MODIFIED="1667610302622" TEXT="es gibt eine Invarianten-Funktion"/>
|
|
<node CREATED="1667610303406" ID="ID_268951847" MODIFIED="1667610331180" TEXT="diese führt eine feste Folge von Prüf- und Korrekturschritten aus"/>
|
|
<node CREATED="1667610416991" ID="ID_1022295277" MODIFIED="1667610430339" TEXT="und die gleiche Funktion wird nach jeder Änderung gleichermaßen angewendet"/>
|
|
</node>
|
|
<node CREATED="1667610443917" ID="ID_156996069" MODIFIED="1667610464053" TEXT="Invariante(n)">
|
|
<node CREATED="1667610465437" ID="ID_1890704401" MODIFIED="1667660026181" TEXT="pxWidth konstant erhalten">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1667610496460" ID="ID_1598935964" MODIFIED="1667660029149" TEXT="Metrik < Maximal-Faktor">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1667610522737" ID="ID_870501024" MODIFIED="1667660034107" TEXT="visibleWindow ⊂ Canvas">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667610617421" ID="ID_1255567216" MODIFIED="1667780589952" TEXT="Ausgleichs-Regeln">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1667610965654" ID="ID_1822123568" MODIFIED="1667667095016" TEXT="Canvas und Fenster orientieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667667099807" ID="ID_313293093" MODIFIED="1667667110754" TEXT="kann relativ brachial erfolgen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1667667111845" ID="ID_240814651" MODIFIED="1667667131096" TEXT="Input kann nur leer sein, nicht negativ"/>
|
|
<node CREATED="1667667143969" ID="ID_971076298" MODIFIED="1667667564598" TEXT="falls leer, weite aus auf DEFAULT_CANVAS (≙ 23sec)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...zunächst habe ich hier immer nur das Minimale getan, nämlich 1 µTick aufgeweitet; dies würde zwar funktionieren, aber in der Regel nicht zu einem praktikablen Verhalten führen — wohingegen der <i>DEFAULT_CANVAS</i>  so gewählt ist, daß er klein und handlich ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667667185251" ID="ID_396603353" MODIFIED="1667667316295" TEXT="extrem große Canvas oder Fenster sind nicht gefährlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sofern wir den Speicher haben...
|
|
</p>
|
|
<p>
|
|
Will sagen, sie sind nicht gefährlich für den Invarianten-Mechanismus, denn für diesen wird es ehr bei sehr kleinen Zeitspannen kniffelig; wohingegen beliebig starkes zoom-out stets repräsentierbar ist als fraktionaler Integer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667611339595" ID="ID_1035209313" MODIFIED="1667668297039" TEXT="pxWidth errechnen / festsetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667667900172" ID="ID_638983817" MODIFIED="1667667999509" TEXT="hier nun doch eine Maximal-Pixelzahl eingeführt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...auch das basiert auf einer pragmatischen Überlegung; theoretisch könnten wir beliebig große Pixelanzahl unterstützen, dies würde aber auf allen Ebenen zu unerwartetem Verhalten führen, dessen Konsequenzen ich nicht überblicke ⟹ dann besser eine willkürliche und hinreichend große Grenze
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667668184215" ID="ID_364715169" MODIFIED="1667668292358" TEXT="und fall-back auf das visibleWin in default-Metrik">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dies ist ein reiner Platzhalter für Tests, denn in der Praxis erwarte ich stets daß sofort zu Beginn eine Breite in Pixeln gesetzt wird — kann ja gar nicht anders sein...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671236494801" ID="ID_50154227" MODIFIED="1671236514711" TEXT="inhärente Grenzen der Zoom-Metrik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1671236517973" ID="ID_1641527388" MODIFIED="1671236616158" TEXT="nachträglich eingeführt im Zuge der Streß-Tests">
|
|
<arrowlink COLOR="#6499bb" DESTINATION="ID_78031576" ENDARROW="Default" ENDINCLINATION="-146;-1064;" ID="Arrow_ID_283548397" STARTARROW="None" STARTINCLINATION="967;54;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671236771308" ID="ID_1634457986" MODIFIED="1671236783202" TEXT="zoom < 2*Time::SCALE"/>
|
|
<node COLOR="#435e98" CREATED="1671236757105" ID="ID_1364175921" MODIFIED="1671236783202" TEXT="zoom > LIM_HAZARD/1000"/>
|
|
<node CREATED="1671236506015" ID="ID_1832535054" MODIFIED="1671236795038" TEXT="»conformWindowToMetricLimits«"/>
|
|
</node>
|
|
<node CREATED="1667610653277" ID="ID_1224205751" MODIFIED="1667611359311" TEXT="neue Metrik ⟶ visibleWin">
|
|
<node CREATED="1667659377837" ID="ID_634768326" MODIFIED="1667659613008" TEXT="»conformWindowToMetric«">
|
|
<node CREATED="1667780062257" ID="ID_765381666" MODIFIED="1667780567605" TEXT="zentriert auch um Ankerpunkt">
|
|
<arrowlink COLOR="#f6eea5" DESTINATION="ID_1526154403" ENDARROW="Default" ENDINCLINATION="806;0;" ID="Arrow_ID_1380091213" STARTARROW="None" STARTINCLINATION="255;23;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667780073285" ID="ID_956345787" MODIFIED="1667780222348" TEXT="enthält zentrale bound + sanity-Checks">
|
|
<arrowlink COLOR="#588caf" DESTINATION="ID_1376383397" ENDARROW="Default" ENDINCLINATION="-365;-86;" ID="Arrow_ID_1012524185" STARTARROW="None" STARTINCLINATION="244;18;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667610682228" ID="ID_154285310" MODIFIED="1667610688031" TEXT="Fenster in Canvas schieben">
|
|
<node CREATED="1667659486321" ID="ID_897577157" MODIFIED="1667659616368" TEXT="»conformWindowToCanvas«"/>
|
|
</node>
|
|
<node CREATED="1667610688715" ID="ID_11883276" MODIFIED="1667610699053" TEXT="Fenster auf Canvas beschneiden"/>
|
|
<node CREATED="1667610653277" ID="ID_831514693" MODIFIED="1667611449269" TEXT="neue Metrik ⟵ visibleWin">
|
|
<node CREATED="1667659622859" ID="ID_828891167" MODIFIED="1667659633949" TEXT="»conformMetricToWindow«"/>
|
|
<node COLOR="#435e98" CREATED="1671236817013" ID="ID_661439299" LINK="#ID_1175951405" MODIFIED="1671236839666">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist das <b>Kernstück</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667611135215" ID="ID_1783825207" MODIFIED="1667611444146" TEXT="neue Metrik beschneiden">
|
|
<node CREATED="1667659689795" ID="ID_1515577475" MODIFIED="1667659703886" TEXT="»conformBounds«"/>
|
|
<node CREATED="1667672310513" ID="ID_1440027403" MODIFIED="1667672328162" TEXT="Metric < MAX_ZOOM"/>
|
|
<node CREATED="1667610653277" ID="ID_761246682" MODIFIED="1667682138815" TEXT="Metrik ⟶ visibleWin">
|
|
<linktarget COLOR="#9e7367" DESTINATION="ID_761246682" ENDARROW="Default" ENDINCLINATION="145;-11;" ID="Arrow_ID_702546557" SOURCE="ID_1067254564" STARTARROW="None" STARTINCLINATION="-54;-36;"/>
|
|
</node>
|
|
<node CREATED="1667611247456" ID="ID_1658100193" MODIFIED="1667611265274" TEXT="visibleWin ⟶ Canvas"/>
|
|
<node COLOR="#435e98" CREATED="1667673574471" FOLDED="true" ID="ID_1973274504" MODIFIED="1667774166875" TEXT="neue Metrik < MAX_ZOOM">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1667673606578" ID="ID_1067254564" MODIFIED="1667682151865" TEXT="potentiell gefährlich: Metrik ⟶ visibleWin">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn dabei wird gerundet, um die exakte Pixel-Zahl zu erhalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#9e7367" DESTINATION="ID_761246682" ENDARROW="Default" ENDINCLINATION="145;-11;" ID="Arrow_ID_702546557" STARTARROW="None" STARTINCLINATION="-54;-36;"/>
|
|
</node>
|
|
<node CREATED="1667682713949" ID="ID_425310807" MODIFIED="1667682719231" TEXT="Grenzfall-Analyse">
|
|
<node CREATED="1667682721338" ID="ID_842333816" MODIFIED="1667682794317" TEXT="Fenster kann verkürzt werden durch Rundung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced">afterWin_ = startWin_ + Time{dur};</font>
|
|
</p>
|
|
<p>
|
|
wobei dur einen fraktionalen Anteil < 1 µTick enthalten könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667683782783" ID="ID_1842670966" MODIFIED="1667683907910" TEXT="MAX_TIMESPAN: Begrenzung hier nicht relevant">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Grenzfall ist ja changedMetric = MAX_ZOOM
|
|
</p>
|
|
<p>
|
|
Wenn ich das durch eine irgendwie geartete pxWidth teile, wird es niemals größer, und zudem ist MAX_ZOOM < MAX_TIMESPAN
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667683116532" ID="ID_895916326" MODIFIED="1667683126786" TEXT="ruft auf: conformMetricToWindow">
|
|
<node COLOR="#435e98" CREATED="1667683149810" ID="ID_872183002" MODIFIED="1667683633595" TEXT="Bug: errechnet pxWidth neu mit schon geänderter Länge">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das bedeutet: genau durch diese Abrundung auf den nächst kleineren µTick könnten wir u.U einen Pixel verlieren
|
|
</p>
|
|
<p>
|
|
⟹ Abhilfe: originale pxWidth als Paremeter mitgeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1667683634701" ID="ID_1449451873" MODIFIED="1667685735423" TEXT="Metrik kann minimal größer geworden sein (durch Rundung)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Konkretes Rechenbeispiel:</u>
|
|
</p>
|
|
<p>
|
|
pxWidth = 99999  (ein Pixel weniger als maximal möglich)
|
|
</p>
|
|
<p>
|
|
changedMetric = MAX_ZOOM = 2000000
|
|
</p>
|
|
<p>
|
|
⟹ conformWindowToMetric() errechnet
|
|
</p>
|
|
<p>
|
|
dur = 49999+1/2 µTick
|
|
</p>
|
|
<p>
|
|
�� das wird abgerundet auf 49999 µTick
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
⟹ conformMetricToWindow() errechnet
|
|
</p>
|
|
<p>
|
|
adjMetric = 99999 / (49999/1000000) = 2000020,0004000080001600032
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
⟹ das ist <b>definitiv größer</b> als MAX_ZOOM
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667688476525" ID="ID_226096711" MODIFIED="1667688576067" TEXT="⟹ Konsequenz: Bias in Richtung vergrößerter Zoom / verkleinertes Fenster">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667688579306" ID="ID_486622183" MODIFIED="1667688586268" TEXT="allerdings ein sehr kleiner Effekt"/>
|
|
<node CREATED="1667688595090" ID="ID_1458378798" MODIFIED="1667688601683" TEXT="äquivalent +1 µTick"/>
|
|
<node CREATED="1667688946763" ID="ID_376119418" MODIFIED="1667689144112" TEXT="trotzdem unerwünscht ⟹ man kommt nicht zum Anfrang zurück">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
einmal stark reinzoomen, und dann wieder zurück ⟹ Bereich ist beschnitten und kleiner geworden; das ist lästig, weil die nächst größere Stufe deutlich größer ist; meiner Einschätzung nach wäre es weniger lästig, wenn man ein kleines bischen zu viel sieht, zumal sich das auf der nächsten Zweierpotenz einpendeln dürfte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667687800139" ID="ID_1785911993" MODIFIED="1667774152727" TEXT="Abhilfe">
|
|
<linktarget COLOR="#6989a3" DESTINATION="ID_1785911993" ENDARROW="Default" ENDINCLINATION="972;1311;" ID="Arrow_ID_993002191" SOURCE="ID_59748398" STARTARROW="None" STARTINCLINATION="1011;-3697;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667687810116" ID="ID_1519072103" MODIFIED="1667689196961" TEXT="Lösung-1">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1667688228377" ID="ID_1083352192" MODIFIED="1667688446311" TEXT="den Fall MAX_ZOOM + Rundungsfehler explizit abtesten"/>
|
|
<node CREATED="1667688234896" ID="ID_1025502092" MODIFIED="1667688423306" TEXT="und dann das visibleWin um 1 µTick vergrößern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...vergrößern, weil damit die Metrik kleiner wird und unter der Schwelle MAX_ZOOM gehalten wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667688257381" ID="ID_1551466069" MODIFIED="1667689187817" TEXT="Lösung-2">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1667688279379" ID="ID_873793356" MODIFIED="1667688288165" TEXT="stets pauschal 1µTick aufschlagen"/>
|
|
<node CREATED="1667688305031" ID="ID_950638301" MODIFIED="1667688330439" TEXT="keine gute Idee: behandelt exakte Verhältnisse falsch"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667688337402" ID="ID_124934014" MODIFIED="1667774147291" TEXT="Lösung-3">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1667688343137" ID="ID_1666323585" MODIFIED="1667774142887" TEXT="explizit auf Rundungsfehler testen">
|
|
<arrowlink COLOR="#16967b" DESTINATION="ID_395273674" ENDARROW="Default" ENDINCLINATION="-430;-19;" ID="Arrow_ID_1396048890" STARTARROW="None" STARTINCLINATION="308;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667688354104" ID="ID_1203966035" MODIFIED="1667774073074" TEXT="und in diesem Fall visibleWin um 1 µTick vergrößern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1667689836161" FOLDED="true" ID="ID_1356615492" MODIFIED="1667760039819" TEXT="besser: Aufrundungs-Konstante addieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nach grober Abschätzung sind das weniger Operationen, als die Konvertierung auszuführen und zurück zu konvertieren und dann zu testen; zwar könnte der Optimiser den Test per common subexpression noch vereinfachen — aber letztlich empfinde ich das Addieren einer ULP-Konstante als deklarativer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#338800" CREATED="1667690184889" ID="ID_1410341897" MODIFIED="1667753830123" TEXT="Vorsicht: experimentell prüfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667747398556" ID="ID_952719507" MODIFIED="1667747493566" TEXT="wie schon vermutet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es kommt eine negative Zahl heraus: IntMax * Scale ⟼ -Scale  (im Nenner)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1667747411897" ID="ID_767311084" MODIFIED="1667747502782" TEXT="Fract-Arithmetik kann entgleisen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1667757234228" ID="ID_1561483253" MODIFIED="1667757240865" TEXT="gefährlich sind die Nenner">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667757241668" ID="ID_149215399" MODIFIED="1667757383608" TEXT="zu jedem gegebenen Nenner > 1..."/>
|
|
<node CREATED="1667757251446" ID="ID_1048380323" MODIFIED="1667759097045">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
läßt sich ein »<b>unbeherrschbarer Summand</b>« konstruieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#7e4c66" DESTINATION="ID_1048380323" ENDARROW="Default" ENDINCLINATION="411;20;" ID="Arrow_ID_1424188982" SOURCE="ID_1576668072" STARTARROW="None" STARTINCLINATION="450;-29;"/>
|
|
</node>
|
|
<node CREATED="1667757360499" ID="ID_1110013809" MODIFIED="1667757378957" TEXT="im Zweifelsfall 1/IntMax"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667747515038" ID="ID_1929663553" MODIFIED="1667753823728" TEXT="gesucht: Rational-Konstante">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1667747539288" ID="ID_1951969589" MODIFIED="1667754024155" TEXT="naiver-Ansatz: ein ULP abziehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da wird die Rechnung schwierig, denn ich kann es nicht ohne Weiteres mathematisch greifen....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#fd2a6a" DESTINATION="ID_1951969589" ENDARROW="Default" ENDINCLINATION="228;179;" ID="Arrow_ID_1471419287" SOURCE="ID_219818450" STARTARROW="None" STARTINCLINATION="-119;-5;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1667748952764" ID="ID_1863452609" MODIFIED="1667751189345">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ansatz mit Unbekannten
|
|
</p>
|
|
<p style="text-align: center">
|
|
1/S - 1/M = x / I  < 1/S
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ansatz mit Unbekannten führt auf eine nicht-lineare Gleichung, welche
|
|
die beiden Unbekannten verknüpft....
|
|
</p>
|
|
<p>
|
|
mit ULP = 1/M  und I (IntMax) und S (µTick Scale) setze ich an:
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
�� 1/s - 1/M = x / I
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
denn einen Ausdruck x/I kann man grade noch repräsentieren in
|
|
fraktionaler Arithmetik.
|
|
</p>
|
|
<p>
|
|
Das fürhrt dann leider zu einger Gleichung, die nicht besonders <i>sexy</i> daherkommt
|
|
</p>
|
|
<p>
|
|
<br>
|
|
�� I·S = I·M - x·M·S
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
also
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
 x = (I·M - I·S ) / (M·S) = (M - S) / (M·S/I) = I · (M - S)/(M·S)
|
|
</li>
|
|
<li>
|
|
 M = I·S / (I - x·S) = S / (1 - x·S/I)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1667749206392" ID="ID_1460373483" MODIFIED="1667751173463" TEXT="suche das größtmögliche repräsentierbare x">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1667751592378" ID="ID_18326921" MODIFIED="1667751601497" TEXT="muß eine Ganzzahl sein"/>
|
|
<node CREATED="1667751607890" ID="ID_132312569" MODIFIED="1667752562566" TEXT="muß kleiner sein als I/S">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn für x ≔ I/S  ergibt sich x/I = 1/s
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fdf78d" DESTINATION="ID_1095374074" ENDARROW="Default" ENDINCLINATION="26;-56;" ID="Arrow_ID_747520692" STARTARROW="None" STARTINCLINATION="-198;19;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667749438203" ID="ID_161790566" MODIFIED="1667749475409" TEXT="⟹ Diskussion von f(M) = 1/S - 1/M">
|
|
<node CREATED="1667750115800" ID="ID_56326642" MODIFIED="1667750136091" TEXT="(M - S) / (M·S)"/>
|
|
<node CREATED="1667749568601" ID="ID_471212878" MODIFIED="1667749579627" TEXT="Funktion hat kein lokales Minimum"/>
|
|
<node CREATED="1667749580760" ID="ID_324213979" MODIFIED="1667749608656" TEXT="Funktion ist für positive M monoton wachesnd mit Grenzwert 1/S"/>
|
|
<node CREATED="1667751717132" ID="ID_340559314" MODIFIED="1667751723817" TEXT="Sackgasse">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667752512074" ID="ID_1095374074" MODIFIED="1667752569851" TEXT="Problem emprisch/numerisch lösbar">
|
|
<linktarget COLOR="#fdf78d" DESTINATION="ID_1095374074" ENDARROW="Default" ENDINCLINATION="26;-56;" ID="Arrow_ID_747520692" SOURCE="ID_132312569" STARTARROW="None" STARTINCLINATION="-198;19;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1667752577050" ID="ID_1732134433" MODIFIED="1667752586180" TEXT="I/S ist selber keine Ganzzahl"/>
|
|
<node CREATED="1667752586960" ID="ID_1690080736" MODIFIED="1667752609545" TEXT="also kann man ausrechnen rational_cast<int64_t> (I/S)"/>
|
|
<node CREATED="1667752612145" ID="ID_895088673" MODIFIED="1667752625679" TEXT="und wegen der Truncation ist das dann unser gesuchtes x"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667752642697" ID="ID_1015534138" MODIFIED="1667752662085" TEXT=" x = 9223372036854">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1667752695274" ID="ID_1446953820" MODIFIED="1667752882367">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>empirsche Kontrolle</u>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">    const Rat UU = Rat(X/I); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">    SHOW_EXPR (UU); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">    SHOW_EXPR ((UU < MICRO_TICK)); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">    SHOW_EXPR ((Rat(X+1)/I < MICRO_TICK)); </font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<u>Ausgabe...</u>
|
|
</p>
|
|
<p>
|
|
<font color="#2d158d" face="Monospaced" size="2">Probe rational_cast<int64_t>(LIM) ? = 9223372036854 </font>
|
|
</p>
|
|
<p>
|
|
<font color="#2d158d" face="Monospaced" size="2">Probe UU ? = 9223372036854/9223372036854775807 </font>
|
|
</p>
|
|
<p>
|
|
<font color="#2d158d" face="Monospaced" size="2">Probe (UU < MICRO_TICK) ? = </font><font color="#fe0d1e" face="Monospaced" size="2">true</font>
|
|
</p>
|
|
<p>
|
|
<font color="#2d158d" face="Monospaced" size="2">Probe (Rat(X+1)/I < MICRO_TICK) ? = </font><font color="#f44d8f" face="Monospaced" size="2">false</font>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667753664696" ID="ID_324128019" MODIFIED="1667753836503" TEXT="praktisch aber nicht brauchbar">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1667753679862" ID="ID_114001625" MODIFIED="1667753691100" TEXT="weil unser ULP im Nenner IntMax enthält"/>
|
|
<node CREATED="1667753692252" ID="ID_1791487346" MODIFIED="1667753710406" TEXT="wird jede Fractional-Rechnung mit einer teilerfremden Zahl entgleisen"/>
|
|
<node CREATED="1667753910591" ID="ID_219818450" MODIFIED="1667754029902" TEXT="⟹ es gibt repreäsentierbare Zahlen, die nicht mit ULP beaufschlagt werden können">
|
|
<arrowlink COLOR="#fd2a6a" DESTINATION="ID_1951969589" ENDARROW="Default" ENDINCLINATION="228;179;" ID="Arrow_ID_1471419287" STARTARROW="None" STARTINCLINATION="-119;-5;"/>
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1667754041750" ID="ID_680571899" MODIFIED="1667754051627" TEXT="damit bricht der ganze Ansatz zusammen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1667754062939" ID="ID_415976096" MODIFIED="1667774059912" TEXT="pragmatischer Ansatz: Rechnung analysieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667754986080" ID="ID_569618069" MODIFIED="1667754991939" TEXT="was wird gerechnet?">
|
|
<node CREATED="1667755010501" ID="ID_452896877" MODIFIED="1667755012696" TEXT="dur = Rat(pxWidth) / changedMetric;"/>
|
|
<node CREATED="1667760086102" ID="ID_1300680991" MODIFIED="1667760242140" TEXT="S · dur muß Ganzzahl werden"/>
|
|
<node CREATED="1667760247368" ID="ID_1551257128" MODIFIED="1667770564715" TEXT="lieder gibt es dafür viele Möglichkeiten...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Wenn der Nenner selbst S ist
|
|
</li>
|
|
<li>
|
|
Wenn der Nenner ein Teiler von S ist
|
|
</li>
|
|
<li>
|
|
wenn der Nenner ein Teiler von S · pxWidth ist
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667755619878" ID="ID_52791788" MODIFIED="1667755640606" TEXT="Problem: Metrik ist eingabe-Parameter, also beliebig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667755644345" ID="ID_834430909" MODIFIED="1667755652835" TEXT="ohne eine Gesamtanalyse komme ich hier nicht weiter"/>
|
|
<node CREATED="1667757006642" ID="ID_1683391428" MODIFIED="1667757022260" TEXT="läuft auf ein ähnliges Argument wie oben hinaus...?"/>
|
|
<node CREATED="1667757079456" ID="ID_1233477394" MODIFIED="1667757139221" TEXT="metric.numerator() kann im Extremfall IntMax sein"/>
|
|
<node CREATED="1667757144904" ID="ID_1576668072" MODIFIED="1667759201511" TEXT="und keine Addition damit wäre beherrschbar">
|
|
<arrowlink COLOR="#7e4c66" DESTINATION="ID_1048380323" ENDARROW="Default" ENDINCLINATION="411;20;" ID="Arrow_ID_1424188982" STARTARROW="None" STARTINCLINATION="450;-29;"/>
|
|
<arrowlink COLOR="#fd3f58" DESTINATION="ID_87489281" ENDARROW="Default" ENDINCLINATION="95;0;" ID="Arrow_ID_1297278568" STARTARROW="None" STARTINCLINATION="-251;16;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1667759132638" ID="ID_87489281" MODIFIED="1667759196400" TEXT="Fazit: additive Konstante führt eine unnötige Gefahr ein">
|
|
<linktarget COLOR="#fd3f58" DESTINATION="ID_87489281" ENDARROW="Default" ENDINCLINATION="95;0;" ID="Arrow_ID_1297278568" SOURCE="ID_1576668072" STARTARROW="None" STARTINCLINATION="-251;16;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667770583325" ID="ID_1376383397" MODIFIED="1667774045227" TEXT="Test und Anpassung sicher implementieren">
|
|
<linktarget COLOR="#588caf" DESTINATION="ID_1376383397" ENDARROW="Default" ENDINCLINATION="-365;-86;" ID="Arrow_ID_1012524185" SOURCE="ID_956345787" STARTARROW="None" STARTINCLINATION="244;18;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667770594084" ID="ID_986392174" MODIFIED="1667770606454" TEXT="stellt sich als überraschend kniffelig heraus"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667770659811" ID="ID_1409927740" LINK="#ID_1236820860" MODIFIED="1667770728339" TEXT="besonders lästig: die einseitigen Einschränkungen mit TimeVar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667770746680" ID="ID_811746832" MODIFIED="1667770768217" TEXT="wenn TIme, TimeVal und TimeVar das Gleiche wären..."/>
|
|
<node CREATED="1667770768901" ID="ID_1155429207" MODIFIED="1667770782222" TEXT="dann ließe sich sowas wie hier viel einfacher implementieren"/>
|
|
<node COLOR="#435e98" CREATED="1667770804751" ID="ID_999676314" MODIFIED="1667770824136" TEXT="habe deshalb Ticket #1261 angelegt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667774098939" ID="ID_395273674" MODIFIED="1667774133273" TEXT="der Test selber läßt sich auf einen Modulo-Check reduzieren">
|
|
<linktarget COLOR="#16967b" DESTINATION="ID_395273674" ENDARROW="Default" ENDINCLINATION="-430;-19;" ID="Arrow_ID_1396048890" SOURCE="ID_1666323585" STARTARROW="None" STARTINCLINATION="308;26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670694560258" ID="ID_396828585" MODIFIED="1670694655272" TEXT="und sogar noch so vereinfachen daß er nicht mehr wrappt">
|
|
<arrowlink COLOR="#50a780" DESTINATION="ID_1981781381" ENDARROW="Default" ENDINCLINATION="1222;-1794;" ID="Arrow_ID_276369750" STARTARROW="None" STARTINCLINATION="477;23;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667773768899" ID="ID_1573161089" MODIFIED="1667773780121" TEXT="verwende nun zusätzliche lokal definierte Operatoren"/>
|
|
<node CREATED="1667773780950" ID="ID_1691901384" MODIFIED="1667773787049" TEXT="Thma auf später vertagt">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667659852956" ID="ID_1802836695" MODIFIED="1668131990115" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667659867147" ID="ID_1797487380" MODIFIED="1667659882100" TEXT="jeweils den beweglichen Teil als Argument"/>
|
|
<node CREATED="1667659890055" ID="ID_1728452596" MODIFIED="1667659897292" TEXT="immer nur einen Aspekt justieren"/>
|
|
<node CREATED="1667659931146" ID="ID_1567516385" MODIFIED="1667659944676" TEXT="die jeweilige Ziel-Invariante per Assertion dokumentieren"/>
|
|
<node COLOR="#338800" CREATED="1667698387387" ID="ID_1173911153" MODIFIED="1667787327395" TEXT="Normalisierungs-Sequenz auf Basis der einzel-Normalisierungen definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667774188104" ID="ID_377878203" MODIFIED="1668131988380" TEXT="alle externen Manipulationen darauf aufsetzen (und erfolgreich testen)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260366701" ID="ID_1895903283" MODIFIED="1668132061931" TEXT="sonstige Fälle lt. Spec">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667260373164" ID="ID_1630007510" MODIFIED="1667960414569" TEXT="Konstruktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667260420318" ID="ID_477529431" MODIFIED="1667960405494" TEXT="komplett default">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260430580" ID="ID_750011979" MODIFIED="1667960406446" TEXT="partielle Angaben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260502770" ID="ID_723001683" MODIFIED="1667960415708" TEXT="Metrik kalibrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667517362063" ID="ID_692971631" MODIFIED="1667517374025" TEXT="Metrik-Änderung wird auf das aktuelle window angewendet"/>
|
|
<node CREATED="1667517374757" ID="ID_1436498397" MODIFIED="1667960401094" TEXT="danach aber shift/scroll, damit das Window im Canvas bleibt"/>
|
|
<node CREATED="1667517394850" ID="ID_360062482" MODIFIED="1667517421035" TEXT="Beschnitt, wenn das Window zu groß wird ⟹ Metrik dann angepaßt"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667318608370" ID="ID_888607544" MODIFIED="1668131950765" TEXT="Metrik manipulieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1667318655807" ID="ID_1664936439" MODIFIED="1667960424344" TEXT="Einschränkung der Testbarkeit hier">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1667318668477" ID="ID_841988354" MODIFIED="1667318701059" TEXT="Regel für AnchorPoint sollte offen bleiben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667260470855" ID="ID_1346204475" MODIFIED="1668131895009" TEXT="Grenzfälle / Fehlerbehandlung ausleuchten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667517252905" ID="ID_335958554" MODIFIED="1667960483441" TEXT="größtmöglicher Zoom ≙ 2px / µ-Tick">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671236879381" ID="ID_1741876890" LINK="#ID_368621922" MODIFIED="1671237047783" TEXT="kleinstmöglicher Zoom ≙ ganze Time-Domain (erreichbar ab 560px Window)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667517299247" ID="ID_1450395718" MODIFIED="1667960483442" TEXT="kleinstmögliches window ≙ 1 µ-Tick">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667517317821" ID="ID_1713703867" MODIFIED="1668110364974" TEXT="weitest möglicher zoom-out ≙ Canvas-size">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667517346296" ID="ID_1169099153" MODIFIED="1668110660571" TEXT="aber: kann Canvas per reverse-Zoom expandieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668110423021" ID="ID_634828014" MODIFIED="1668110534049" TEXT="Ansatz: affin-lineare Transformation ">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1668110480428" ID="ID_1914764887" MODIFIED="1668110499005" TEXT="f ⟼ a·x + b">
|
|
<node COLOR="#435e98" CREATED="1668110501176" ID="ID_301241943" MODIFIED="1668110530507" TEXT="zwei Gleichungen mit zwei Unbekannten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668110510702" ID="ID_994770187" MODIFIED="1668110529021" TEXT="Rechnung insgesamt in Rat ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668110543283" ID="ID_1610967476" MODIFIED="1668110656569" TEXT="Test auf Anhieb erfolgreich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mathematik halt....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668131918787" ID="ID_663070466" MODIFIED="1668131947409" TEXT="runden um vorgegebene Pixel-Breite zu erzielen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667318726445" ID="ID_1535955412" MODIFIED="1668131953303" TEXT="visibleRange setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667528162442" ID="ID_1415942522" MODIFIED="1668131967248" TEXT="setzen einer Anker-Position">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667528171215" ID="ID_1526154403" MODIFIED="1668131970674" TEXT="relativ positionieren">
|
|
<linktarget COLOR="#f6eea5" DESTINATION="ID_1526154403" ENDARROW="Default" ENDINCLINATION="806;0;" ID="Arrow_ID_1380091213" SOURCE="ID_765381666" STARTARROW="None" STARTINCLINATION="255;23;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667528176866" ID="ID_1620735407" MODIFIED="1668131974988" TEXT="Canvas explizit erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667318713048" ID="ID_1238239373" MODIFIED="1668131978138" TEXT="scrollen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1667528185832" ID="ID_1091652690" MODIFIED="1668131887272" TEXT="schrittweise incl Canvas erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1667528199785" ID="ID_1692959674" MODIFIED="1668131867493" TEXT="limits bei relativem Positionieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1668131841797" ID="ID_1345079810" MODIFIED="1668131852632" TEXT="Verhalten der Implementierung bewußt geändert"/>
|
|
<node CREATED="1668131853635" ID="ID_864783373" MODIFIED="1668131862502" TEXT="wieso sollte man hier limitieren?"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667787116332" ID="ID_538942533" MODIFIED="1667871911986" TEXT="relativ nach Position und Prozentsatz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1667871912848" ID="ID_28548966" MODIFIED="1667871963481" TEXT="das läuft auf eine Variante des relativen-Ankers hinaus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667871926941" ID="ID_56646265" MODIFIED="1667872010814" TEXT="kann aber nur die kubische Positions-Regel wiederverwenden...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alles Andere ist in diesem Fall eben doch speziell; wir kommen bereits mit einer relativen Angabe, und die aktuelle Fensterposition spielt keine Rolle
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1667528209948" ID="ID_914020436" MODIFIED="1667871908657" TEXT="explizit setzen und Canvas erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1667787036706" ID="ID_192598582" MODIFIED="1667871690775" TEXT="muß hierfür die Limitierung explizit aufheben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1667787054759" ID="ID_280714694" MODIFIED="1667871751969" TEXT="neue Festlegung: alle mutateWindow()-Aufrufe können Canvas erweitern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667871761244" ID="ID_550353046" MODIFIED="1667871901718" TEXT="hierzu ändere ich die Spezifikation: auch relatives Zoomen kann nun Canvas erweitern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum auch nicht?
|
|
</p>
|
|
<p>
|
|
Das ist dann so viel konsistenter, insofern nun nämlich genau die Funktionen, die die visible-Window-Position setzen, auch den Canvas erweitern dürfen — aber alle anderen Funktionen stoßen an der Canvas-Grenze an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668176529007" ID="ID_1000385499" MODIFIED="1668178932385" TEXT="changeNotification">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668176558035" ID="ID_389422615" MODIFIED="1668176565812" TEXT="es ist ein reiner Trigger">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668176566961" ID="ID_1163344157" MODIFIED="1668178900570" TEXT="also genügt es, zu beweisen, daß er ausgelöst wird">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668178902040" ID="ID_1008564979" MODIFIED="1668178918007" TEXT="außerdem: Notification ist pro Instanz gesondert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668178918696" ID="ID_958127282" MODIFIED="1668178931317" TEXT="und man kann sie auch wieder abkoppeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180004015" ID="ID_1355163433" MODIFIED="1671324161416" TEXT="extreme Grenzfälle abtesten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668212345981" ID="ID_1473341053" MODIFIED="1668212365788" TEXT="leer konstruiert ⟹ default-canvas">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180016155" ID="ID_506165727" MODIFIED="1670961012384" TEXT="leere Intervalle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670960970348" ID="ID_1737770423" MODIFIED="1670982893953" TEXT="leerer TimeSpan ⟹ ensureNonEmpty()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670960996683" ID="ID_200537694" MODIFIED="1670961014742" TEXT="mutateDuration ist abgesichert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670961004168" ID="ID_1406068671" MODIFIED="1670961037304" TEXT="calibrateExtension ist abgesichert">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180071412" ID="ID_1188877277" MODIFIED="1670961056848" TEXT="falsch orientierte Intervalle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668262916332" ID="ID_670540657" MODIFIED="1668262927471" TEXT="weitgehend unmöglich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1668262928548" ID="ID_186072598" MODIFIED="1668262939564" TEXT="TimeSpan verhindert das">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1668263012905" ID="ID_37434622" MODIFIED="1668263018116" TEXT="genauer: es ist bereits Duration"/>
|
|
<node CREATED="1668263018992" ID="ID_774651709" MODIFIED="1668263029586" TEXT="Duration hat keinen normalen Copy-Konstruktur"/>
|
|
<node CREATED="1668263130427" ID="ID_371714481" MODIFIED="1668263147178" TEXT="Duration nimmt in jedem Ctor einen Absolutbetrag"/>
|
|
<node CREATED="1668263170236" ID="ID_1832591940" MODIFIED="1668263185566" TEXT="TimeSpan schickt alle Eingaben durch Duration-ctor"/>
|
|
<node CREATED="1668263200351" ID="ID_526293515" MODIFIED="1668263226330" TEXT="⟹ sofern man TimeSpan per Value nimmt ist sogar Manipulation unmöglich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670966291514" ID="ID_248415571" MODIFIED="1670982882510" TEXT="TimeSpan::conform()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670966626174" ID="ID_1602981358" MODIFIED="1670966640064" TEXT="wird normalerweise nicht automatisch aufgerufen"/>
|
|
<node CREATED="1670966647403" ID="ID_1992293509" MODIFIED="1670966667911" TEXT="kann aber das Schieben + Kappen eines Intervals auf Domäne erledigen"/>
|
|
<node CREATED="1670966669608" ID="ID_1330290323" MODIFIED="1670966686260" TEXT="erzeugt eine konditionierte Kopie"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668262940706" ID="ID_1639008148" MODIFIED="1670961054485" TEXT="⟹ Eingangs-Checks vereinfachen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668554856002" FOLDED="true" ID="ID_1728331882" MODIFIED="1671235912681" TEXT="potentiell schädliche Eingabedaten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668262961151" ID="ID_1262854527" MODIFIED="1671235655665" TEXT="alle Eingänge daraufhin prüfen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668263281549" ID="ID_1653448250" MODIFIED="1668263292760" TEXT="potentiell gefährlich">
|
|
<node COLOR="#435e98" CREATED="1668263300631" ID="ID_1173749705" MODIFIED="1670960741915" TEXT="setMetric (Rat px_per_sec)">
|
|
<arrowlink COLOR="#aa6877" DESTINATION="ID_1257614207" ENDARROW="Default" ENDINCLINATION="271;-11;" ID="Arrow_ID_292335664" STARTARROW="None" STARTINCLINATION="314;29;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668263308095" ID="ID_41228001" MODIFIED="1668263308095" TEXT="nudgeMetric (int steps)">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668265226231" HGAP="29" ID="ID_680870152" MODIFIED="1668265531172" TEXT="(ähnliche Problemlage)" VSHIFT="6">
|
|
<arrowlink COLOR="#be7ca2" DESTINATION="ID_1943948610" ENDARROW="Default" ENDINCLINATION="57;-54;" ID="Arrow_ID_569700266" STARTARROW="None" STARTINCLINATION="197;26;"/>
|
|
<font NAME="SansSerif" SIZE="8"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668263379747" ID="ID_1108084309" MODIFIED="1668265880846" TEXT="setOverallStart (TimeValue start)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1668265476934" HGAP="22" ID="ID_1672613430" MODIFIED="1668265497115" TEXT="Offset ⟹ harmlos" VSHIFT="2">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668263363873" ID="ID_1000302477" MODIFIED="1668267369598" TEXT="nudgeVisiblePos (int steps)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1668267251650" ID="ID_772154372" MODIFIED="1671235578564" TEXT="potentieller TimeValue-wrap">
|
|
<linktarget COLOR="#d37297" DESTINATION="ID_772154372" ENDARROW="Default" ENDINCLINATION="-1063;-32;" ID="Arrow_ID_1688376810" SOURCE="ID_407876103" STARTARROW="None" STARTINCLINATION="918;66;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#338800" CREATED="1671225675177" ID="ID_833984717" MODIFIED="1671235584467" TEXT="Parameter muß int64_t sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ dann paßt der Wertebereich im Extremfall grade so rein (1px-Window mit 1µ-Tick, und das per halb-Steps von Time::MIN ⟼ Time::MAX bringen:  lb <= 62 )
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671225805631" ID="ID_1037472560" MODIFIED="1671235592474" TEXT="jeweils konkreten Limit auf Maximal-Offset berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671225819397" ID="ID_1944515344" MODIFIED="1671235594489" TEXT="Time-Scale fängt mehr als ± Duration::MAX ab">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671225861224" ID="ID_1547165206" MODIFIED="1671235596761" TEXT="die neulich nachgeschärfte Limitierung von time::Offset erledigt den Rest...">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668265476934" HGAP="22" ID="ID_1024656656" MODIFIED="1668265497115" TEXT="Offset ⟹ harmlos" VSHIFT="2">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668263398546" ID="ID_1572318013" MODIFIED="1668265880846" TEXT="setVisiblePos (Time posToShow)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1668265476934" HGAP="22" ID="ID_1485739923" MODIFIED="1668265497115" TEXT="Offset ⟹ harmlos" VSHIFT="2">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668263409355" ID="ID_1494604965" MODIFIED="1671216876683" TEXT="setVisiblePos (Rat percentage)">
|
|
<arrowlink COLOR="#895f96" DESTINATION="ID_759637608" ENDARROW="Default" ENDINCLINATION="124;-7;" ID="Arrow_ID_728050450" STARTARROW="None" STARTINCLINATION="168;14;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668263422928" ID="ID_1049514706" MODIFIED="1668263422928" TEXT="setVisiblePos (double percentage)"/>
|
|
<node COLOR="#435e98" CREATED="1670608837155" ID="ID_1810196404" MODIFIED="1670608847785" TEXT="pxWidth()">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1670608849328" ID="ID_1135224410" MODIFIED="1670608880268" TEXT="kann bei maximal zulässigen Parametern bereits in numeric-wrap laufen">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670608881221" ID="ID_617148644" LINK="#ID_1459847631" MODIFIED="1670609042831">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gelöst durch geschickte schrittweise Berechnung:
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#403786">calcPixelsForDurationAtScale (Rat zoomFactor, FSecs duration)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wir nutzen explizit aus, daß das Ergebnis durch truncating quantisiert wird (Integer-Division). Daher können wir erst den ersten Dividenden (die Zeitspanne) aufteilen, und zwar erst mal in den Sekunden-Anteil, dann den Rest, und dann den Rest vom Rest
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668263441959" ID="ID_1366157126" MODIFIED="1668263454322" TEXT="2.Layer — privat">
|
|
<node COLOR="#435e98" CREATED="1668263464370" ID="ID_452384864" MODIFIED="1670608807787" TEXT="establishMetric (uint pxWidth, Time startWin, Time afterWin)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1668269822171" ID="ID_1581625515" MODIFIED="1670608805543" TEXT="Resultat sollte "ungiftig" sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil es direkt in das Feld <font face="Monospaced" color="#87179a">px_per_second_</font> geht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668269838609" ID="ID_982888658" MODIFIED="1670608801375" TEXT="geeignet normieren oder kappen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670608693763" ID="ID_1403342865" MODIFIED="1670608757928" TEXT="genauere Betrachtung zeigt: hier keine Gefahr"/>
|
|
<node CREATED="1670608703396" ID="ID_1449271152" MODIFIED="1670960623932" TEXT="Duration wird errechnet und ist daher ggfs. sehr groß, aber nicht giftig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Nenner ist limitiert (kleiner Time::SCALE) und nicht toxisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670608782329" ID="ID_1737555624" MODIFIED="1670608799171" TEXT="Pixel-Zahl wird grade hier explizit gekappt"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668263473958" ID="ID_1175951405" MODIFIED="1670608663663" TEXT="conformWindowToMetric (Rat changedMetric)">
|
|
<arrowlink COLOR="#bf0f5b" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="297;-23;" ID="Arrow_ID_389982782" STARTARROW="None" STARTINCLINATION="-323;20;"/>
|
|
<arrowlink COLOR="#856e9e" DESTINATION="ID_773636992" ENDARROW="Default" ENDINCLINATION="138;-8;" ID="Arrow_ID_976571904" STARTARROW="None" STARTINCLINATION="219;13;"/>
|
|
<arrowlink COLOR="#65253d" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="9;-40;" ID="Arrow_ID_382076752" STARTARROW="None" STARTINCLINATION="-11;29;"/>
|
|
<linktarget COLOR="#6f4b85" DESTINATION="ID_1175951405" ENDARROW="Default" ENDINCLINATION="300;0;" ID="Arrow_ID_739178440" SOURCE="ID_1976979366" STARTARROW="None" STARTINCLINATION="45;-137;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1668555596031" HGAP="151" ID="ID_1196389964" MODIFIED="1668555795593" TEXT="�� die zentrale Gelenkstelle" VSHIFT="4">
|
|
<edge COLOR="#fdf7a5" STYLE="linear"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668555725214" ID="ID_1632657793" MODIFIED="1668555774726" TEXT="alle potentiell gefährlichen Wirkpfade kommen hier vorbei"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668555737844" ID="ID_625503483" MODIFIED="1668555774726" TEXT="hier verwandeln sich Eingabedaten in Parameterdaten"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668701661948" HGAP="175" ID="ID_1116086039" MODIFIED="1668736303030" TEXT="Datenfluß-Analyse" VSHIFT="1">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1668701689231" ID="ID_1495743277" MODIFIED="1668701701766" TEXT="changedMetric ⟶ dur">
|
|
<node CREATED="1668701735972" ID="ID_1362411868" MODIFIED="1668701746854" TEXT="metric.num ⟶ dur.denom"/>
|
|
<node CREATED="1668701831578" ID="ID_364333659" MODIFIED="1668701864041" TEXT="Lim: metric.denom * pixWidth < MAX_INT">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668701912660" ID="ID_778993460" MODIFIED="1668701930151" TEXT="Lim: metric.num * Time::Scale < MAX_INT">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668701935616" ID="ID_1861389254" MODIFIED="1670694113716" TEXT="wegen isMicroGridAligned()">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1670694115318" ID="ID_1221970195" LINK="#ID_20864170" MODIFIED="1670694147739" TEXT="inzwischen entschärft">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668701946449" ID="ID_296260515" MODIFIED="1668701964086" TEXT="anschließend wird dur -> Time gerundet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668702760034" ID="ID_868876168" MODIFIED="1668703402758" TEXT="placeWindowRelativeToAnchor (dur)">
|
|
<arrowlink COLOR="#94576a" DESTINATION="ID_51247840" ENDARROW="Default" ENDINCLINATION="149;-123;" ID="Arrow_ID_257501351" STARTARROW="None" STARTINCLINATION="-150;12;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1668703282413" HGAP="-88" ID="ID_1113812536" MODIFIED="1668703442612" TEXT="Input (changedMetric) muß entgiftet werden" VSHIFT="23">
|
|
<edge COLOR="#f74141" STYLE="linear"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node COLOR="#338800" CREATED="1669473799874" ID="ID_1081409038" MODIFIED="1669473855697" TEXT="detox">
|
|
<edge COLOR="#5e51c9"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668703200176" ID="ID_1915595988" MODIFIED="1670608657540" TEXT="conformMetricToWindow()">
|
|
<linktarget COLOR="#65253d" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="9;-40;" ID="Arrow_ID_382076752" SOURCE="ID_1175951405" STARTARROW="None" STARTINCLINATION="-11;29;"/>
|
|
<linktarget COLOR="#6a6a92" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="37;170;" ID="Arrow_ID_1959668732" SOURCE="ID_4317582" STARTARROW="None" STARTINCLINATION="-243;-9;"/>
|
|
<linktarget COLOR="#6a6a92" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="45;199;" ID="Arrow_ID_1858388760" SOURCE="ID_538384824" STARTARROW="None" STARTINCLINATION="-486;-28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1668703282413" ID="ID_1976673029" MODIFIED="1669473783896" TEXT="Output muß entgiftet werden">
|
|
<edge COLOR="#f74141" STYLE="linear"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node COLOR="#338800" CREATED="1669473816376" HGAP="129" ID="ID_1549431699" MODIFIED="1669473872429" TEXT="detox" VSHIFT="4">
|
|
<edge COLOR="#5e51c9"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668703253721" ID="ID_562775888" MODIFIED="1668703454748" TEXT="output ⟶ finaler Metrik-Faktor">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668263585452" ID="ID_195681721" MODIFIED="1668270219934" TEXT="conformWindowToCanvas(<current-settings>)">
|
|
<node CREATED="1668270193562" ID="ID_918641802" MODIFIED="1668270440632" TEXT="nur additive arithmetik">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668270199865" ID="ID_764029688" MODIFIED="1668270213799" TEXT="bereits explizit auf Grenzen geprüft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668263473958" ID="ID_148236436" MODIFIED="1668292385911" TEXT="conformToBounds (Rat changedMetric)">
|
|
<arrowlink COLOR="#9a858e" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="297;-23;" ID="Arrow_ID_1815772846" STARTARROW="None" STARTINCLINATION="-292;20;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668292226927" ID="ID_46729545" MODIFIED="1668292236334" TEXT="nur eine Verwendung in ensureInvariants">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1668292206153" ID="ID_1278501779" MODIFIED="1668292239165" TEXT="liegt hinter conforMetricToWindow">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1668292291702" ID="ID_199183662" MODIFIED="1668294441771" TEXT="dies kann zwar einen sehr großen Nenner einführen">
|
|
<arrowlink COLOR="#c6476e" DESTINATION="ID_91804756" ENDARROW="Default" ENDINCLINATION="220;-12;" ID="Arrow_ID_1385445807" STARTARROW="None" STARTINCLINATION="721;42;"/>
|
|
</node>
|
|
<node CREATED="1668292302036" ID="ID_232220269" MODIFIED="1668292309247" TEXT="ist aber selber weiter nicht toxisch"/>
|
|
<node CREATED="1668292317202" ID="ID_883712171" MODIFIED="1668292327181" TEXT="und kann nicht entgleisen">
|
|
<node CREATED="1668292327913" ID="ID_1178284866" MODIFIED="1668292332396" TEXT="pxWidth ist limitiert"/>
|
|
<node CREATED="1668292333165" ID="ID_1678221888" MODIFIED="1668292343339" TEXT="dur = FSecs(after-start) ist limitiert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668263629246" ID="ID_1257614207" MODIFIED="1671216867276" TEXT="mutateScale (Rat changedMetric)">
|
|
<arrowlink COLOR="#e62f5c" DESTINATION="ID_651838862" ENDARROW="Default" ENDINCLINATION="115;-4;" ID="Arrow_ID_1930230162" STARTARROW="None" STARTINCLINATION="-189;14;"/>
|
|
<arrowlink COLOR="#753c82" DESTINATION="ID_1976979366" ENDARROW="Default" ENDINCLINATION="-43;-3;" ID="Arrow_ID_226790124" STARTARROW="None" STARTINCLINATION="80;7;"/>
|
|
<linktarget COLOR="#aa6877" DESTINATION="ID_1257614207" ENDARROW="Default" ENDINCLINATION="271;-11;" ID="Arrow_ID_292335664" SOURCE="ID_1173749705" STARTARROW="None" STARTINCLINATION="314;29;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1668265021139" HGAP="52" ID="ID_1943948610" MODIFIED="1670517343960" TEXT="prüfen: sehr kleine Metrik" VSHIFT="-2">
|
|
<linktarget COLOR="#be7ca2" DESTINATION="ID_1943948610" ENDARROW="Default" ENDINCLINATION="57;-54;" ID="Arrow_ID_569700266" SOURCE="ID_680870152" STARTARROW="None" STARTINCLINATION="197;26;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1668265390104" ID="ID_1154641838" MODIFIED="1668265435386" TEXT="es gibt keine Unterschwelle">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668265398152" ID="ID_754119758" MODIFIED="1668265427796" TEXT="⟶ hier könnte sehr großer Nenner ins System gelangen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670516822914" FOLDED="true" ID="ID_78031576" LINK="#ID_368621922" MODIFIED="1670517608517" TEXT="dynamische Untergrenze einführen">
|
|
<arrowlink COLOR="#64bc9c" DESTINATION="ID_660534369" ENDARROW="Default" ENDINCLINATION="227;-218;" ID="Arrow_ID_1983834485" STARTARROW="None" STARTINCLINATION="-503;36;"/>
|
|
<linktarget COLOR="#6499bb" DESTINATION="ID_78031576" ENDARROW="Default" ENDINCLINATION="-146;-1064;" ID="Arrow_ID_283548397" SOURCE="ID_1641527388" STARTARROW="None" STARTINCLINATION="967;54;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670516838244" ID="ID_479791948" MODIFIED="1670516852366" TEXT="in Abhängigkeit von der Weite in Pixeln"/>
|
|
<node CREATED="1670516854928" ID="ID_999425219" MODIFIED="1670516948570" TEXT="nach technischem Kriterium definiert (Berechenbarkeit)">
|
|
<arrowlink COLOR="#4660c4" DESTINATION="ID_979012602" ENDARROW="Default" ENDINCLINATION="-136;-164;" ID="Arrow_ID_456720693" STARTARROW="None" STARTINCLINATION="115;6;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1670285974347" ID="ID_281565361" MODIFIED="1670517155305" TEXT="pixel/maxExtension > 1/ LIM_HAZARD">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn der Zoom-Faktor einen größeen Nenner bekommt, wird er nach den inzwischen etablierten Richtlinien als »toxisch« betrachtet, und das heißt, die typischen Berechnungen im ZoomWindow könnten entgleisen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670285726380" ID="ID_1653623380" MODIFIED="1670516907686" TEXT="⟹ maxExtension < pxWidth * (1<<40)"/>
|
|
</node>
|
|
<node CREATED="1670517051791" ID="ID_681227378" MODIFIED="1670517268759" TEXT="nur wirksam bei relativ kleiner Pixelzahl">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hinreichend große Fenster (ab ein paar hunder Pixeln) können die ganze Zeitdomäne abdecken
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1670517163880" ID="ID_1748539032" MODIFIED="1670517173530" TEXT="insofern ist das eine Grenzwertbetrachtung"/>
|
|
<node CREATED="1670517174286" ID="ID_741254433" MODIFIED="1670517260345" TEXT="erwarte keinerelei Relevanz in der Praxis">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle die hier angewendeten Heuristiken werden im normalen Einsatz niemals aktiviert, und daher profitieren wir normalerweise von der extremen Präzision der Integer-Bruchrechnung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668263638141" ID="ID_909162669" MODIFIED="1670960651484" TEXT="mutateDuration (FSecs duration, uint px =0)">
|
|
<node CREATED="1668270374842" HGAP="29" ID="ID_1976979366" MODIFIED="1670960723275" TEXT="delegiert an conformWindowToMetric(Rat)" VSHIFT="-13">
|
|
<arrowlink COLOR="#6f4b85" DESTINATION="ID_1175951405" ENDARROW="Default" ENDINCLINATION="300;0;" ID="Arrow_ID_739178440" STARTARROW="None" STARTINCLINATION="45;-137;"/>
|
|
<linktarget COLOR="#753c82" DESTINATION="ID_1976979366" ENDARROW="Default" ENDINCLINATION="-43;-3;" ID="Arrow_ID_226790124" SOURCE="ID_1257614207" STARTARROW="None" STARTINCLINATION="80;7;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669479155534" ID="ID_620129730" MODIFIED="1669479162094" TEXT="adaptWindowToPixels(px)">
|
|
<node COLOR="#435e98" CREATED="1669479175476" ID="ID_590715378" MODIFIED="1669479353924" TEXT="Arithmetik erscheint ungefährlich">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1669479204552" ID="ID_29297928" MODIFIED="1669479365083" TEXT="unter der Annahme daß bestehende Metrik sauber ist">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669479223678" ID="ID_4317582" MODIFIED="1669479361432" TEXT="außerdem: Ausgang durch conformMetricToWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das betrachte ich als gutmütig und hinreichend abgesichert...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6a6a92" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="37;170;" ID="Arrow_ID_1959668732" STARTARROW="None" STARTINCLINATION="-243;-9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668263652677" ID="ID_759637608" MODIFIED="1671216888664" TEXT="anchorWindowAtPosition (FSecs canvasOffset)">
|
|
<linktarget COLOR="#895f96" DESTINATION="ID_759637608" ENDARROW="Default" ENDINCLINATION="124;-7;" ID="Arrow_ID_728050450" SOURCE="ID_1494604965" STARTARROW="None" STARTINCLINATION="168;14;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668265925547" ID="ID_548541569" MODIFIED="1668265934174" TEXT="negative Werte">
|
|
<node CREATED="1668267213730" ID="ID_751640089" MODIFIED="1668267225777" TEXT="grundsätzlich hier vorgesehen"/>
|
|
<node CREATED="1668267238564" ID="ID_1057480192" MODIFIED="1668267248362" TEXT="startWin_ = startAll_ + (canvasOffset - partBeforeAnchor);">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668267251650" ID="ID_1280626173" MODIFIED="1670016135487" TEXT="potentieller TimeValue-wrap">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1669507976363" ID="ID_1360914257" MODIFIED="1669508005798" TEXT="Duration und Canvas-size können groß sein">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1669507940458" ID="ID_355998747" MODIFIED="1669507940458" TEXT="Rat posFactor = canvasOffset / FSecs{afterAll_-startAll_};"/>
|
|
<node CREATED="1669507965470" ID="ID_1858701509" MODIFIED="1669507965470" TEXT="FSecs partBeforeAnchor = posFactor * duration;"/>
|
|
<node COLOR="#338800" CREATED="1670016112689" ID="ID_1869447563" LINK="#ID_289279043" MODIFIED="1670016131455" TEXT="hierfür eigene Hilfsfunktion geschaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668267393360" ID="ID_1700728412" MODIFIED="1668267398176" TEXT="giftige Brüche">
|
|
<node COLOR="#435e98" CREATED="1669508070174" ID="ID_171647736" MODIFIED="1670549465314" TEXT="Aua: so ziemlich alles kann hier giftig sein">
|
|
<linktarget COLOR="#8c2958" DESTINATION="ID_171647736" ENDARROW="Default" ENDINCLINATION="103;88;" ID="Arrow_ID_1341085031" SOURCE="ID_196873456" STARTARROW="None" STARTINCLINATION="351;-26;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1669508081900" ID="ID_1740115162" MODIFIED="1669508382889" TEXT="zwar kann das Ergebnis nicht grob entgleisen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1669508094694" ID="ID_1971396713" MODIFIED="1669508365178" TEXT="konsistentes Verhalten ist aber schwer aufrecht zu erhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar dann, wenn auch noch die Window-Parameter extrem sind — dann sieht die Lage ziemlich hoffnungslos aus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1669508366255" ID="ID_1644190283" MODIFIED="1669682752758" TEXT="Idee: auf gleichen Nenner normalisieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn dadurch würde man die kreuzweise Multiplikation verhindern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fbf8c7" DESTINATION="ID_267834802" ENDARROW="Default" ENDINCLINATION="538;-591;" ID="Arrow_ID_1957682133" STARTARROW="None" STARTINCLINATION="668;44;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668267422500" ID="ID_17566048" MODIFIED="1668267468507" TEXT="parabolicAnchorRule">
|
|
<arrowlink COLOR="#e92c3f" DESTINATION="ID_1689286236" ENDARROW="Default" ENDINCLINATION="82;-4;" ID="Arrow_ID_176217068" STARTARROW="None" STARTINCLINATION="-158;21;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669479223678" ID="ID_538384824" MODIFIED="1670960844426" TEXT=" Ausgang durch conformMetricToWindow">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das betrachte ich als gutmütig und hinreichend abgesichert...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6a6a92" DESTINATION="ID_1915595988" ENDARROW="Default" ENDINCLINATION="45;199;" ID="Arrow_ID_1858388760" STARTARROW="None" STARTINCLINATION="-486;-28;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668263473958" ID="ID_773636992" MODIFIED="1668293112414" TEXT="placeWindowRelativeToAnchor (FSecs duration)">
|
|
<arrowlink COLOR="#b18586" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="256;-19;" ID="Arrow_ID_882084800" STARTARROW="None" STARTINCLINATION="-201;12;"/>
|
|
<linktarget COLOR="#856e9e" DESTINATION="ID_773636992" ENDARROW="Default" ENDINCLINATION="138;-8;" ID="Arrow_ID_976571904" SOURCE="ID_1175951405" STARTARROW="None" STARTINCLINATION="219;13;"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668270677518" HGAP="31" ID="ID_51247840" MODIFIED="1668293080653" STYLE="fork" TEXT="Berechnung kann wild entgleisen" VSHIFT="2">
|
|
<linktarget COLOR="#94576a" DESTINATION="ID_51247840" ENDARROW="Default" ENDINCLINATION="149;-123;" ID="Arrow_ID_257501351" SOURCE="ID_868876168" STARTARROW="None" STARTINCLINATION="-150;12;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668292845491" ID="ID_1723809039" MODIFIED="1668293079087" TEXT="Differenz wird noch vom Puffer in TimeValue aufgefangen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich habe ja ganz bewußt Time::MAX == INT_MAX/3 genommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1668292982369" ID="ID_1496719180" MODIFIED="1668293079087" TEXT="Assignment an eine TimeVar macht einen Guard-check">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1668292909179" ID="ID_944892675" MODIFIED="1668703468960" TEXT="sofern der duration-Parameter auch sauber ist....">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668270662235" ID="ID_238899324" MODIFIED="1668293024213" TEXT="kein wirklicher Schaden möglich">
|
|
<node CREATED="1668293046153" ID="ID_1545859602" MODIFIED="1668293053428" TEXT="danach haben wir wieder einen TimeValue"/>
|
|
<node CREATED="1668293054279" ID="ID_202153481" MODIFIED="1668293059275" TEXT="und dieser liegt im Limit"/>
|
|
<node CREATED="1668293062334" ID="ID_1382128860" MODIFIED="1668293074089" TEXT="nachfolgende Normalisierung erledigt den Rest"/>
|
|
</node>
|
|
<node CREATED="1668703609105" ID="ID_1557527906" MODIFIED="1668703662246">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ <u><b>Fazit</b></u>:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
erhält Invariante
|
|
</li>
|
|
<li>
|
|
Ergebnis kann aber <i>inhaltlich falsch</i> sein
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668263721530" ID="ID_829406482" MODIFIED="1668270430868" TEXT="establishWindowDuration (TimeVar duration)">
|
|
<node CREATED="1668270193562" ID="ID_440259374" MODIFIED="1668270440632" TEXT="nur additive arithmetik">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668270199865" ID="ID_927662816" MODIFIED="1668270213799" TEXT="bereits explizit auf Grenzen geprüft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668263742928" ID="ID_1689286236" MODIFIED="1668736289358" TEXT="parabolicAnchorRule (Rat posFactor)">
|
|
<linktarget COLOR="#e92c3f" DESTINATION="ID_1689286236" ENDARROW="Default" ENDINCLINATION="82;-4;" ID="Arrow_ID_176217068" SOURCE="ID_17566048" STARTARROW="None" STARTINCLINATION="-158;21;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668267470317" ID="ID_409576187" MODIFIED="1668267475864" TEXT="kann entgleisen"/>
|
|
<node CREATED="1668269162412" ID="ID_983739705" MODIFIED="1668269175422" TEXT="Fehlfunktion ist aber letztlich harmlos"/>
|
|
<node CREATED="1668269178282" ID="ID_697782687" MODIFIED="1668269188827" TEXT="die nachgelagerte Normalisierung fängt die Konsequenzen auf"/>
|
|
<node COLOR="#338800" CREATED="1668269189680" ID="ID_1612606864" MODIFIED="1668269410626" TEXT="aber: Limitierung am Ausgang fehlt ⟹ nachrüsten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1668703498792" ID="ID_622549972" MODIFIED="1668703538961">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Vorsicht: Ergebnis-Faktor kann trotzdem <i><font color="#f41bbc">giftig sein</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668703745543" ID="ID_660082790" MODIFIED="1668736277567" TEXT="Ergebnis auch noch entgiften!">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668554900067" HGAP="80" ID="ID_1302892550" MODIFIED="1671235664482" TEXT="kritische Wirkpfade abtesten" VSHIFT="9">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668555028046" ID="ID_660534369" MODIFIED="1670517608516" TEXT="sehr kleine Metrix (≙ exterm zoom-out)">
|
|
<linktarget COLOR="#64bc9c" DESTINATION="ID_660534369" ENDARROW="Default" ENDINCLINATION="227;-218;" ID="Arrow_ID_1983834485" SOURCE="ID_78031576" STARTARROW="None" STARTINCLINATION="-503;36;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1669475559599" FOLDED="true" ID="ID_460741178" MODIFIED="1670376664053" TEXT="setMetric mit sehr kleinem giftigem Faktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670283526032" ID="ID_229404798" MODIFIED="1670283558380">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: <font color="#792020" face="Monospaced">detox()</font> macht den zu Null
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670283586375" ID="ID_890051949" MODIFIED="1670283599337" TEXT="so wie detox() arbeitet ist das sogar logisch"/>
|
|
<node CREATED="1670283673379" ID="ID_30349087" MODIFIED="1670283698026" TEXT="hier aber ungünstig — wir schneiden Möglichkeiten ab"/>
|
|
<node CREATED="1670283795387" ID="ID_980739299" MODIFIED="1670283813301" TEXT="nicht klar ob wir diese Möglichkeiten auch handhaben können"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670283872465" ID="ID_1585241919" MODIFIED="1670376488285" TEXT="möglicher Umgang mit dieser Situation?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670284011918" ID="ID_1146546548" MODIFIED="1670284021365" TEXT="versuchen, mit dem realen Wert zu rechnen">
|
|
<node CREATED="1670284747694" ID="ID_1625216692" MODIFIED="1670284760926" TEXT="das wird wohl nicht realisierbar sein">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1670284762764" ID="ID_1551749144" MODIFIED="1670284803643" TEXT="vor allem die Berechnung des changeFactor ist hart">
|
|
<node CREATED="1670284805670" ID="ID_822617912" MODIFIED="1670284832879" TEXT="denn die bestehende Metrik kann auch bereits grenzwertig sein"/>
|
|
<node CREATED="1670284841546" ID="ID_1593692519" MODIFIED="1670284867186" TEXT="es können durchaus alle vier Zahlefaktoren teilerfremd sein"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670283950255" ID="ID_1052150725" MODIFIED="1670285128230" TEXT="an dieser Stelle dann auf »ganzen Canvas« ausweiten">
|
|
<node CREATED="1670285064420" ID="ID_563185130" MODIFIED="1670285070703" TEXT="ist keine wirkliche Alternative"/>
|
|
<node CREATED="1670285071507" ID="ID_637749708" MODIFIED="1670285101603" TEXT="denn: wie geht's beim nächsten Mal weiter"/>
|
|
</node>
|
|
<node CREATED="1670283932962" ID="ID_368621922" MODIFIED="1670517297644" TEXT="Zoom-Faktor an der Grenze des Handhabbaren kappen">
|
|
<node CREATED="1670285161615" ID="ID_1178402010" MODIFIED="1670285182257" TEXT="es gibt implizit eine weitere Invariante">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670285183856" ID="ID_1638946901" MODIFIED="1670285196927" TEXT="der Zoom-Faktor darf nämlich nicht giftig werden"/>
|
|
<node CREATED="1670285610802" ID="ID_1302970319" MODIFIED="1670285620774" TEXT="weil damit multipliziert und dividiert wird"/>
|
|
</node>
|
|
<node CREATED="1670285635534" ID="ID_979012602" MODIFIED="1670516948570" TEXT="damit ergibt sich aus der Pixel-Weite eine maximale Canvas-Ausdehnung">
|
|
<linktarget COLOR="#4660c4" DESTINATION="ID_979012602" ENDARROW="Default" ENDINCLINATION="-136;-164;" ID="Arrow_ID_456720693" SOURCE="ID_999425219" STARTARROW="None" STARTINCLINATION="115;6;"/>
|
|
<node CREATED="1670285974347" ID="ID_1007233105" MODIFIED="1670286288243" TEXT="pixel/maxExtension > 1/ LIM_HAZARD"/>
|
|
<node CREATED="1670285726380" ID="ID_1300128015" MODIFIED="1670286035624" TEXT="⟹ maxExtension < pxWidth * (1<<40)"/>
|
|
<node CREATED="1670286048745" ID="ID_735928158" MODIFIED="1670286420499" TEXT="und zwar in µ-Ticks gemessen!">
|
|
<linktarget COLOR="#6ca8d7" DESTINATION="ID_735928158" ENDARROW="Default" ENDINCLINATION="-761;71;" ID="Arrow_ID_907454112" SOURCE="ID_804263127" STARTARROW="None" STARTINCLINATION="1521;-73;"/>
|
|
</node>
|
|
<node CREATED="1670286453362" ID="ID_1224708034" MODIFIED="1670286466277" TEXT="das sind etwa 35 Jahre pro Pixel">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670286467361" ID="ID_1883858304" MODIFIED="1670286472580" TEXT="damit kann ich leben">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1670286557479" ID="ID_1970209350" MODIFIED="1670286579062" TEXT="denn mit ca 250px kann man die ganze Time-Domain ausschöpfen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670285681242" ID="ID_670151068" MODIFIED="1670370844366" TEXT="⟹ diese zusätzliche implizite Invariante muß noch eingearbeitet werden">
|
|
<node CREATED="1670286640826" ID="ID_51850143" MODIFIED="1670286716839" TEXT="es gibt also eine quasi-statische Untergrenze für den Zoomfaktor">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"quasi statisch" meint hier: hängt vom pxWith-Parameter ab, ist aber ansonsten unveränderlich (aber eben keine compile-time Konstante)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670286723855" ID="ID_158367837" MODIFIED="1670370838832" TEXT="diese muß bei jeder Neuermittlung der Metrik durchgesetzt werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670286987710" ID="ID_1721006813" MODIFIED="1670287002982" TEXT="also immer in / nach conformMetricToWindow()"/>
|
|
<node CREATED="1670287008354" ID="ID_1557779177" MODIFIED="1670287369540" TEXT="dies wird immer gefolgt von ensureInvariants()">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670287287334" ID="ID_166391512" MODIFIED="1670287291272" TEXT="das ist zu spät"/>
|
|
<node COLOR="#435e98" CREATED="1670287292244" ID="ID_1347205579" MODIFIED="1670370835889" TEXT="denn die giftige Metrik darf erst gar nicht entstehen">
|
|
<arrowlink COLOR="#7a53c2" DESTINATION="ID_1402443098" ENDARROW="Default" ENDINCLINATION="104;-2;" ID="Arrow_ID_924666177" STARTARROW="None" STARTINCLINATION="-324;17;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670287311529" ID="ID_1402443098" MODIFIED="1670370847816">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also davor eine neue Funktion: <b>conformWindowToMetricLimits</b>(px)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aus praktischen Gründen erfolgt die Rechnung in FSecs, und das ist hier nicht gefährlich, weil der Nenner dieses Wertes in der Metrik-Berechnung nur mit den Pixeln in Berührung kommt
|
|
</p>
|
|
<p>
|
|
Hilfsfunktion maxSaneWinExtension(px) = FSecs{LIM_HAZARD * pxWidth, Time::SCALE};
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#7a53c2" DESTINATION="ID_1402443098" ENDARROW="Default" ENDINCLINATION="104;-2;" ID="Arrow_ID_924666177" SOURCE="ID_1347205579" STARTARROW="None" STARTINCLINATION="-324;17;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670287378272" HGAP="54" ID="ID_1137014082" MODIFIED="1670370387641" TEXT="und zwar immer nur wenn die Fenstergröße manipuliert wird" VSHIFT="18">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670376631305" ID="ID_840249575" MODIFIED="1670516765208" TEXT="setMetic ganz knapp unter dem Metrik-Limit">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670376670692" ID="ID_1841257088" MODIFIED="1670376680228" TEXT="funktioniert an sich genauso gut"/>
|
|
<node COLOR="#435e98" CREATED="1670376680960" FOLDED="true" ID="ID_620447936" MODIFIED="1670516743330" TEXT="Assertion-Failure">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670376702055" ID="ID_1469832654" MODIFIED="1670376729324" TEXT="ENSURE (px_per_sec_<= changedMetric); // bias towards increased window">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1670376703894" ID="ID_263971594" MODIFIED="1670376723327" TEXT="Ursache ist dur = detox (dur);">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1670376742896" ID="ID_824068641" MODIFIED="1670376752323" TEXT="wir quantisieren grundsätzich nach unten"/>
|
|
<node CREATED="1670376753567" ID="ID_1311484746" MODIFIED="1670376778683" TEXT="...und das macht hier tatsächlich das window kleiner"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670376784643" ID="ID_826342965" MODIFIED="1670516712383" TEXT="kann man die Assertion inhaltlich retten?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670513034252" ID="ID_1850302207" MODIFIED="1670513344405" TEXT="nein, aber man kann sie verbessern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...zwar ist der Bias in Richtung auf ein größeres Fenster weiterhin im Code gegeben, aber dieser Fall hier zeigt eben, daß er durch andere Rundungs-Effekte sogar übersteuert werden kann; aber wir können sogar eine stärkere Bedinung errichten, nämlich daß wir nicht zu weit von der Vorgabe abweichen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1670513151296" ID="ID_1024266568" MODIFIED="1670513173265" TEXT="stattdessen nachrechnen, wie weit wir von der Vorgabe abgewichen sind"/>
|
|
<node CREATED="1670513174117" ID="ID_1899476162" MODIFIED="1670513185583" TEXT="und zwar in Bildschirm-Pixel ausdrücken"/>
|
|
<node CREATED="1670513186435" ID="ID_1680999319" MODIFIED="1670513314716" TEXT="dazu müssen wir rückwärts vorgehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit meine ich: ausrechnen wie viele Pixel die jetzt eingestelle Fenstergröße in der ursprünglich geforderten Metrik einnehmen würde.....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670513315788" ID="ID_323106710" MODIFIED="1670516717164" TEXT="Idealerweise solten wir höchstens einen Pixel danebenliegen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670516720740" ID="ID_1472736752" MODIFIED="1670516739986" TEXT="neue Assertion ⟹ erfüllt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670516751855" ID="ID_874152554" MODIFIED="1670516762807" TEXT="Ergebnis wie erwartet und nur minimal justiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670520735802" FOLDED="true" ID="ID_208606753" MODIFIED="1670889954683" TEXT="Pixel-Zahl dann extrem vergrößern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670520761346" ID="ID_159180995" MODIFIED="1670608116400" TEXT="bereits sehr großes Fenster">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670520772342" ID="ID_139525815" MODIFIED="1670608119171" TEXT="sollte erweitert werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1670528324475" ID="ID_681633951" MODIFIED="1670608109444" TEXT="entgleist bereits hier">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670528706677" ID="ID_511512599" MODIFIED="1670528730642" TEXT="zoomFactor * duration">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670528736693" ID="ID_692399777" MODIFIED="1670528752135" TEXT="duration kann im Zähler eine sehr große Zahl haben"/>
|
|
<node CREATED="1670528767251" ID="ID_718316208" MODIFIED="1670528801175" TEXT="zoomFactor ist zwar limitiert..."/>
|
|
<node CREATED="1670528801884" ID="ID_1318256555" MODIFIED="1670528842450" TEXT="aber der Zähler kann MAX_PX_WIDTH haben"/>
|
|
</node>
|
|
<node CREATED="1670529398909" ID="ID_1760275990" MODIFIED="1670529444484" TEXT="kann nicht durch weitere Beschränkungen gelöst werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sofern wir überhaupt relevant große Zeitspannen zulassen wollen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670529488664" ID="ID_1459847631" MODIFIED="1670608100497" TEXT="Aufgabe: pxWidth zuverlässig berechnen">
|
|
<linktarget COLOR="#984981" DESTINATION="ID_1459847631" ENDARROW="Default" ENDINCLINATION="37;46;" ID="Arrow_ID_1118525297" SOURCE="ID_1603322916" STARTARROW="None" STARTINCLINATION="-82;-3;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670529520436" ID="ID_1589666141" MODIFIED="1670529556855" TEXT="Beobachtung: Ergebnis ist quantisiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670530578527" ID="ID_106780218" MODIFIED="1670530592241" TEXT="aufteilen in Pixel für die ganzen Sekunden + den Rest"/>
|
|
<node CREATED="1670533665256" ID="ID_1624584888" MODIFIED="1670533684900" TEXT="letztlich nur Bruchrechnen"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670533759294" ID="ID_1337555507" MODIFIED="1670533795730">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>latente Gefahr</u>: Rest bei <i>giftiger Duration</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#c23775" DESTINATION="ID_1337555507" ENDARROW="Default" ENDINCLINATION="-42;54;" ID="Arrow_ID_222968818" SOURCE="ID_619135931" STARTARROW="None" STARTINCLINATION="-229;-15;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1670533870555" ID="ID_649716018" MODIFIED="1670533882170" TEXT="nach meinem Verständnis ist aber die Duration stets berechnet"/>
|
|
<node CREATED="1670533882974" ID="ID_1544775451" MODIFIED="1670533906598" TEXT="und daher kann der Zähler nicht > LIM_HAZARD sein"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670533969244" ID="ID_509879073" MODIFIED="1670620313585" TEXT="Problem: detox verfälscht die pxWidth">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670534010893" ID="ID_719080732" MODIFIED="1670534023047" TEXT="in conformMetricToWindow(pxWidth)"/>
|
|
<node CREATED="1670534028996" ID="ID_218226232" MODIFIED="1670534040364" TEXT="detox(metric) ist unverzichtbar"/>
|
|
<node COLOR="#338800" CREATED="1670534041313" FOLDED="true" ID="ID_1590617796" MODIFIED="1670608092950" TEXT="muß dann aber korrigieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670535342258" ID="ID_1603322916" MODIFIED="1670535392115" TEXT="kann nun erst mal ein Delta (zuverlässig) ausrechnen">
|
|
<arrowlink COLOR="#984981" DESTINATION="ID_1459847631" ENDARROW="Default" ENDINCLINATION="37;46;" ID="Arrow_ID_1118525297" STARTARROW="None" STARTINCLINATION="-82;-3;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1670535410497" ID="ID_1208592840" MODIFIED="1670535642174" TEXT="pixel = metric * duration"/>
|
|
<node CREATED="1670535643825" ID="ID_1568387866" MODIFIED="1670535934094" TEXT="Ansatz : px + Δ = (mn + δ)/md * dur">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1670535754235" ID="ID_1587392333" MODIFIED="1670535810351" TEXT="mn/md*dur + Δ = md/md*dur + δ/md*dur"/>
|
|
<node CREATED="1670535823465" ID="ID_250829706" MODIFIED="1670607989952" STYLE="bubble" TEXT="⟹ Δ = δ/md*dur ⟺ δ = Δ*md/dur"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670608025807" ID="ID_303221939" MODIFIED="1670608049361" TEXT="ist aber nicht genau">
|
|
<arrowlink COLOR="#f71732" DESTINATION="ID_118806151" ENDARROW="Default" ENDINCLINATION="5;-41;" ID="Arrow_ID_1345035443" STARTARROW="None" STARTINCLINATION="-123;-2;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670536172779" ID="ID_118806151" MODIFIED="1670608043975" TEXT="Vorsicht Divisionsrest!">
|
|
<linktarget COLOR="#f71732" DESTINATION="ID_118806151" ENDARROW="Default" ENDINCLINATION="5;-41;" ID="Arrow_ID_1345035443" SOURCE="ID_303221939" STARTARROW="None" STARTINCLINATION="-123;-2;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#d10909" CREATED="1670607546820" ID="ID_1768315854" MODIFIED="1670607657973" TEXT="habe naiv eingesetzt px = mn/md * dn/dd">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das unterschlägt den Divisionsrest. Oder anders gesagt, die Integer-Division ist keine lineare Funktion, die man einfach so umkehren kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1670536172779" ID="ID_1511677021" MODIFIED="1670539160426" TEXT="Divisionsrest: px + r ≔ mn/md*dur">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1670535823465" ID="ID_1442936314" MODIFIED="1670539218793" TEXT="⟹ Δ+r = δ/md*dur">
|
|
<node CREATED="1670539261437" ID="ID_1632113284" MODIFIED="1670539263858" TEXT="r < 1"/>
|
|
</node>
|
|
<node CREATED="1670539193095" ID="ID_393314988" MODIFIED="1670539228949" TEXT=" ⟺ δ = Δ*md/dur + r*md/dur"/>
|
|
</node>
|
|
<node CREATED="1670547897187" ID="ID_567199472" MODIFIED="1670547982037" TEXT="wobei px = trunc(mn/md*dur)"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1670550198610" ID="ID_108770284" MODIFIED="1670550213350" TEXT="Berechnung wrappt">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670607729254" ID="ID_236985538" MODIFIED="1670607748664" TEXT="kann weder direkt die (an sich linerare) Beziehung umkehren"/>
|
|
<node CREATED="1670607749430" ID="ID_44338618" MODIFIED="1670607760342" TEXT="noch kann ich den modulus berechnen">
|
|
<node CREATED="1670607771857" ID="ID_432964800" MODIFIED="1670607787595" TEXT="mod = (mn*dn) % (md*dd)"/>
|
|
<node CREATED="1670607788343" ID="ID_1369221920" MODIFIED="1670607952820" TEXT="vor allem der erste Faktor könnte wrappen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1670607798845" ID="ID_1832446179" MODIFIED="1670607935324" TEXT="es gibt hier keine Garantien">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anders im Nenner;  md * dd ist garantiert berechenbar, sofern die Duration selber aus einem time::Duration gebildet wurde (und md ist durch das detox() limitiert worden)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670550618233" ID="ID_717977520" MODIFIED="1670550628155" TEXT="hngra">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670598462329" ID="ID_1937499858" MODIFIED="1670608058331" TEXT="Einsicht: Problem liegt bei der Umkehrung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Rechenweg ist hier eine »Einbahnstraße« : durch einen Kniff ist es gelungen die Quatisierung zu berechnen Metrik ⟼ pxWidth. Aber die Umkehrfunktion können wir nicht berechnen, weil es in der Berechnung zu einem Überlauf kommt. Daher können wir die Fehler-Korrektur nicht einfach ausrechnen, weil wir nicht einfach von einen Pixel-Δ auf ein Metrik-Δ zurückrechnen können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1670598658291" ID="ID_215061275" MODIFIED="1670608011680" TEXT="Newton-Iteration könnte ein eleganter Lösungsweg sein">
|
|
<arrowlink COLOR="#758da1" DESTINATION="ID_1617011877" ENDARROW="Default" ENDINCLINATION="-1787;200;" ID="Arrow_ID_1389754977" STARTARROW="None" STARTINCLINATION="-5051;242;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1648160051303" ID="ID_1360701786" MODIFIED="1670600088741" TEXT="setze xₙ ≔ mn und f(xₙ) ≔ trunc{ xₙ * dn/(md*dd) } - sollPx"/>
|
|
<node CREATED="1648160051303" ID="ID_1815070178" MODIFIED="1670600102106" TEXT="xₙ ≔ xₙ - f(xₙ)/f'(xₙ)">
|
|
<node CREATED="1670600262299" ID="ID_200772347" MODIFIED="1670600289470" TEXT="trunc{•} ist nicht differenzierbar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670600297357" ID="ID_1661748842" MODIFIED="1670600371342" TEXT="berechne ersatzweise die nicht-Quantisierte lineare Beziehung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das mag unsinnig erscheinen, aber der Punkt ist, wir können diese lineare Beziehung nur eingeschränkt numerisch berechnen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670601331854" ID="ID_1987937364" MODIFIED="1670601421702" TEXT="aber: f(xₙ) ≔ Δₙ = istPx-sollPx = trunc{ xₙ * dn/(md*dd) } - sollPx"/>
|
|
<node CREATED="1670600125528" ID="ID_44998069" MODIFIED="1670600375236" TEXT="⟹ f'(xₙ) = dn/(md*dd)">
|
|
<node CREATED="1670600381136" ID="ID_1737301130" MODIFIED="1670600391140" TEXT="Faktor md*dd ist zu groß"/>
|
|
<node CREATED="1670600392117" ID="ID_972774071" MODIFIED="1670600415383" TEXT="⟹ Konsequenz: Näherung per floating-point rechnen"/>
|
|
</node>
|
|
<node CREATED="1670600444488" ID="ID_1680948621" MODIFIED="1670608003557" STYLE="bubble" TEXT="Schritt: mnₙ₁ ≔ mnₙ - Δₙ * md*dd / dn"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670600703979" ID="ID_1488808337" MODIFIED="1670600728131" TEXT="effektiv war die erste naive Rechnung ein Newtion-Iterationsschritt"/>
|
|
<node COLOR="#338800" CREATED="1670600731863" ID="ID_186434159" MODIFIED="1670608063458" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670600737086" ID="ID_844920706" MODIFIED="1670608065992" TEXT="Ziel-Test in while-Schleife einbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670602664659" ID="ID_1968097363" MODIFIED="1670608071566" TEXT="Delta und Schritt-Berechnung in floating-point">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670608072601" ID="ID_693088307" MODIFIED="1670608085799" TEXT="Berechnung damit sicher, elegant (und funktioniert auch)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670520779106" ID="ID_442688956" MODIFIED="1670889948185" TEXT="dann nochmal giftigen maximal-Zoom-out">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670615758976" ID="ID_1452400924" MODIFIED="1670890015364" TEXT="erst mal bruteZoom verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1670615776976" ID="ID_1512494689" MODIFIED="1670615803740" TEXT="Fehler im abschlißenden Plausibilitätscheck">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670615806180" ID="ID_619135931" MODIFIED="1670620369556" TEXT="in der Tat: die schrittweise Integer-Division kann auch wrappen">
|
|
<arrowlink COLOR="#c23775" DESTINATION="ID_1337555507" ENDARROW="Default" ENDINCLINATION="-42;54;" ID="Arrow_ID_222968818" STARTARROW="None" STARTINCLINATION="-229;-15;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670615839039" ID="ID_1944815131" MODIFIED="1670615993483" TEXT="dieser Gebrauch hier ist aber klar außerhalb der definierten Grenzen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1670615926323" ID="ID_1960899448" MODIFIED="1670615939582" TEXT="Duration muß aus time::Duration errechnet sein"/>
|
|
<node CREATED="1670615942711" ID="ID_255892393" MODIFIED="1670615951220" TEXT="der ZoomFaktor muß entgiftet sein"/>
|
|
<node CREATED="1670615952000" ID="ID_1758205571" MODIFIED="1670615971194" TEXT="dadurch ist zd*dd handhabbar"/>
|
|
<node CREATED="1670615972022" ID="ID_1327396184" MODIFIED="1670615981992" TEXT="genau das (und Weiteres) ist hier nicht gegeben"/>
|
|
</node>
|
|
<node CREATED="1670615994715" ID="ID_193734845" MODIFIED="1670616015887" TEXT="die vorherige Lösung war besser: näherungsweise Rechnung per floating-point">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670616019359" ID="ID_1695051977" MODIFIED="1670616022048" TEXT="revert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670616045807" ID="ID_1657986247" MODIFIED="1670616133443" TEXT="außerdem: das ist gar nicht was ich testen wollte">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670616061533" ID="ID_1889255548" MODIFIED="1670616137418" TEXT="das wäre ein weiterer guter Testfall">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670616069498" ID="ID_1354086365" MODIFIED="1670616142124" TEXT="aber es ist ein extremes zoom-in">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670616082383" FOLDED="true" ID="ID_156266762" MODIFIED="1670620297299" TEXT="die berechneten Zoom-Faktoren und Durations ändern sich unterwegs ganz kraß">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#435e98" CREATED="1670616117714" ID="ID_309015495" MODIFIED="1670617416589" TEXT="korrekt oder Fehlverhalten?">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1670616704876" ID="ID_1622141133" MODIFIED="1670617395856" TEXT="Untersuchung">
|
|
<node CREATED="1670616712931" ID="ID_1501827077" MODIFIED="1670616746582" TEXT="metricVorher: 0,00000090950401180624"/>
|
|
<node CREATED="1670616748326" ID="ID_367770862" MODIFIED="1670616775054" TEXT="metricGesetzt: 0,00000090949470177293"/>
|
|
<node CREATED="1670616817724" ID="ID_1415764699" MODIFIED="1670616822521" TEXT="changeFactor">
|
|
<node CREATED="1670616823604" ID="ID_1357255245" MODIFIED="1670616824954" TEXT="8738124595203125/8738214042927104"/>
|
|
<node CREATED="1670616832746" ID="ID_1244959877" MODIFIED="1670616837612" TEXT="= 0.99998976361490579406"/>
|
|
</node>
|
|
<node CREATED="1670617088809" ID="ID_1991508385" MODIFIED="1670617093931" TEXT="durVorher: 109951052826,533333"/>
|
|
<node CREATED="1670617154682" ID="ID_225306013" MODIFIED="1670617200454" TEXT="durModifiziert">
|
|
<node CREATED="1670617174581" ID="ID_969572944" MODIFIED="1670617177190" TEXT="2054375346307858432/7405988284081966813"/>
|
|
<node CREATED="1670617161148" ID="ID_1958223126" MODIFIED="1670617162826" TEXT="= 0,27739381531610337409"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#cd158d" CREATED="1670617179460" ID="ID_1631410208" MODIFIED="1670617208435" TEXT="tja">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670617402798" ID="ID_30984099" MODIFIED="1670618258486">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eindeutig: <b>wrap-around</b> in der relativen Änderung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670617418716" ID="ID_520825252" MODIFIED="1670617441582" TEXT="relative Anwendung des Zoom-Faktors scheitert">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670617477125" ID="ID_1008445724" MODIFIED="1670617487798" TEXT="auch detox() hie und da hilft nix"/>
|
|
<node CREATED="1670617500514" ID="ID_42571289" MODIFIED="1670617536811" TEXT="grade wenn Duration groß ist reicht detox() nicht"/>
|
|
<node CREATED="1670617542996" ID="ID_890256504" MODIFIED="1670617548121" TEXT="...und ist außerdem ungenau"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670617465750" ID="ID_1125263407" MODIFIED="1670618244591" TEXT="ist dieser Ansatz überhaupt sinnvoll">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670617550570" ID="ID_794382292" MODIFIED="1670617586580" TEXT="dieser Rechenweg stammt noch aus der initialien Implementierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...welche ich inzwischen nahezu komplett einmal umgepflügt habe...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670617587918" ID="ID_1941807837" MODIFIED="1670617700006" TEXT="auf den ersten Blick cool...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1670617617322" ID="ID_154517336" MODIFIED="1670617693674" TEXT="aber numerisch ein Albtraum!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil hier...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
zum Einen eine sehr große Zahl auf einen beliebigen Bruchfaktor trifft
|
|
</li>
|
|
<li>
|
|
und außerdem als Resultat eine Beliebige Zahl entsteht, die nicht auf Time::SCALE quantisiert ist
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670617722212" ID="ID_552344182" MODIFIED="1670618342028">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>und <b>redundant</b></u>: macht nicht <font face="Monospaced" color="#461bac">conformWindowToMetric()</font>  inzwischen genau dassselbe??
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#3489d0" DESTINATION="ID_1728003116" ENDARROW="Default" ENDINCLINATION="7;-26;" ID="Arrow_ID_32836248" STARTARROW="None" STARTINCLINATION="-90;3;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670617949506" ID="ID_1728003116" MODIFIED="1670618335701" TEXT="implementieren ohne Rückgrif auf mutatDuration()">
|
|
<linktarget COLOR="#3489d0" DESTINATION="ID_1728003116" ENDARROW="Default" ENDINCLINATION="7;-26;" ID="Arrow_ID_32836248" SOURCE="ID_552344182" STARTARROW="None" STARTINCLINATION="-90;3;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670618047801" ID="ID_981414972" MODIFIED="1670618077348" TEXT="puh... da fällt ja fast alles weg">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1670618058280" ID="ID_1146416916" MODIFIED="1670618073226" TEXT="und die ganzen Fallen, um die ich mich so geplagt habe">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1670618082836" ID="ID_958310234" MODIFIED="1670618112665" TEXT="was zusätzlich bleibt, ist nur die Limitierung der Metrik">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1670618093994" ID="ID_833295341" MODIFIED="1670618108468" TEXT="die allerdings ist eine Errungenschaft!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670618161449" ID="ID_676303735" MODIFIED="1670618174884" TEXT="kaum macht ma's richtig, schon funktioniert's">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1670618176639" ID="ID_393011013" MODIFIED="1670618207065">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und die Testsuite ist auf Anhieb <b><font color="#0ba911">GRÜN</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670618211155" ID="ID_1878857756" MODIFIED="1670618231508" TEXT="wie gut, daß ich betreits so viele penible Tests gebaut habe">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670620383399" FOLDED="true" ID="ID_674544235" MODIFIED="1670642115198" TEXT="hätte Zoom auf gesamten Canvas erwartet">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1670620405080" ID="ID_1202192964" MODIFIED="1670620418967" TEXT="...nachdem jetzt die Zahl der Pixel so drastisch erhöht wurde"/>
|
|
<node CREATED="1670621505792" ID="ID_645635162" MODIFIED="1670621528305" TEXT="aber der definierte Grenzfaktor verhindert das">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670621532941" ID="ID_1641685049" MODIFIED="1670641908692" TEXT="ist der Grenzfaktor korrekt berechnet?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670621551706" ID="ID_804263127" MODIFIED="1670621631745" TEXT="konzeptionell hatte ich etwas Anderes in Erinnerung">
|
|
<arrowlink COLOR="#6ca8d7" DESTINATION="ID_735928158" ENDARROW="Default" ENDINCLINATION="-761;71;" ID="Arrow_ID_907454112" STARTARROW="None" STARTINCLINATION="1521;-73;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670623877667" ID="ID_1836625419" MODIFIED="1670641911673" TEXT="möglicherweise genau um Time::SCALE zu klein?">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1670629795767" ID="ID_1040393126" MODIFIED="1670629827889" TEXT="der Nenner Time::SCALE ist nämlich in dem Fall harmlos (da pxWidth limitiert ist)"/>
|
|
<node CREATED="1670629829067" ID="ID_1784755741" MODIFIED="1670629843428" TEXT="aber er macht das Ergebnis um den Fakror 1Mio größer"/>
|
|
<node CREATED="1670629845864" ID="ID_1290369344" MODIFIED="1670629860659" TEXT="und limitiert genau dadurch den minimalen Zoom"/>
|
|
<node CREATED="1670629897993" ID="ID_652419307" MODIFIED="1670629969742" TEXT="1 / LIM_HAZARD wäre das Extremum">
|
|
<arrowlink COLOR="#549dd2" DESTINATION="ID_1085901724" ENDARROW="Default" ENDINCLINATION="53;-82;" ID="Arrow_ID_292029179" STARTARROW="None" STARTINCLINATION="-212;16;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670629923629" ID="ID_1085901724" MODIFIED="1670641895675" TEXT="versuchen, das Limit um 1e-6 abzusenken">
|
|
<linktarget COLOR="#549dd2" DESTINATION="ID_1085901724" ENDARROW="Default" ENDINCLINATION="53;-82;" ID="Arrow_ID_292029179" SOURCE="ID_652419307" STARTARROW="None" STARTINCLINATION="-212;16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1670629990253" ID="ID_1122755361" MODIFIED="1670890039381" TEXT="ENSURE_matchesExpectedPixWidth scheitert">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670629999164" ID="ID_1312554244" MODIFIED="1670630059800" TEXT="und zwar mit interessanten (realistischen) Werten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ZoomWindow: established size or metric misses expectation by more than 1px. 3px != 0.279620 expected pixel.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670631017435" ID="ID_1279940239" MODIFIED="1670634674575" TEXT="Beobachtung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1670634343385" ID="ID_284249821" MODIFIED="1670634414906" TEXT="detox(changedMetric) macht nix">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da die Metrik ja limitiert wurde und damit per definitionem auch sauber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670631027193" ID="ID_1715093187" MODIFIED="1670631034852" TEXT="dur = 3* LIM_HAZARD"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670631036152" ID="ID_824462335" MODIFIED="1670634653392" TEXT="ist größer als MAX_TIMESPAN und wird limitiert">
|
|
<linktarget COLOR="#de3b4d" DESTINATION="ID_824462335" ENDARROW="Default" ENDINCLINATION="507;0;" ID="Arrow_ID_79951922" SOURCE="ID_1912544646" STARTARROW="Default" STARTINCLINATION="507;0;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1670631144522" ID="ID_1178539358" MODIFIED="1670631160644" TEXT="detox(dur) läuft dann in das untere Limit für den quantiser = 64"/>
|
|
<node CREATED="1670631354782" ID="ID_1215630500" MODIFIED="1670633662153" TEXT="der Fehler dadurch ist kleiner als 1 sec und relativ irre klein (1e-14)"/>
|
|
<node COLOR="#435e98" CREATED="1670631820765" ID="ID_1612035545" MODIFIED="1670632327145" TEXT="aber TimeVar limitiert">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670631831417" ID="ID_1807731566" MODIFIED="1670631837782" TEXT="umgewandelter Wert: 614891469123640625"/>
|
|
<node CREATED="1670631861403" ID="ID_1701766180" MODIFIED="1670631953102" TEXT="theoretischer Wert: 614891469123651720"/>
|
|
<node CREATED="1670631996436" ID="ID_327677153" MODIFIED="1670632023685" TEXT="limitierter Zeitpunkt: 307445734561825860"/>
|
|
<node COLOR="#338800" CREATED="1670632336743" ID="ID_769313456" MODIFIED="1670632349302" TEXT="Fix: Umwandlung über Duration(FSecs)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670633143989" ID="ID_1654804140" MODIFIED="1670633155150" TEXT="conformWindowToMetric(3px)">
|
|
<node CREATED="1670633164402" ID="ID_208283454" MODIFIED="1670633165812" TEXT="Rat adjMetric = detox (Rat(pxWidth) / dur);"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670633167112" ID="ID_404249260" MODIFIED="1670633316053" TEXT="detox() führt hier einen starken Fehler ein">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670633198943" ID="ID_1237559681" MODIFIED="1670633230283" TEXT="vorher: 192/39353054023913"/>
|
|
<node CREATED="1670633202891" ID="ID_34394013" MODIFIED="1670633262719" TEXT="nachher: 5/1229782938247"/>
|
|
<node CREATED="1670633305726" ID="ID_841098021" MODIFIED="1670633311104" TEXT="16% Fehler"/>
|
|
<node CREATED="1670633355551" ID="ID_86750972" MODIFIED="1670633370881" TEXT="Grund: der kleine Zähler wegen kleiner Pixelzahl"/>
|
|
</node>
|
|
<node CREATED="1670633496181" ID="ID_1991750411" MODIFIED="1670633509494" TEXT="nachjustierte Metrik">
|
|
<node CREATED="1670633510314" ID="ID_474285004" MODIFIED="1670633512214" TEXT="6/1229782938247"/>
|
|
<node CREATED="1670633548900" ID="ID_1038736733" MODIFIED="1670633568254" TEXT="viel näher am Wert vor detox()"/>
|
|
<node CREATED="1670633579125" ID="ID_330672165" MODIFIED="1670633590883" TEXT="Fehlerfaktor: nur noch 1e-13"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670634446738" ID="ID_335582946" MODIFIED="1670634451077" TEXT="Gesamtresultat">
|
|
<node CREATED="1670634452282" ID="ID_695823259" MODIFIED="1670634564479" TEXT="geforderte Metrik: 1/1099511627776 = 9.09e-13"/>
|
|
<node CREATED="1670634484934" ID="ID_186085154" MODIFIED="1670634549193" TEXT="resultiernde Metrik: 6/1229782938247 = 1.87e-12"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670634566275" ID="ID_16315489" MODIFIED="1670634586577" TEXT="das ist natürlich viel zu weit weg">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670634593967" ID="ID_213992089" MODIFIED="1670634599258" TEXT="Fehler 430%"/>
|
|
<node CREATED="1670634622307" ID="ID_1912544646" MODIFIED="1670634640149" TEXT="Grund ist aber kein Rechenfehler....">
|
|
<arrowlink COLOR="#de3b4d" DESTINATION="ID_824462335" ENDARROW="Default" ENDINCLINATION="507;0;" ID="Arrow_ID_79951922" STARTARROW="Default" STARTINCLINATION="507;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670634676452" ID="ID_829552595" MODIFIED="1670642079860">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Grund</b> sind die expliziten <i>Limitierungen </i>in dieser Funktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#6d669c" DESTINATION="ID_829552595" ENDARROW="Default" ENDINCLINATION="299;14;" ID="Arrow_ID_166387953" SOURCE="ID_1376379301" STARTARROW="None" STARTINCLINATION="107;-4;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1670635244880" ID="ID_873866162" MODIFIED="1670635272173" TEXT="nicht klar ob man diese Assertion aufrecht erhalten kann">
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#435e98" CREATED="1670890065771" HGAP="22" ID="ID_313809624" MODIFIED="1670890076308" TEXT="letztlich: ja" VSHIFT="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670634800459" ID="ID_1764699375" MODIFIED="1670634819881" TEXT="abgesehen davon würde die Rechnung sogar mit diesen extremen Werten funktionieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1670634821458" ID="ID_343578534" MODIFIED="1670634835363" TEXT="das liegt vor allem an dem Nachjustieren per Newton"/>
|
|
<node CREATED="1670634842378" ID="ID_1192611860" MODIFIED="1670635459431" TEXT="detox() würde hier wegen dem kleinen Zähler schon zu extremen Fehlern führen">
|
|
<arrowlink COLOR="#f9ffa8" DESTINATION="ID_1107044319" ENDARROW="Default" ENDINCLINATION="291;11;" ID="Arrow_ID_1783361555" STARTARROW="None" STARTINCLINATION="-36;103;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670635294357" ID="ID_1940319351" MODIFIED="1670642085976" TEXT="Kompromiß: Faktor 1000">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670635326013" ID="ID_1487818131" MODIFIED="1670635342383" TEXT="liegt zwischen den ausgetesteten Grenzen"/>
|
|
<node CREATED="1670635343499" ID="ID_641939740" MODIFIED="1670635360580" TEXT="wäre immer noch grade ausreichend groß">
|
|
<node CREATED="1670635361856" ID="ID_1028559962" MODIFIED="1670635368331" TEXT="wenige Pixel: beschränkte Domäne"/>
|
|
<node CREATED="1670635369111" ID="ID_733591685" MODIFIED="1670635384681" TEXT="1000 Pixel : kann ganze Zeitdomäne darstellen"/>
|
|
</node>
|
|
<node CREATED="1670635388270" ID="ID_1107044319" MODIFIED="1670635464001" TEXT="Abstand vom Quantisierer 1000 mal größer ⟹ detox() arbeitet geschmeidiger">
|
|
<linktarget COLOR="#f9ffa8" DESTINATION="ID_1107044319" ENDARROW="Default" ENDINCLINATION="291;11;" ID="Arrow_ID_1783361555" SOURCE="ID_1192611860" STARTARROW="None" STARTINCLINATION="-36;103;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670638029954" ID="ID_1190734639" MODIFIED="1670638077699" TEXT="maxSaneWindowExtension(MAX_PX_WIDTH) wird zu groß">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670638079529" ID="ID_1748017185" MODIFIED="1670638086064" TEXT="als FSecs noch darstellbar"/>
|
|
<node CREATED="1670638086722" ID="ID_1899582755" MODIFIED="1670638102317" TEXT="aber die Umwandlung in TimeValue scheitert"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670641927167" ID="ID_623913340" MODIFIED="1670641959044" TEXT="direkt hier die Limitierung auf MAX_TIMESPAN">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670641960810" ID="ID_1647554495" MODIFIED="1670641975196" TEXT="damit gefährliche Werte überhaupt nirgends mehr in die Rechnung kommen"/>
|
|
<node CREATED="1670641975904" ID="ID_977206807" MODIFIED="1670641988890" TEXT="sollte sich unter dem Strich genauso verhalten (wie wenn wir später limitieren)"/>
|
|
<node CREATED="1670641992206" ID="ID_1376379301" MODIFIED="1670642079860" TEXT="das Problem mit der nachträglichen Domain-Beschränkung ist „unter den Teppich gekehrt“">
|
|
<arrowlink COLOR="#6d669c" DESTINATION="ID_829552595" ENDARROW="Default" ENDINCLINATION="299;14;" ID="Arrow_ID_166387953" STARTARROW="None" STARTINCLINATION="107;-4;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670642102191" ID="ID_1301915764" MODIFIED="1670642109934" TEXT="nun geht der Zoom auf den ganzen Canvas">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670642126767" ID="ID_235330604" MODIFIED="1670642131347" TEXT="Testdaten anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670642140314" ID="ID_846585763" MODIFIED="1670889815781" TEXT="bruteZoom verhält sich aber sonderbar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670642186191" ID="ID_1230929067" MODIFIED="1670642222176" TEXT="Fenster vorher auf Max">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670642203289" FOLDED="true" ID="ID_415548658" MODIFIED="1670889812462" TEXT="danach Fenster minimal verkleinert">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1670682209051" ID="ID_1053497195" MODIFIED="1670684264281" TEXT="Beobachtung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1670682213786" ID="ID_8161854" MODIFIED="1670682223677" TEXT="Zoom-Faktor wird wie erwartet gekappt"/>
|
|
<node CREATED="1670682224409" ID="ID_386983711" MODIFIED="1670682240570" TEXT="detox() führt zu signifikanter Änderung"/>
|
|
<node CREATED="1670682241254" ID="ID_1153651731" MODIFIED="1670682266424" TEXT="aber Metrik ist dadurch kleiner und resultierende Duration größer Limit"/>
|
|
<node CREATED="1670682277170" ID="ID_1708537757" MODIFIED="1670682289524" TEXT="conformWindowToMetric(Rat)">
|
|
<node CREATED="1670682296535" ID="ID_1090940166" MODIFIED="1670682331228" TEXT="metric.in: 305175/1876499844737"/>
|
|
<node CREATED="1670682434788" ID="ID_1588977532" MODIFIED="1670682452025" TEXT="dur ergibt sich > MAX_TIMESPAN">
|
|
<node CREATED="1670682454651" ID="ID_1197083606" MODIFIED="1670682471813" TEXT="7505999378948000/12207 = 614893043249,61087900385024985664"/>
|
|
<node CREATED="1670682520681" ID="ID_1147025950" MODIFIED="1670682612647" TEXT="15372286728091293/25000 =614891469123,65172">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1147025950" ENDARROW="Default" ENDINCLINATION="-14;28;" ID="Arrow_ID_360490716" SOURCE="ID_508324854" STARTARROW="None" STARTINCLINATION="158;13;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670682575586" ID="ID_508324854" MODIFIED="1670682612647" TEXT="⟶ wird auf MAX_TIMESPAN gesetzt">
|
|
<arrowlink DESTINATION="ID_1147025950" ENDARROW="Default" ENDINCLINATION="-14;28;" ID="Arrow_ID_360490716" STARTARROW="None" STARTINCLINATION="158;13;"/>
|
|
</node>
|
|
<node CREATED="1670682736516" ID="ID_1333476908" MODIFIED="1670684329873" TEXT="weiteres detox(dur)">
|
|
<arrowlink COLOR="#ff1900" DESTINATION="ID_1464666749" ENDARROW="Default" ENDINCLINATION="90;-19;" ID="Arrow_ID_1868007293" STARTARROW="None" STARTINCLINATION="-100;12;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670682766512" HGAP="123" ID="ID_1323866380" MODIFIED="1670682821052" TEXT="39353054023913/64 = 614891469123,640625" VSHIFT="-5"/>
|
|
<node CREATED="1670682842974" HGAP="30" ID="ID_787436737" MODIFIED="1670682866149" TEXT="das ist bereits der Wert den wir im Ergebnis sehen" VSHIFT="4">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670683945906" ID="ID_1283272835" MODIFIED="1670683949742" TEXT="errechnete Metrik">
|
|
<node CREATED="1670683951354" HGAP="42" ID="ID_1942870047" MODIFIED="1670684168247" TEXT="199999/1229782938247 = 0,00000016262951272124" VSHIFT="1"/>
|
|
<node CREATED="1670683995492" HGAP="24" ID="ID_254998507" MODIFIED="1670684159760" TEXT="in: 305175/1876499844737 = 0,00000016262990953925" VSHIFT="1"/>
|
|
<node CREATED="1670684113164" ID="ID_1747248918" MODIFIED="1670684190766" TEXT="fin: 200000/1229782938247 = 0,00000016263032587287"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670684285301" FOLDED="true" ID="ID_1464666749" MODIFIED="1670684347077" TEXT="Grund ist das nachgeschaltete detox(dur)">
|
|
<linktarget COLOR="#ff1900" DESTINATION="ID_1464666749" ENDARROW="Default" ENDINCLINATION="90;-19;" ID="Arrow_ID_1868007293" SOURCE="ID_1333476908" STARTARROW="None" STARTINCLINATION="-100;12;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1670684550969" ID="ID_880239933" MODIFIED="1670684603143" TEXT="seinerzeit eingeführt wegen Integer-wrap in der µ-Tick-Quantisierung"/>
|
|
<node CREATED="1670684604442" ID="ID_1823756460" MODIFIED="1670684622968" TEXT="dieses Problem habe ich aber später analog zu detox() gelöst"/>
|
|
<node COLOR="#435e98" CREATED="1670684628318" ID="ID_1042201800" MODIFIED="1670695155347">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bleibt noch der Belang: die Duration soll hier auf µ-Tick <b>aufgerundet</b>  werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1670693333199" ID="ID_1981781381" MODIFIED="1670694655272" TEXT="die bestehende Lösung »wasserdicht« machen">
|
|
<linktarget COLOR="#50a780" DESTINATION="ID_1981781381" ENDARROW="Default" ENDINCLINATION="1222;-1794;" ID="Arrow_ID_276369750" SOURCE="ID_396828585" STARTARROW="None" STARTINCLINATION="477;23;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1670693356652" ID="ID_1296124851" MODIFIED="1670693373385" TEXT="isMicroGridAligned(dur) könnte wrappen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670693374569" ID="ID_1577391935" MODIFIED="1670693466487" TEXT="aber nur weil es naiv/generisch implementiert ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(num * Time::SCALE) % den == 0
|
|
</p>
|
|
<p>
|
|
Das ist zwar offensichtlich richtig, erlaubt aber als Solches noch keine weiteren Schlüsse, sofern man über num/den nichts weiter weiß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670693469133" ID="ID_20864170" MODIFIED="1670693499840" TEXT="Betrachte stattdessen die re-Quantisierung den/num ⟼ auf u">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1670693504734" ID="ID_259327398" MODIFIED="1670693517501" TEXT="generische Division: den/num = i + r/den"/>
|
|
<node CREATED="1670693522229" ID="ID_747418277" MODIFIED="1670693531800" TEXT="dann erweitern mit * u/u"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670693537115" ID="ID_1681141223" MODIFIED="1670693594564" TEXT="u*i + r* u/den muß ganzzahlig sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1670693554097" ID="ID_269924016" MODIFIED="1670693565331" TEXT="r/den ist gebrochen per Ansatz(Divisionsrest)"/>
|
|
<node COLOR="#435e98" CREATED="1670693573502" ID="ID_1720542045" MODIFIED="1670693599139" TEXT="⟹ u/den muß ohne Rest aufgehen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670693619440" ID="ID_734762923" MODIFIED="1670693633898" TEXT="u % den kann man stets gefahrlos berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670693675833" ID="ID_1405525825" MODIFIED="1670695147960" TEXT="Alternative">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1670693681739" ID="ID_59748398" MODIFIED="1670694770304" TEXT="hatte ich mir schon neulich der Länge nach überlegt....">
|
|
<arrowlink COLOR="#6989a3" DESTINATION="ID_1785911993" ENDARROW="Default" ENDINCLINATION="972;1311;" ID="Arrow_ID_993002191" STARTARROW="None" STARTINCLINATION="1011;-3697;"/>
|
|
</node>
|
|
<node CREATED="1670694912251" ID="ID_1739440365" LINK="#ID_324128019" MODIFIED="1670695001317" TEXT="Alternative: ULP aufschlagen — ist numerisch nicht durchführbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das geht in Floating-Point aber eben grade nicht in Integer-Bruchrechnung; ein ULP ist der <i>»maximal giftige Bruch«</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670695006358" ID="ID_178508700" MODIFIED="1670695122062" TEXT="Alternative: Umrechnen und zurückrechnen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670695036426" ID="ID_1096226415" MODIFIED="1670695043701" TEXT="und dann muß man immer noch die Differenz erkennen"/>
|
|
<node CREATED="1670695044386" ID="ID_1440113563" MODIFIED="1670695056972" TEXT="das kann auch entgleisen (wenn man's falsch macht)"/>
|
|
<node CREATED="1670695067366" ID="ID_1511491697" MODIFIED="1670695119208" TEXT="und wäre effektiv genauso wie die bestehende Lösung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
man ruft eine Detektor-Funktion auf
|
|
</li>
|
|
<li>
|
|
man inkrementiert die quantisierte Variante
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670695125327" ID="ID_91649195" MODIFIED="1670695142557">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das hier ist die <b>beste Alternative</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670686892666" ID="ID_663041240" MODIFIED="1670689470564" TEXT="und : placeWindowRelativeToAnchor (dur) erfordert eine µ-Tick-quantisierte Duration">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sonst kann man eine fehlerfreie Kalkulation nicht garantieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1670688407583" ID="ID_802069957" MODIFIED="1670688422028" TEXT="das läßt sich aber beheben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670688425020" ID="ID_1795384448" MODIFIED="1670689441040" TEXT="und zwar durch eine Verbesserung von scaleSafe">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670688441890" ID="ID_1195772525" MODIFIED="1670688571570" TEXT="bisher hat scaleSafe di µ-Tick-Quantisierung fest vorausgesetzt"/>
|
|
<node COLOR="#338800" CREATED="1670688463136" ID="ID_1765522524" MODIFIED="1670689380463" TEXT="durch expliziten Check kann man hier eine falsche Rechnung verhindern">
|
|
<linktarget COLOR="#4a9197" DESTINATION="ID_1765522524" ENDARROW="Default" ENDINCLINATION="-650;0;" ID="Arrow_ID_863565881" SOURCE="ID_1754365321" STARTARROW="None" STARTINCLINATION="255;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670688488686" ID="ID_66504136" MODIFIED="1670689395158" TEXT="das krezuweise Setup der Fälle garantiert eine Lösung">
|
|
<arrowlink COLOR="#5365c2" DESTINATION="ID_69967327" ENDARROW="Default" ENDINCLINATION="196;-673;" ID="Arrow_ID_33256420" STARTARROW="None" STARTINCLINATION="-593;729;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670689449188" ID="ID_1579474968" MODIFIED="1670689473897" TEXT="damit könnte ich mit jeder giftigen Duration einsteigen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670695220102" ID="ID_389130735" MODIFIED="1670889808508" TEXT="Fazit: das nachgeschaltete detox(dur) kann jetzt gefahrlos wegfallen">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#435e98" CREATED="1670695711835" FOLDED="true" ID="ID_180269191" MODIFIED="1670889449190" TEXT="Abweichungen bei den letzten Extrem-Tests">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670695786581" ID="ID_1444004105" MODIFIED="1670695788153" TEXT="win.setMetric (1001_r/LIM_HAZARD)"/>
|
|
<node CREATED="1670695791701" ID="ID_1934884504" MODIFIED="1670695802439" TEXT="Duration nur auf den letzten 3 Stellen größer"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670695809730" ID="ID_1755203527" MODIFIED="1670816905413" TEXT="aber Metrik-Fator weicht sehr deutlich ab">
|
|
<arrowlink COLOR="#9a2652" DESTINATION="ID_946682751" ENDARROW="Default" ENDINCLINATION="-244;-11;" ID="Arrow_ID_508831862" STARTARROW="None" STARTINCLINATION="4;65;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670695844350" ID="ID_862469141" MODIFIED="1670695963722" TEXT="vorher: 750/823809910921 = 0,00000000091040419647"/>
|
|
<node CREATED="1670695862235" ID="ID_602512673" MODIFIED="1670695957130" TEXT="nachher: 1952/1609003732267 = 0,00000000121317307154"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670697214513" ID="ID_1548423209" MODIFIED="1670816868146" TEXT="Problem ist die Newton-Approximation">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670697242478" ID="ID_1694286199" MODIFIED="1670697275809" TEXT="hier haben wir sehr große Quantisierungs-Stufen (nur insges. 3 Pixel)"/>
|
|
<node CREATED="1670697276989" ID="ID_1309607221" MODIFIED="1670697310068" TEXT="die Approximation ist zufrieden, wenn sie die Pixel-Zahl "erwischt""/>
|
|
<node CREATED="1670697311136" ID="ID_1925008467" MODIFIED="1670697312348" TEXT="(selbst wenn die Metrik viel zu groß ist)"/>
|
|
<node CREATED="1670697313432" ID="ID_398787454" MODIFIED="1670697327818" TEXT="von der Ergebnis-Metrik wird nicht mehr auf die Duration zurückgerechnet"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670697328710" FOLDED="true" ID="ID_946682751" MODIFIED="1670889921456" TEXT="pxWidth*Metric würde etwas deutlich Anderes ergeben">
|
|
<linktarget COLOR="#9a2652" DESTINATION="ID_946682751" ENDARROW="Default" ENDINCLINATION="-244;-11;" ID="Arrow_ID_508831862" SOURCE="ID_1755203527" STARTARROW="None" STARTINCLINATION="4;65;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670703907239" ID="ID_1136727655" MODIFIED="1670703914898" TEXT="also müssen wir darauf genau optimieren"/>
|
|
<node COLOR="#435e98" CREATED="1670710050702" ID="ID_59496229" MODIFIED="1670720671013" TEXT="wie genau kann dieses Ziel angesteuert werden?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670710106867" ID="ID_411669983" MODIFIED="1670710132795" TEXT="Berechnung nun ohne trunc{•}"/>
|
|
<node CREATED="1670710118326" ID="ID_696924178" MODIFIED="1670719386236" TEXT="f(xₙ) ≔ Δₙ = resPx-pxWidth = xₙ · dn/(md·dd) - pxWidth"/>
|
|
<node CREATED="1670710479537" ID="ID_1107528495" MODIFIED="1670710480526" TEXT="xₙ₁ ≔ xₙ - f(xₙ)/f'(xₙ)">
|
|
<node CREATED="1670719334585" ID="ID_1012714967" MODIFIED="1670719377864" TEXT="xₙ - Δₙ /dn ·md·dd"/>
|
|
<node CREATED="1670720183545" ID="ID_74252514" MODIFIED="1670720198130" TEXT="Begrenzung durch Integer-Quantisierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670720199199" ID="ID_1527746651" MODIFIED="1670720220936" TEXT="1 < md · dd/dn">
|
|
<node CREATED="1670720224652" ID="ID_1101376604" MODIFIED="1670720248700" TEXT="⟹ md > dn/dd"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670720540449" ID="ID_856703596" MODIFIED="1670720731747" TEXT="das kann eigentlich immer gebrochen werden">
|
|
<arrowlink COLOR="#8989ad" DESTINATION="ID_975354864" ENDARROW="Default" ENDINCLINATION="50;-21;" ID="Arrow_ID_1786066101" STARTARROW="None" STARTINCLINATION="-274;16;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670720590707" ID="ID_981071358" MODIFIED="1670720651637" TEXT="abgesehen davon: Δₙ muß hinreichend klein werden">
|
|
<arrowlink COLOR="#8052a9" DESTINATION="ID_939267839" ENDARROW="Default" ENDINCLINATION="81;-7;" ID="Arrow_ID_527726449" STARTARROW="None" STARTINCLINATION="-91;5;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670720672529" ID="ID_975354864" MODIFIED="1670720722836" TEXT="Konsequenz: floating-Point-Rechnung machen">
|
|
<linktarget COLOR="#8989ad" DESTINATION="ID_975354864" ENDARROW="Default" ENDINCLINATION="50;-21;" ID="Arrow_ID_1786066101" SOURCE="ID_856703596" STARTARROW="None" STARTINCLINATION="-274;16;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670716500389" FOLDED="true" ID="ID_1163092630" MODIFIED="1670889912132" TEXT="Newton-Approximation könnte nicht terminieren">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1670716541578" ID="ID_66975459" MODIFIED="1670716554297" TEXT="wenn man die Ziel-Bandbreite zu eng ansetzt"/>
|
|
<node CREATED="1670716555261" ID="ID_731488848" MODIFIED="1670716577327" TEXT="grundsätzlich sogar überhaupt nicht (im Rahmen der Ganzzahl-Arithmetik)"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670717434415" ID="ID_1457691957" MODIFIED="1670816918779" TEXT="Bedingungen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670717442798" ID="ID_1933929107" MODIFIED="1670717464575" TEXT="Einfache Newton-Approximation (wie implementiert, Zähler variiert)"/>
|
|
<node CREATED="1670717474602" ID="ID_939267839" MODIFIED="1670720645262" TEXT="Vorgabe: Δₙ < 0.1">
|
|
<linktarget COLOR="#8052a9" DESTINATION="ID_939267839" ENDARROW="Default" ENDINCLINATION="81;-7;" ID="Arrow_ID_527726449" SOURCE="ID_981071358" STARTARROW="None" STARTINCLINATION="-91;5;"/>
|
|
</node>
|
|
<node CREATED="1670717504598" ID="ID_1593916172" MODIFIED="1670717538008" TEXT="0.1 > xₙ / md · dn/dd - px">
|
|
<node CREATED="1670717548461" ID="ID_991051485" MODIFIED="1670717614444" TEXT="⟹ (10px +1)/10 · dd/dn > xₙ / md"/>
|
|
<node CREATED="1670717770803" ID="ID_972821680" MODIFIED="1670717794626" TEXT="die Metrik xₙ/md ist nach untern limitiert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670717895146" ID="ID_750112679" MODIFIED="1670717903085" TEXT="effektiv ~ 1e-9"/>
|
|
<node CREATED="1670717904177" ID="ID_850581245" MODIFIED="1670718019510" TEXT="oder etwas kleiner falls MAX_TIMESPAN">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die MAX_TIMESPAN-Limitierung beginnt etwas über 1000px zu greifen; diese Unterschwelle wäre aber px · 1e-14
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670718042479" ID="ID_1099895360" MODIFIED="1670718073999" TEXT="⟹ dd/dn < 1e-9 wird gefärlich">
|
|
<node CREATED="1670718077402" ID="ID_1523825947" MODIFIED="1670718152194" TEXT="der Vorfaktor ist minimal 1.1 (bzw 2 für ganze Pixel)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
minimale Pixel-Zahl 1px. Mit 1/10 Band dann 1.1, mit 1px-Band 2
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670718253667" ID="ID_1543257432" MODIFIED="1670718341579" TEXT="⟹ Duration(sec) > ≈ 1e+9 · px">
|
|
<node CREATED="1670718410758" ID="ID_613768759" MODIFIED="1670718431185" TEXT="≈ 31 Jahre · px"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670718609339" ID="ID_1974821140" MODIFIED="1670719888521" TEXT="hoppla: ≈ maxSaneWinExtension(px)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670718805267" ID="ID_1516871892" MODIFIED="1670718832329" TEXT="bei den maximal erlauben Zeitspannen könnte es grade gefährlich werden">
|
|
<node CREATED="1670718839716" ID="ID_301815780" MODIFIED="1670718852142" TEXT="extrem wenig Pixel"/>
|
|
<node CREATED="1670718867369" ID="ID_1477343330" MODIFIED="1670719045718" TEXT="Zeitspanne knapp an px · LIM_HAZARD/1000"/>
|
|
<node CREATED="1670785753941" ID="ID_347403436" MODIFIED="1670785911020" TEXT="px >=560 ⟹ metric = px*1e6 / Duration::MAX">
|
|
<arrowlink COLOR="#538fce" DESTINATION="ID_1996127148" ENDARROW="Default" ENDINCLINATION="231;-255;" ID="Arrow_ID_764100813" STARTARROW="None" STARTINCLINATION="-483;11;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670719062943" ID="ID_1581529912" MODIFIED="1670719167745" TEXT="die Frage ob 0.1px-Band oder 1px-Band ist demgegenüber zweitrangig (nur Faktor 2)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
will sagen, wenn man das 0.1px-Band zum Absturz bringen kann, dann klappt das mit der doppelten Zeit auch beim 1px-Band
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670719529018" ID="ID_1496087661" MODIFIED="1670816812681" TEXT="Konsequenzen">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#990000" CREATED="1670719549717" ID="ID_864034169" MODIFIED="1670816753143" TEXT="die verfeinerte Rechnung kann umgesetzt werden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#338800" CREATED="1670720748175" ID="ID_1186911543" MODIFIED="1670726404457" TEXT="die ganze Optimierungs-Schleife in double rechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670726407009" ID="ID_1804166411" MODIFIED="1670804460008" TEXT="Aufgabe: sicherstellen daß das Ergebnis auch gerundet im Ziel liegt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670726493421" ID="ID_1608426092" MODIFIED="1670726526180" TEXT="die Pixel-Zahl vor Quantisierung muß etwas über der Marke liegen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1670726578627" ID="ID_1008014521" MODIFIED="1670726664314" TEXT="aber auch dann noch, wenn man die Rechnung mit Integer-Brüchen macht"/>
|
|
<node CREATED="1670726672744" ID="ID_1853957443" MODIFIED="1670726682672" TEXT="Problem hier: das geht nicht in den Feedback ein"/>
|
|
<node COLOR="#990033" CREATED="1670726688101" ID="ID_1472574562" MODIFIED="1670804431578" TEXT="kann man das in den Feedback mit einbauen?">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1670787309172" ID="ID_1428485868" MODIFIED="1670787329673" TEXT="vielleicht könnte man..."/>
|
|
<node CREATED="1670787331622" ID="ID_1654809229" MODIFIED="1670787350911" TEXT="erscheint mir aber der Methode zuwider zu laufen"/>
|
|
</node>
|
|
<node CREATED="1670787359266" ID="ID_680040293" MODIFIED="1670787385643" TEXT="bessere Lösung: vorhandenen Spielraum im Bruch zur Genauigkeitsverbesserung nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670804470398" ID="ID_80318439" MODIFIED="1670816791233" TEXT="Stop: ich bin ein Trottel">
|
|
<arrowlink COLOR="#8f4575" DESTINATION="ID_975395011" ENDARROW="Default" ENDINCLINATION="41;-158;" ID="Arrow_ID_1007214797" STARTARROW="None" STARTINCLINATION="-611;68;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670804496939" ID="ID_1184455321" MODIFIED="1670804511211" TEXT="ach der schöne Newton-Algorithmus....">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1670804513145" ID="ID_877585639" MODIFIED="1670804692975" TEXT="wenn ich ohnehin mit floats rechne, dann kann ich gleich alles mit Floats rechnen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Newton-Approximation kam ja nur ins Spiel, weil ich mit Integer rechnen wollte, in <i>dieser Domain</i> aber die Rechnung nicht umkehren konnte. Im weiteren Kontext betrachtet war das von Anfang an ein Schmuh (und ich habe jetzt schon zwei Tage lang ein dumpfes Gefühl, daß es ein Schmuh ist....)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670804541533" ID="ID_1739055812" MODIFIED="1670804597604" TEXT="da mir ja hier das »ungiftige« Ergebnis so wichtig ist, daß ich erhebliche Fehler in Kauf nehme...">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1670804699664" ID="ID_654656000" MODIFIED="1670804885457" TEXT="und ja — das ist die Prämisse">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Im Regelfall möchte ich die präzise Integer-Bruch-Arithmetik, aber ich möchte die Grenzfälle nahtlos mit integrieren, und nehme für diese Grenzfälle absolut betrachtet erehbliche Fehler in Kauf.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1670804855947" ID="ID_1040358248" MODIFIED="1670804870858" TEXT="also: nur den Ansatz mit dem korrigierten Zähler beibehalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1670719566683" ID="ID_1040949384" MODIFIED="1670816827965" TEXT="empirisch prüfen, ob die Endlosschleife möglich ist">
|
|
<linktarget COLOR="#7d5c62" DESTINATION="ID_1040949384" ENDARROW="Default" ENDINCLINATION="-541;29;" ID="Arrow_ID_1071041256" SOURCE="ID_266339038" STARTARROW="None" STARTINCLINATION="1170;80;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670816836062" ID="ID_851885311" MODIFIED="1670816841537" TEXT="kein Newton mehr!"/>
|
|
<node CREATED="1670816842370" ID="ID_1563827764" MODIFIED="1670816851327" TEXT="⟹ keine Schleife"/>
|
|
<node CREATED="1670816852083" ID="ID_1868207063" MODIFIED="1670816858431" TEXT="kein Deadlock möglich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670816009109" ID="ID_975395011" MODIFIED="1670889443756" TEXT="Optimierung in double ohne Newton...">
|
|
<linktarget COLOR="#8f4575" DESTINATION="ID_975395011" ENDARROW="Default" ENDINCLINATION="41;-158;" ID="Arrow_ID_1007214797" SOURCE="ID_80318439" STARTARROW="None" STARTINCLINATION="-611;68;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670816029198" ID="ID_1452556449" MODIFIED="1670816086216" TEXT="aber gleiches Prinzip">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670816046304" ID="ID_1426435830" MODIFIED="1670816089716" TEXT="Metrik auf Zweierpotenz requantisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670816056231" ID="ID_1728459173" MODIFIED="1670816089715" TEXT="dann den Zähler optimieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670816062869" ID="ID_1276500575" MODIFIED="1670816089715" TEXT="dann soweit möglich hochskalieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670816091978" ID="ID_1568711094" MODIFIED="1670816108432" TEXT="funktioniert gut und mit vertretbarem Fehler">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670816109718" ID="ID_619043266" MODIFIED="1670889738713" TEXT="Fehler: 1 digit im Zähler ⟹ 1‰">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kommt dadurch zustande, daß ich nach dem Hochskalieren i.d.R doch noch einen Rest habe, den ich für Integer-Arithmetik abrunde; damit dann trotzdem die gewünschte (i.d.R. um einen Pixel höhere) Pixelzahl rauskommt, inkrementiere ich die letzte Stelle, und das ist zugleich meine maximale Fehlerschranke. In Extremfällen haben wir im Zähler noch eine 4-stellige Zahl (1000/LIM_HAZARD) und damit etwa 1‰ Fehler maximal. Das ist nicht schön, aber akzeptabel — gemessen daran, daß ich dadruch eine »ungiftige« Metrik sicherstellen kann. Sobald man etwas weg ist von der Unterschranke der Metrik 1000/LIM_HAZARD, wirkt das Nach-Skalieren und Mitnehmen des gebrochenen Anteils viel besser, und der Fehler sinkt drastisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#659bda" DESTINATION="ID_619043266" ENDARROW="Default" ENDINCLINATION="27;148;" ID="Arrow_ID_814014787" SOURCE="ID_1184311307" STARTARROW="None" STARTINCLINATION="154;23;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670816505986" ID="ID_715992496" MODIFIED="1670816655190" TEXT="nahe am Limit kann es zu scheinbar zufälligem Verhalten kommen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670816533446" ID="ID_1029606070" MODIFIED="1670816549353" TEXT="da auf mehreren Ebenen quantisiert wird"/>
|
|
<node CREATED="1670816550292" ID="ID_966482500" MODIFIED="1670816558978" TEXT="Beispiel">
|
|
<node CREATED="1670816572401" ID="ID_528266122" MODIFIED="1670882262212" TEXT="1001_r/(LIM_HAZARD-3)"/>
|
|
<node CREATED="1670816582730" ID="ID_1561405826" MODIFIED="1670816620196" TEXT="Ergebnis 2002_r/(2*LIM_HAZARD)"/>
|
|
<node CREATED="1670816626705" ID="ID_1528211021" MODIFIED="1670816637773" TEXT="das heißt...">
|
|
<node CREATED="1670816638576" ID="ID_1556421449" MODIFIED="1670816644123" TEXT="zoom-out angefordert"/>
|
|
<node CREATED="1670816644903" ID="ID_1804356719" MODIFIED="1670816649571" TEXT="zoom-in bekommen"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1670816710871" ID="ID_817219684" MODIFIED="1670816718496" TEXT="halte ich für unvermeidbar">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670816721077" ID="ID_1346974922" MODIFIED="1670889438465" TEXT="noch im Test dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#990000" CREATED="1670816940056" ID="ID_721415029" MODIFIED="1670889435171" TEXT="Testfall schwer zu finden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670816973011" ID="ID_11852866" MODIFIED="1670816988485" TEXT="ich möchte zoom-out von 1001/LIM_HAZARD"/>
|
|
<node CREATED="1670816990899" ID="ID_838942819" MODIFIED="1670817021017" TEXT="aber das wird immer auf 1001/LIM_HAZARD zurück gerundet"/>
|
|
<node CREATED="1670817026420" ID="ID_425109455" MODIFIED="1670817157515" TEXT="obwohl man theoretisch daran vorbeikommen sollte">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
und zwar mit einer Zahl zwischen 1001/LIM_HAZARD > gesucht > 1000/LIM_HAZARD
|
|
</li>
|
|
<li>
|
|
die resultierende Metrik sollte idealerweise giftig sein
|
|
</li>
|
|
<li>
|
|
aber auch noch Headroom übrig lassen (andernfalls gehen wir in die falsche Richtung)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670889380176" ID="ID_390014316" MODIFIED="1670889436751" TEXT="finde nur einen Tesfall der ohne Optimierung / detox genau aufgeht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
1000_r/LIM_HAZARD * 1024_r/1023
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670889456537" ID="ID_1888005668" MODIFIED="1670889472787" TEXT="nun keine Abweichung mehr: geht exakt ans Maximum">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670785144912" ID="ID_459433908" MODIFIED="1670889480274" TEXT="conformMetricToWindow(px) überarbeiten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670785204059" ID="ID_1114726267" MODIFIED="1670785236008" TEXT="kein "blindes" detox()">
|
|
<node CREATED="1670785240715" ID="ID_795170008" MODIFIED="1670785328509" TEXT="Zievorgabe: so ungiftig wie möglich"/>
|
|
<node CREATED="1670785422813" ID="ID_1124667044" MODIFIED="1670785429400" TEXT="problematisch sind sehr kleine Metriken">
|
|
<node CREATED="1670785873462" ID="ID_1996127148" MODIFIED="1670785905744" TEXT="Limits für Metric">
|
|
<linktarget COLOR="#538fce" DESTINATION="ID_1996127148" ENDARROW="Default" ENDINCLINATION="231;-255;" ID="Arrow_ID_764100813" SOURCE="ID_347403436" STARTARROW="None" STARTINCLINATION="-483;11;"/>
|
|
<node CREATED="1670785753941" ID="ID_1553384977" MODIFIED="1670785826668" TEXT="px >=560 ⟹ metric = px*1e6 / Duration::MAX">
|
|
<node CREATED="1670786467236" ID="ID_1737539122" MODIFIED="1670786496748" TEXT="=9,1073e-10 · px/560"/>
|
|
</node>
|
|
<node CREATED="1670785923384" ID="ID_1777459427" MODIFIED="1670785947961" TEXT="px < 560 ⟹ metric = 1000 / LIM_HAZARD">
|
|
<node CREATED="1670785984449" ID="ID_170764771" MODIFIED="1670785994497" TEXT="= 9,0949e-10"/>
|
|
</node>
|
|
<node CREATED="1670786599846" ID="ID_1314688550" MODIFIED="1670786624720" TEXT="ZOOM_MAX_RESOLUTION = 2*Time::SCALE"/>
|
|
</node>
|
|
<node CREATED="1670786699086" ID="ID_1357536106" MODIFIED="1670786712975" TEXT="kleinsmöglicher nicht-toxischer Wert">
|
|
<node CREATED="1670786714371" ID="ID_690038090" MODIFIED="1670786719462" TEXT="1/LIM_HAZARD"/>
|
|
<node CREATED="1670786720242" ID="ID_1737636488" MODIFIED="1670786727852" TEXT="9,0949e-13"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670786927366" ID="ID_495890468" MODIFIED="1670786950021" TEXT="valide Metrik-Werte müssen niemals toxisch sein">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670786993539" ID="ID_1985716158" MODIFIED="1670787033776" TEXT="stattdessen: requantisieren auf 2-er-Potenz + Resultat im Zähler optimieren"/>
|
|
<node COLOR="#338800" CREATED="1670889501935" ID="ID_608097440" MODIFIED="1670889589637" TEXT="Wichtig: anschließend möglichst hochskalieren, um mehr Genauigkeit mitzunehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670889523827" ID="ID_932462373" MODIFIED="1670889532670" TEXT="geht aber nur im Rahmen des vorhandenen Headroom"/>
|
|
<node CREATED="1670889533466" ID="ID_176906927" MODIFIED="1670889582551" TEXT="spendiere fest einen Faktor 2 als Minimum">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geht, weil die Metrik limitiert ist, insofern ist wenigstens dafür im Extremfall noch ein Bit übrig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670889597369" ID="ID_1674926358" MODIFIED="1670889627058" TEXT="Wenn dann noch ein Rest bleibt ⟹ Zähler inkrementieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670889629266" ID="ID_1009582082" MODIFIED="1670889648092" TEXT="das definiert das Fehler-Limit">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670889650019" ID="ID_1046455083" MODIFIED="1670889667095" TEXT="im worst-case haben wir mindestens einen 4-stelligen Zähler"/>
|
|
<node CREATED="1670889667816" ID="ID_1184311307" MODIFIED="1670889744565" TEXT="also Fehler < 1‰">
|
|
<arrowlink COLOR="#659bda" DESTINATION="ID_619043266" ENDARROW="Default" ENDINCLINATION="27;148;" ID="Arrow_ID_814014787" STARTARROW="None" STARTINCLINATION="154;23;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670889821294" ID="ID_842321492" MODIFIED="1670889891273" TEXT="aufgeklärt: war tückische Falle in der Metrik-Optimierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und der ganze Ansatz mit Newton-Näherung stellte sich als unsinnig heraus; jetzt rechnen wir die Optimierung mit einem Schuß in float, und reizen dann sogar noch den Headroom aus, wodurch die Werte viel genauer werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670889961473" ID="ID_994446883" MODIFIED="1670889977598" TEXT="Testfälle in epischer Breite analysiert und dokumentiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668555072594" ID="ID_742229180" MODIFIED="1671216852441" TEXT="Ansteuern exterm großer Zeit-Positionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670982930768" ID="ID_1528129980" MODIFIED="1670982944610" TEXT="erzeugen mit Start-Pos == Time::MAX">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669475536331" ID="ID_486161883" MODIFIED="1671153173786" TEXT="setVisiblePos mit extremer Time">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669475549345" ID="ID_234786683" MODIFIED="1671216849651" TEXT="setVisiblePos mit extremem Faktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1671153443706" ID="ID_43785368" MODIFIED="1671216714904" TEXT="Rechnung sieht plausibel aus, aber das Ergebnis ist falsch">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1671153472181" ID="ID_1963137458" MODIFIED="1671153492750" TEXT="Offset wird auf MAX_DURATION gekappt (korrekt)"/>
|
|
<node CREATED="1671153500329" ID="ID_983458362" MODIFIED="1671153514062" TEXT="als relativer Pox-Faktor kommt 1 raus (korrekt)"/>
|
|
<node COLOR="#990033" CREATED="1671153518751" ID="ID_180845154" MODIFIED="1671216726077" TEXT="auch partBeforeAnchor wird anscheinend korrekt berechnet?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1671153550626" ID="ID_1354877877" MODIFIED="1671216842541" TEXT="aber visible().end() ist dann nicht Time::MAX">
|
|
<arrowlink COLOR="#c04288" DESTINATION="ID_1578460487" ENDARROW="Default" ENDINCLINATION="61;-23;" ID="Arrow_ID_914471115" STARTARROW="None" STARTINCLINATION="181;11;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671216679413" ID="ID_1318691761" MODIFIED="1671216817689" TEXT="nach „Begradigung“ der Implementierung nun auch korrekt">
|
|
<arrowlink COLOR="#7accc0" DESTINATION="ID_1757084511" ENDARROW="Default" ENDINCLINATION="-271;-16;" ID="Arrow_ID_1766419591" STARTARROW="None" STARTINCLINATION="468;22;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1669479474484" ID="ID_1657847338" MODIFIED="1669479489366" TEXT="alle Mutatoren, die conformWindowToMetric() verwenden">
|
|
<node CREATED="1670520100834" ID="ID_636101408" MODIFIED="1670520114018" TEXT="das sind nicht viele (überraschenderweise)">
|
|
<node CREATED="1670961179624" ID="ID_712008770" MODIFIED="1670961184625" TEXT="mutateScale(Rat)"/>
|
|
<node CREATED="1670520136501" ID="ID_1373384288" MODIFIED="1670520142854" TEXT="mutateDuration(FSecs)"/>
|
|
<node CREATED="1670520143698" ID="ID_113302808" MODIFIED="1670520150597" TEXT="und ensureInvariants()"/>
|
|
</node>
|
|
<node CREATED="1670520153513" ID="ID_574049062" MODIFIED="1670520170810" TEXT="wozu? weil dort das Window anteilig neu positioniert wird"/>
|
|
<node CREATED="1670520176781" ID="ID_171252675" MODIFIED="1670520196129" TEXT="⟹ gefährlich wenn die bestehende Window-Pos gefährlich ist"/>
|
|
<node COLOR="#338800" CREATED="1670520232861" ID="ID_1248431637" MODIFIED="1671153193486" TEXT="Szenario">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670520238693" ID="ID_1734279608" MODIFIED="1670982961594" TEXT="sehr kleines Fenster">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670520245444" ID="ID_428615363" MODIFIED="1671153194914" TEXT="fast aber nicht ganz an Time::MIN">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670520259018" ID="ID_591142628" MODIFIED="1671153197781" TEXT="vergrößern auf Duration::MAX - aWeng">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1671153207589" ID="ID_1801258827" MODIFIED="1671153210390" TEXT="so lala"/>
|
|
<node CREATED="1671153211145" ID="ID_779131227" MODIFIED="1671210849270" TEXT="man bekommt nicht exakt die gesetzte Duration">
|
|
<arrowlink COLOR="#6f6fbd" DESTINATION="ID_854310223" ENDARROW="Default" ENDINCLINATION="140;0;" ID="Arrow_ID_1109327091" STARTARROW="None" STARTINCLINATION="134;8;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#690f14" CREATED="1671153242324" ID="ID_1578460487" MODIFIED="1671216836261" TEXT="geht aber nicht besser, da Zahlen maximal giftig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir rechnen von der Duration auf eine Metrik um, weil wir den Mechanismus zur relativen Positionierung haben wollen. Dieser muß aber detox() verwenden, weil sonst die Division mit der Pixel-Zahl einen numeric-wrap machen würde....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#c04288" DESTINATION="ID_1578460487" ENDARROW="Default" ENDINCLINATION="61;-23;" ID="Arrow_ID_914471115" SOURCE="ID_1354877877" STARTARROW="None" STARTINCLINATION="181;11;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1671153715708" ID="ID_293245647" MODIFIED="1671210765629" TEXT="wirklich nicht?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1671153746581" ID="ID_965916539" MODIFIED="1671153758123" TEXT="wir brauchen doch nur die relative Positionierung"/>
|
|
<node CREATED="1671153758879" ID="ID_318897179" MODIFIED="1671153783226" TEXT="die trickreiche Limitierung und quantisierung ist überflüssig..."/>
|
|
<node COLOR="#435e98" CREATED="1671153783923" ID="ID_1591963678" MODIFIED="1671210763661" TEXT="...weil wir ja schon eine Duration haben!">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671210766716" ID="ID_380651309" MODIFIED="1671210780555" TEXT="also eine unnötige Schleife">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671210784819" ID="ID_1757084511" MODIFIED="1671216807713" TEXT="mutateDuration() direkt implementieren">
|
|
<linktarget COLOR="#7accc0" DESTINATION="ID_1757084511" ENDARROW="Default" ENDINCLINATION="-271;-16;" ID="Arrow_ID_1766419591" SOURCE="ID_1318691761" STARTARROW="None" STARTINCLINATION="468;22;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671210799428" ID="ID_854310223" MODIFIED="1671210890809" STYLE="fork" TEXT="⟹ gesetzte Duration wird nun exakt realisiert">
|
|
<linktarget COLOR="#6f6fbd" DESTINATION="ID_854310223" ENDARROW="Default" ENDINCLINATION="140;0;" ID="Arrow_ID_1109327091" SOURCE="ID_779131227" STARTARROW="None" STARTINCLINATION="134;8;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668555157385" ID="ID_1157546672" MODIFIED="1671235570910" TEXT="Time-wrap nach extremem Offset">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1671224197185" ID="ID_1016259949" MODIFIED="1671235568010" TEXT="offsetVisiblePos wird bereits abgefangen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671224211255" ID="ID_407876103" MODIFIED="1671235569554" TEXT="nudgeVisiblePos ist noch gefährlich">
|
|
<arrowlink COLOR="#d37297" DESTINATION="ID_772154372" ENDARROW="Default" ENDINCLINATION="-1063;-32;" ID="Arrow_ID_1688376810" STARTARROW="None" STARTINCLINATION="918;66;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1671225926047" HGAP="97" ID="ID_1143975886" MODIFIED="1671225950100" TEXT="Ansteuern mit Maximalwerten genügt als Test" VSHIFT="19"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668555183502" ID="ID_1287974241" MODIFIED="1670280063243" TEXT="Einspeisen giftiger Metrik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1669478124298" ID="ID_1987069808" MODIFIED="1669488168358" TEXT="Fall-1 : kappen auf Canvas-Grenzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669478154709" ID="ID_499422673" MODIFIED="1669488173372" TEXT="Fall-2 : hinreichend großer Canvas">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669479930775" ID="ID_196873456" MODIFIED="1670016092876" TEXT="Fall-3 : setVisiblePos mit giftigem faktor">
|
|
<arrowlink COLOR="#8c2958" DESTINATION="ID_171647736" ENDARROW="Default" ENDINCLINATION="103;88;" ID="Arrow_ID_1341085031" STARTARROW="None" STARTINCLINATION="351;-26;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1669682888293" HGAP="67" ID="ID_1431682003" MODIFIED="1670016089041" TEXT="erweist sich als ziemlich schwer unter Kontrolle zu bekommen" VSHIFT="-1">
|
|
<edge COLOR="#01a450"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#338800" CREATED="1670016009463" HGAP="38" ID="ID_413813658" LINK="#ID_264195573" MODIFIED="1670016072649" TEXT="daraus sind nun Support-Funktionen entstanden" VSHIFT="7">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669480019215" ID="ID_930072077" MODIFIED="1670280057047" TEXT="Fall-4 : setVisiblePos mit extrem entfernter Position">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180030777" ID="ID_1319796356" MODIFIED="1671292315206" TEXT="1 µ-Tick">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1671287176378" ID="ID_1489554407" MODIFIED="1671287335758" TEXT="was soll ich hier noch testen?"/>
|
|
<node COLOR="#338800" CREATED="1671287188300" ID="ID_1893630472" MODIFIED="1671287339424" TEXT="wenigstens dokumentieren könnte man das Verhalten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671287208625" ID="ID_1782470121" MODIFIED="1671291588696" TEXT="Scroll-Step soll das Window stets um mindestens 1 µ-Tick bewegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1671287247180" ID="ID_186248922" MODIFIED="1671287327391" TEXT="das ist eine neue Anforderung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1671287277817" ID="ID_1856370622" MODIFIED="1671287319670" TEXT="aber offensichtlich in dieser Situation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es wäre schon überraschend, wenn der Scrollbalken plötzlich nicht mehr reagiert....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1671287255254" ID="ID_1670104161" MODIFIED="1671287269034" TEXT="....wenn ich jetzt nicht getestet hätte....">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671291646626" ID="ID_1133219679" MODIFIED="1671291673767" TEXT="Zoom-Nudge nur im Rahmen der als µ-Tick darstellbaren Größen möglich">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671291593292" ID="ID_603523543" MODIFIED="1671292313793" TEXT="Begrenzung auf ZOOM_MAX_RESOLUTION auch bei sehr vielen Pixeln wirksam">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1671291612706" ID="ID_1061099064" MODIFIED="1671291623193" TEXT="obwohl wir da definitiv mehr darstellen könnten"/>
|
|
<node CREATED="1671292172775" ID="ID_778157874" MODIFIED="1671292310771" TEXT="ich sehe aber keinen Nutzen dafür">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
selbst Sound-Samples sind (absolut betrachet) noch 10.41ms auseinander; solange wir <i>das</i> komfortabel und sauber im GUI darstellen und handhaben können, sind wir fein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180054302" ID="ID_1604190635" MODIFIED="1671324160042" TEXT="1 Pixel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670719662361" ID="ID_1680322812" MODIFIED="1670719685207" TEXT="maximal gefährlich für die Metrik-Berechnung">
|
|
<node COLOR="#990000" CREATED="1670719706106" ID="ID_266339038" MODIFIED="1670889773325" TEXT="Newton-Optimierung möglicherweise ⟘">
|
|
<arrowlink COLOR="#7d5c62" DESTINATION="ID_1040949384" ENDARROW="Default" ENDINCLINATION="-541;29;" ID="Arrow_ID_1071041256" STARTARROW="None" STARTINCLINATION="1170;80;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node COLOR="#435e98" CREATED="1670889780025" ID="ID_584710662" MODIFIED="1670889789485" TEXT="jetzt keine Schleife mehr">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1671294771824" ID="ID_115927706" MODIFIED="1671322048434" TEXT="numeric-wrap entdeckt">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1671295216805" ID="ID_987376979" MODIFIED="1671295239222" TEXT="In der conversion FSecs ⟼ µ-tick"/>
|
|
<node CREATED="1671295240330" ID="ID_1742063347" MODIFIED="1671295249934" TEXT="bei übergroßen Werten">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671322050278" ID="ID_1702542630" MODIFIED="1671322066067" TEXT="Limit in den Konverter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670719689323" ID="ID_794436463" MODIFIED="1670719702317" TEXT="mit möglichst großen Zeiten kombinieren"/>
|
|
<node COLOR="#338800" CREATED="1671294759109" ID="ID_531574116" MODIFIED="1671324166659" TEXT="ähnliche Operationen wie bereits für die giftigen Faktoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671324210414" ID="ID_1973605620" MODIFIED="1671324233682" TEXT="sehr groß skalieren und Limit LIM_HAZARD*1000">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671324243418" ID="ID_596210372" MODIFIED="1671324255033" TEXT="Scroll / Zoom-Nudge">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668264626100" ID="ID_45091906" MODIFIED="1671235896011" TEXT="giftige Brüche">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668264634478" ID="ID_651838862" MODIFIED="1671235708969" TEXT="setMetric (Rat) ⟶ mutateScale (Rat changedMetric)">
|
|
<linktarget COLOR="#e62f5c" DESTINATION="ID_651838862" ENDARROW="Default" ENDINCLINATION="115;-4;" ID="Arrow_ID_1930230162" SOURCE="ID_1257614207" STARTARROW="None" STARTINCLINATION="-189;14;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668270062492" FOLDED="true" ID="ID_1671513743" MODIFIED="1671235854348" TEXT="entgiftungs-Methoden schaffen">
|
|
<linktarget COLOR="#bf0f5b" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="297;-23;" ID="Arrow_ID_389982782" SOURCE="ID_1175951405" STARTARROW="None" STARTINCLINATION="-323;20;"/>
|
|
<linktarget COLOR="#9a858e" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="297;-23;" ID="Arrow_ID_1815772846" SOURCE="ID_148236436" STARTARROW="None" STARTINCLINATION="-292;20;"/>
|
|
<linktarget COLOR="#b18586" DESTINATION="ID_1671513743" ENDARROW="Default" ENDINCLINATION="256;-19;" ID="Arrow_ID_882084800" SOURCE="ID_773636992" STARTARROW="None" STARTINCLINATION="-201;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1668292035888" HGAP="50" ID="ID_511660460" MODIFIED="1668295679206" TEXT="ist das überhaupt möglich" VSHIFT="9">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1668292124740" ID="ID_1232493436" MODIFIED="1668292133321" TEXT="könnte ein Restrisiko bleiben"/>
|
|
<node CREATED="1668292133979" ID="ID_770094379" MODIFIED="1668292156815">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erfordert Analyse <i>aller relevanten </i>Code-Pfade
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1668292396131" ID="ID_7304516" MODIFIED="1668294943464" TEXT="conformWindowToMetric">
|
|
<linktarget COLOR="#c87094" DESTINATION="ID_7304516" ENDARROW="Default" ENDINCLINATION="6;156;" ID="Arrow_ID_1140056910" SOURCE="ID_96983887" STARTARROW="None" STARTINCLINATION="-286;-12;"/>
|
|
<node CREATED="1668293208971" ID="ID_1653636245" MODIFIED="1668293210015" TEXT="dur = Rat(pxWidth) / changedMetric">
|
|
<node CREATED="1668293236069" ID="ID_1127042707" MODIFIED="1668293258728" TEXT="⟹ changedMetric.denominator() * pxWidth < INT_MAX"/>
|
|
</node>
|
|
<node CREATED="1668293281511" ID="ID_1060313609" MODIFIED="1668293290147" TEXT="isMicroGridAligned(dur)">
|
|
<node CREATED="1668293329717" ID="ID_1188353936" MODIFIED="1668293343029" TEXT="hier definiert der gleiche numerator() die Grenze"/>
|
|
</node>
|
|
<node CREATED="1668293649111" ID="ID_944232790" MODIFIED="1668293651579" TEXT="placeWindowRelativeToAnchor">
|
|
<node CREATED="1668293657395" ID="ID_1569543028" MODIFIED="1668293667721" TEXT="geht hier direkt in die Umwandlung auf TimeValue ein"/>
|
|
<node CREATED="1668293668966" ID="ID_386978017" MODIFIED="1668293698664" TEXT="daher ist der Zähler gefährlich für Überlauf">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668293781881" ID="ID_159285221" MODIFIED="1668295774689" TEXT="⟹ den Nenner limitieren und umrechnen">
|
|
<arrowlink COLOR="#784489" DESTINATION="ID_1438689210" ENDARROW="Default" ENDINCLINATION="202;-30;" ID="Arrow_ID_1396674797" STARTARROW="None" STARTINCLINATION="-243;119;"/>
|
|
<node CREATED="1668293808883" ID="ID_1567408575" MODIFIED="1668293830091" TEXT="dadurch sollte auch der Zähler kleiner werden"/>
|
|
<node CREATED="1668293830823" ID="ID_615954964" MODIFIED="1668293953957" TEXT="danach kann man den Zähler noch limitieren"/>
|
|
<node CREATED="1668293939617" ID="ID_1509248321" MODIFIED="1668293997256" TEXT="das verfälscht dann zwar die Ergebnisse ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber ein Zähler > INT_MAX / Time::SCALE kann unmöglich sinnvoll weiterverarbeitet werden, und außerdem sollte er für eine Metrik gar nicht auftreten können, weil die Metrik ja relativ stark in der Größe beschränkt ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668292406078" ID="ID_700195003" MODIFIED="1668292410082" TEXT="mutateScale">
|
|
<node CREATED="1668294260504" ID="ID_1189855260" MODIFIED="1668294265761" TEXT="changeFaktor wird berechnet">
|
|
<node CREATED="1668294266469" ID="ID_1220681698" MODIFIED="1668294272300" TEXT="hier geht alte und neue Metrik ein"/>
|
|
<node CREATED="1668294279606" ID="ID_1996892048" MODIFIED="1668294286990" TEXT="dabei können Zähler und Nenner überlaufen"/>
|
|
<node CREATED="1668294397413" ID="ID_91804756" MODIFIED="1668294448984" TEXT="Vorsicht: Nenner der bestehenden Metrik kann toxisch sein">
|
|
<linktarget COLOR="#c6476e" DESTINATION="ID_91804756" ENDARROW="Default" ENDINCLINATION="220;-12;" ID="Arrow_ID_1385445807" SOURCE="ID_199183662" STARTARROW="None" STARTINCLINATION="721;42;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668294526618" ID="ID_603305402" MODIFIED="1668736269643" TEXT="maximale Gefahr...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668294547631" ID="ID_1464756735" MODIFIED="1668294561849" TEXT="Nenner der bestehenden Metrik ist nahe Time::MAX"/>
|
|
<node CREATED="1668294577579" ID="ID_1456441768" MODIFIED="1668294606739" TEXT="Zähler der neuen Metrik ist knapp unter ZOOM_MAX_RESOLUTION"/>
|
|
<node CREATED="1668294624158" ID="ID_1703677216" MODIFIED="1668294635105" TEXT="dann kann die neue Duration entgleisen">
|
|
<node CREATED="1668294754587" ID="ID_552564018" MODIFIED="1668294764350" TEXT="negative Werte werden dann zwar gekappt"/>
|
|
<node CREATED="1668294765010" ID="ID_1324653520" MODIFIED="1668294773319" TEXT="aber es können auch extreme positive Werte rauskommen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668294855702" ID="ID_573583654" MODIFIED="1668294856771" TEXT="dur /= changeFactor;">
|
|
<node CREATED="1668294810124" ID="ID_1927711726" MODIFIED="1668294839716" TEXT="Zähler der neuen Metrik * Nenner der bestehenden Metrik ⟶ Nenner der duration"/>
|
|
<node CREATED="1668294868212" ID="ID_513903725" MODIFIED="1668294880149" TEXT="⟹ dur könnte toxisch werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1668294907998" ID="ID_96983887" MODIFIED="1668294948887" TEXT="fließt in conformWindowToMetric">
|
|
<arrowlink COLOR="#c87094" DESTINATION="ID_7304516" ENDARROW="Default" ENDINCLINATION="6;156;" ID="Arrow_ID_1140056910" STARTARROW="None" STARTINCLINATION="-286;-12;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668294985092" ID="ID_25938691" MODIFIED="1668295715873" TEXT="Fazit: sichere Aussage nicht möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...in vertretbarem Rahmen...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
es gibt X verschiedene Fallkombinationen die gefährlich werden können
|
|
</li>
|
|
<li>
|
|
die Normalisierung/Invarianten-Behandlung kann selbst grenzwertige Metriken erzeugen
|
|
</li>
|
|
<li>
|
|
Werte können sich über viele Runden aufschaukeln
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Dies alles erscheint mir analytisch schwer beherrschbar, bzw. würde exzessiven Analyse-Aufwand erfordern; <font color="#af134b">und letztlich ist das hier doch nur eine „sportliche Herausforderung“</font>
|
|
</p>
|
|
<p>
|
|
☢ und kein Kernkraftwerk ☢
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fe153e" DESTINATION="ID_1727052645" ENDARROW="Default" ENDINCLINATION="-220;-12;" ID="Arrow_ID_1068276160" STARTARROW="None" STARTINCLINATION="-298;-17;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668292044070" ID="ID_1745284896" MODIFIED="1668292074183" TEXT="Ansatz der Schwelle">
|
|
<node CREATED="1668295576854" ID="ID_1377873072" MODIFIED="1668295604677" TEXT="Typischwerweise erfolgt »downstream« eine Multiplikation mit Time::SCALE">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1668295605833" ID="ID_1556461638" MODIFIED="1668295655639" TEXT="damit ist INT_MAX / (10*Time::SCALE) die Grenze des Handhabbaren"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668295661949" ID="ID_1727052645" MODIFIED="1671235817019" TEXT="es kann hier nur eine Heuristik geschaffen werden">
|
|
<linktarget COLOR="#fe153e" DESTINATION="ID_1727052645" ENDARROW="Default" ENDINCLINATION="-220;-12;" ID="Arrow_ID_1068276160" SOURCE="ID_25938691" STARTARROW="None" STARTINCLINATION="-298;-17;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1668295744623" ID="ID_1438689210" MODIFIED="1668295768057" TEXT="Methode">
|
|
<linktarget COLOR="#784489" DESTINATION="ID_1438689210" ENDARROW="Default" ENDINCLINATION="202;-30;" ID="Arrow_ID_1396674797" SOURCE="ID_159285221" STARTARROW="None" STARTINCLINATION="-243;119;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1668295785449" ID="ID_248479209" MODIFIED="1668295794255" TEXT="Nenner gegen Limit prüfen"/>
|
|
<node COLOR="#338800" CREATED="1668295795329" FOLDED="true" ID="ID_1179855526" MODIFIED="1668474431508" TEXT="Requantisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668353519645" ID="ID_1709187608" MODIFIED="1668474384018" TEXT="so exakt wie möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da reichen meine Algebra-Kenntnisse nicht aus....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#f2fbd7" DESTINATION="ID_1709187608" ENDARROW="Default" ENDINCLINATION="113;234;" ID="Arrow_ID_229027216" SOURCE="ID_505458679" STARTARROW="Default" STARTINCLINATION="-412;-14;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668353552561" ID="ID_1127388689" MODIFIED="1668474254609" TEXT="näherungsweise per long double">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1668353569055" ID="ID_1784438485" MODIFIED="1668353581617" TEXT="aufteilen in Ganzzahl und Modulus"/>
|
|
<node CREATED="1668353584405" ID="ID_1181209360" MODIFIED="1668353593384" TEXT="dann den Modulus näherungsweise requantifizieren"/>
|
|
<node COLOR="#338800" CREATED="1668353653955" FOLDED="true" ID="ID_1020200002" MODIFIED="1668353816582" TEXT="Neben-Untersuchung: Ganzzahl-Zweierlogarithmus">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668353668892" ID="ID_259284183" MODIFIED="1668353679884" TEXT="ja... die banale Lösung mit der Bitshift-Schleife"/>
|
|
<node CREATED="1668353680848" ID="ID_152151776" MODIFIED="1668353792957" TEXT="Geht das auch besser? vielleicht logarithmisch?">
|
|
<node CREATED="1668353698198" ID="ID_394250867" LINK="https://stackoverflow.com/a/24748637" MODIFIED="1668353698198" TEXT="sowiso...">
|
|
<linktarget COLOR="#ffe1c1" DESTINATION="ID_394250867" ENDARROW="Default" ENDINCLINATION="-128;27;" ID="Arrow_ID_791821354" SOURCE="ID_812438903" STARTARROW="None" STARTINCLINATION="-142;-24;"/>
|
|
</node>
|
|
<node CREATED="1668353698198" ID="ID_275694038" LINK="http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious" MODIFIED="1668353698198" TEXT="aber klar doch..."/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668353793968" ID="ID_9788121" MODIFIED="1668353882082" TEXT="eine Adaption dieser Methode mal als Utility formuliert">
|
|
<arrowlink COLOR="#07a5b2" DESTINATION="ID_1509712772" ENDARROW="Default" ENDINCLINATION="96;-4;" ID="Arrow_ID_1066574831" STARTARROW="None" STARTINCLINATION="-282;15;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668393503545" ID="ID_1760600173" MODIFIED="1668395451097" TEXT="Microbenchmarks durchgeführt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668394019882" ID="ID_599742848" MODIFIED="1668394142917" TEXT="Benchmark-Setup">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1668394043359" ID="ID_1124273723" MODIFIED="1668394063335" TEXT="gebaut per -O3"/>
|
|
<node CREATED="1668394064034" ID="ID_235157501" MODIFIED="1668395296511" TEXT="Impl-Funktion per Lambda übergeben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Habe dies explizit verifiziert und vergliechen mit komplett ausformulierten inline-Funktionen; wie erwartet: mit -O3 werden Lambdas komplett transparent geinlined.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1668394082290" ID="ID_342146050" MODIFIED="1668394093332" TEXT="Array mit 1000 Zufallszahlen"/>
|
|
<node CREATED="1668394096760" ID="ID_1339569720" MODIFIED="1668394109114" TEXT="1000 Durchläufe über dieses Array"/>
|
|
<node CREATED="1668394109774" ID="ID_552943244" MODIFIED="1668395370694" TEXT="Ergebnis in Akkumulator summiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Extrem wichtig. Und auch wichtig: mit diesem Akkumulator nachher noch etwas machen (z.B. ausgeben). Sonst merkt der Compiler daß das kein beobachtbarer Effekt ist, und entfernt die Addition, und dann in einigen Fällen auch den eigentlichen Funktionsaufruf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1668394121117" ID="ID_169752249" MODIFIED="1668394135936" TEXT="Zeitmessung per system_clock"/>
|
|
</node>
|
|
<node CREATED="1668396009603" ID="ID_1438298126" MODIFIED="1668396019050" TEXT="für int64_t">
|
|
<node CREATED="1668393519910" ID="ID_219605808" MODIFIED="1668397317940" TEXT="mein ilog2: 5.6ns"/>
|
|
<node CREATED="1668393672305" ID="ID_812438903" MODIFIED="1668393802739" TEXT="Vorlage SO: 7.6ns">
|
|
<arrowlink COLOR="#ffe1c1" DESTINATION="ID_394250867" ENDARROW="Default" ENDINCLINATION="-128;27;" ID="Arrow_ID_791821354" STARTARROW="None" STARTINCLINATION="-142;-24;"/>
|
|
<node CREATED="1668395067578" ID="ID_386803191" MODIFIED="1668395176399" TEXT="das liegt aber nur am fehlenden -1 Branch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Vorlage auf Stackoverflow initialisiert auf 0 oder -1, läuft dann aber für Input==0 leer durch die Checks durch. Meine Variante testet auf 0 und returnt sofort.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668393804032" ID="ID_21424194" MODIFIED="1668393908928" TEXT="std::ilogb: 5ns">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1668395186709" ID="ID_1211843890" MODIFIED="1668395210813" TEXT="tja..">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668395190925" ID="ID_1430564827" MODIFIED="1668395202091" TEXT="soviel zu mikro-Optimierungen">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668393917856" ID="ID_1019010591" MODIFIED="1668398463666" TEXT="bitshift: 44.5ns"/>
|
|
<node CREATED="1668393950108" ID="ID_1616300073" MODIFIED="1668398506957" TEXT="identity: 0.6ns"/>
|
|
</node>
|
|
<node CREATED="1668396029490" ID="ID_1564618644" MODIFIED="1668396033408" TEXT="für int8_t">
|
|
<node CREATED="1668396057054" ID="ID_1071094861" MODIFIED="1668396063236" TEXT="mein ilog2: 5.2ns">
|
|
<node CREATED="1668397327959" ID="ID_837112422" MODIFIED="1668397363382" TEXT="beachte: profitiert von dem kleineren Zahlenraum"/>
|
|
</node>
|
|
<node CREATED="1668396069719" ID="ID_22228342" MODIFIED="1668396092527" TEXT="std::ilogb: 5.8ns"/>
|
|
<node CREATED="1668396123864" ID="ID_442684506" MODIFIED="1668396149609" TEXT="bitshift: 8.2ns">
|
|
<node CREATED="1668397368169" ID="ID_1133087044" MODIFIED="1668397386347" TEXT="beachte: der Unterschied zum log-Test ist nicht mehr groß"/>
|
|
</node>
|
|
<node CREATED="1668396166545" ID="ID_1651198717" MODIFIED="1668396174213" TEXT="identity: 0.3ns"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668399037176" ID="ID_436989865" MODIFIED="1668399206026" TEXT="Frage: std::ilogb verwenden?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1668399055151" ID="ID_1320606425" MODIFIED="1668399066085" TEXT="sind beide in der gleichen Größenordnung"/>
|
|
<node CREATED="1668399066733" ID="ID_833533643" MODIFIED="1668399154910" TEXT="was dagegen spricht: ich kenne nicht den Grund warum std::ilogb so schnell ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eine andere Standard-Library, und ilogb() könnte deutlich langsamer sein.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1668399085818" ID="ID_342245470" MODIFIED="1668399114059" TEXT="wohingegen die Performance dieser funktion hier rational nachvollziehbar ist"/>
|
|
<node CREATED="1668399157625" ID="ID_702521964" MODIFIED="1668399194000" TEXT="weiteres Argument: diese Funktion wird minimal schneller für kleinere Datentypen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1668399211706" ID="ID_738941814" MODIFIED="1668399256636" TEXT="mit C++20 kommt std::bit_width(i) ⟹ Benchmark wiederholen">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1668353594476" ID="ID_75685604" MODIFIED="1668353613457" TEXT="hier könnte man u.U. sogar erkennen, ob exakte Rechnung möglich ist">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1668353615520" ID="ID_816734415" MODIFIED="1668353619079" TEXT="später mal"/>
|
|
<node CREATED="1668353619784" ID="ID_395391770" MODIFIED="1668353624739" TEXT="nicht klar ob relevant"/>
|
|
<node CREATED="1668353625375" ID="ID_27295187" MODIFIED="1668353643696" TEXT="dann auch Micro-Benchmark notwendig"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668353892092" ID="ID_1654551581" MODIFIED="1668474307633" TEXT="Direkte Lösung + Fehler-Assert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668353919128" ID="ID_1237619949" MODIFIED="1668353937498" TEXT="ohne weitere Sanity-Checks"/>
|
|
<node COLOR="#338800" CREATED="1668353938677" ID="ID_278768234" MODIFIED="1668353944961" TEXT="funktioniert im Smoke-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668474259440" ID="ID_1390713963" MODIFIED="1668474302021" TEXT="verwende long double">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1668474283161" ID="ID_505458679" MODIFIED="1668474406928">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damit kann ich stets so genau wie möglich rechnen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#f2fbd7" DESTINATION="ID_1709187608" ENDARROW="Default" ENDINCLINATION="113;234;" ID="Arrow_ID_229027216" STARTARROW="Default" STARTINCLINATION="-412;-14;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1668474285441" ID="ID_318301259" MODIFIED="1668474305669" TEXT="Risiko: manche Plattformen definieren long double == double">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1668474317488" ID="ID_1121607924" MODIFIED="1668474342956" TEXT="erhöhe deshalb den Fehler-Assert auf einschlißlich Grenze">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668353832314" ID="ID_1509712772" MODIFIED="1668353882082" TEXT="Test-Methoden ob ein Bruch »giftig« ist">
|
|
<linktarget COLOR="#07a5b2" DESTINATION="ID_1509712772" ENDARROW="Default" ENDINCLINATION="96;-4;" ID="Arrow_ID_1066574831" SOURCE="ID_9788121" STARTARROW="None" STARTINCLINATION="-282;15;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668354018194" HGAP="39" ID="ID_1484604434" MODIFIED="1668474197855" TEXT="Testabdeckung..." VSHIFT="14">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668474155145" ID="ID_132764069" MODIFIED="1668474234849" TEXT="ein Beispiel mit Nenner nahe INT_MAX">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Rat poison = (MAXI-88)/(MAXI/7);
|
|
</p>
|
|
<p>
|
|
...das ist näherungsweise Sieben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668474201756" ID="ID_1997612449" MODIFIED="1668474234849" TEXT="Quantisieren auf feineren Divisor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668474224181" ID="ID_721417455" MODIFIED="1668474234849" TEXT="negative Zahlen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1668295799991" ID="ID_192811111" MODIFIED="1668736212375" TEXT="Zähler gegen Limit prüfen und ggfs kappen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1668561130068" ID="ID_1984177447" MODIFIED="1668561136326" TEXT="gefällt mir gar nicht..."/>
|
|
<node CREATED="1668703798232" ID="ID_661092441" MODIFIED="1668703817686" TEXT="Ergebnis sollte stets näherungsweise korrekt sein!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668561137011" ID="ID_1372010715" MODIFIED="1668736186079" TEXT="bessere Idee als "kappen"?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1668561156200" ID="ID_646114106" MODIFIED="1668561196159" TEXT="man könnte nochmal reQuantisieren">
|
|
<node CREATED="1668699891224" ID="ID_420975014" MODIFIED="1668699935567" TEXT="reduzieren um Zähler - LIM_HAZARD"/>
|
|
<node CREATED="1668699947962" ID="ID_307211451" MODIFIED="1668700039253" TEXT="das erste Quansitieren bewirkt nämlich u.U fast gar nix">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar in dem Fall, in dem der Nenner nur knapp über der Schwelle LIM_HAZARD liegt; dann findet nämlich fast keine Reduktion der Größenordnung statt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1668561196884" ID="ID_1903032995" MODIFIED="1668736191824" TEXT="oder gleich gegen einen kleineren Divisor...">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1668703944877" ID="ID_676279711" MODIFIED="1668704058851" TEXT="auf Effekt der re-Quantisierung abstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
der Nenner wird garantiert gleich dem vorgegebenen Quantisierer sein
|
|
</li>
|
|
<li>
|
|
aber der Zähler ist ggfs um das Verhältnis Zähler / Nenner größer als der Quantisierer
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1668705598237" ID="ID_434566365" MODIFIED="1668705615391" TEXT="⟹ es sind zwei Vorgaben umzusetzen">
|
|
<node CREATED="1668705616466" ID="ID_1803292875" MODIFIED="1668705683542" TEXT="Quant < LIM_HAZARD"/>
|
|
<node CREATED="1668705658797" ID="ID_1607621699" MODIFIED="1668705687757" TEXT="Quant so viel kleiner daß Zähler < LIM_HAZARD"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1668705712605" ID="ID_801769631" MODIFIED="1668736224441" TEXT="das ist am effizientesten über den 2-er-Logarithmus umsetzbar">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1668705828544" ID="ID_27322947" MODIFIED="1668705883187" TEXT="lb(zähler) - lb(nenner) ⟼ zusatz-Faktor"/>
|
|
<node CREATED="1668705906923" ID="ID_21115436" MODIFIED="1668705925067" TEXT="bei Überschuß den Quantiser entsprechend reduzieren"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1669508782375" ID="ID_1328009916" MODIFIED="1669673876153" TEXT="Vorsicht: Quantiser kann Null werden">
|
|
<arrowlink COLOR="#dd2238" DESTINATION="ID_507738124" ENDARROW="Default" ENDINCLINATION="93;-57;" ID="Arrow_ID_377645167" STARTARROW="None" STARTINCLINATION="-217;15;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1669673789135" ID="ID_846083949" MODIFIED="1669673797869" TEXT="dieser Ansatz hat seine Grenzen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1669673800862" ID="ID_507738124" MODIFIED="1669673869569" TEXT="absolut sehr große Brüche können wir nicht handhaben">
|
|
<linktarget COLOR="#dd2238" DESTINATION="ID_507738124" ENDARROW="Default" ENDINCLINATION="93;-57;" ID="Arrow_ID_377645167" SOURCE="ID_1328009916" STARTARROW="None" STARTINCLINATION="-217;15;"/>
|
|
</node>
|
|
<node CREATED="1669673828418" ID="ID_1875664128" MODIFIED="1669673980107" TEXT="für solche Fälle würde sogar die "Bereinigung" selber entgleisen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Und zwar, wenn der Nenner viel kleiner ist als der Zähler, und der Zähler extrem groß. Dann würde nämlich die Ganzzahl-Division keine signifikante Verringerung der Dimension bewirken, und die anschließende re-Quantisierung das Ergebnis (bedingt durch die Normierung auf einen gemeinsamen Nenner) sogar noch vergrößern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1669673981445" ID="ID_1599443715" MODIFIED="1669673998427" TEXT="allerdings für Zoom-Faktoren können wir das ausschließen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668705939639" ID="ID_393310295" MODIFIED="1669680301519" TEXT="allgemeiner Entgiftungs-Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668705949188" ID="ID_510681740" MODIFIED="1668707393273" TEXT="2-er-Logarithmen berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668705960324" ID="ID_1999378206" MODIFIED="1668705972646" TEXT="ist die effizientest mögliche Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1668705973302" ID="ID_1516053648" MODIFIED="1668705991661" TEXT="auch ein einfacher Größenvergleich muß nämlich das größte gesetze Bit finden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668706081924" ID="ID_1548560727" MODIFIED="1668707394524" TEXT="daraus Reduktions-Faktor ermitteln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1668706195686" ID="ID_894705182" MODIFIED="1668706204807" TEXT="der Überschuß gegenüber LIM_HAZARD"/>
|
|
<node CREATED="1668706205651" ID="ID_1995535678" MODIFIED="1668706221245" TEXT="und zwar das Maximum von Zähler und Nenner"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668706244774" ID="ID_972239326" MODIFIED="1668707396226" TEXT="Bitshift auf den Nenner um den Reduktoins-Faktor ⟼ neuer Quantiser">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668706302918" ID="ID_319812477" MODIFIED="1668707397496" TEXT="reQuant falls notwendig, sonst unverändert durchreichen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669680303553" ID="ID_943604336" MODIFIED="1671235719664" TEXT="Handhabung extremer Zeitspannen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669680334284" ID="ID_1144877898" MODIFIED="1669680352726" TEXT="Probleme">
|
|
<node CREATED="1669680353674" ID="ID_380004829" MODIFIED="1669680374859" TEXT="Summen mit Brüchen"/>
|
|
<node CREATED="1669680375968" ID="ID_861847594" MODIFIED="1669680389409" TEXT="Verhältnis-Berechnung"/>
|
|
<node CREATED="1669680390181" ID="ID_136457686" MODIFIED="1669680403199" TEXT="Anteil-Berechnung"/>
|
|
</node>
|
|
<node CREATED="1669680416417" ID="ID_264195573" MODIFIED="1669680423082" TEXT="Lösungs-Techniken">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#435e98" CREATED="1669680424602" ID="ID_267834802" MODIFIED="1670015986498" TEXT="Kürzungs-Trick">
|
|
<linktarget COLOR="#fbf8c7" DESTINATION="ID_267834802" ENDARROW="Default" ENDINCLINATION="538;-591;" ID="Arrow_ID_1957682133" SOURCE="ID_1644190283" STARTARROW="None" STARTINCLINATION="668;44;"/>
|
|
<node CREATED="1669680431912" ID="ID_180315930" MODIFIED="1669680447650" TEXT="einen Partner re-Quantisieren"/>
|
|
<node CREATED="1669680448333" ID="ID_969768863" MODIFIED="1669680473406" TEXT="so daß sich dann kreuzweise ein Zähler/Nenner wegkürzen"/>
|
|
<node CREATED="1669680479307" ID="ID_503307048" MODIFIED="1669680497907" TEXT="⟹ danach können wir Produkt oder Quotient ohne Multipliaktion berechnen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669682825470" FOLDED="true" ID="ID_906501375" MODIFIED="1670689404952" TEXT="verallgemeinert: scaleSafe()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670689143468" ID="ID_583442094" MODIFIED="1670689329214" TEXT="generisches Rechenschema: sichere Multiplikation (notfalls angenähert)">
|
|
<linktarget COLOR="#346573" DESTINATION="ID_583442094" ENDARROW="Default" ENDINCLINATION="54;970;" ID="Arrow_ID_1592379847" SOURCE="ID_1347035051" STARTARROW="None" STARTINCLINATION="-143;-9;"/>
|
|
<node CREATED="1669994491114" ID="ID_823441392" MODIFIED="1670689220925" TEXT="Idee: größt möglichen Faktor kürzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1669994530717" ID="ID_246811570" MODIFIED="1670000510847" TEXT="vier symmetrische Fälle">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1669994696676" ID="ID_507544701" MODIFIED="1669997264882" TEXT="alle vier Fälle initial prarametrisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994676320" ID="ID_277762782" MODIFIED="1669997271457" TEXT="der Fall mit Time::SCALE ist speziell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier wissen wir, daß wir den Quantiser ggfs hochskalieren können auf 1e6 (er hat sich u.u mit der µ-Tick-Zahl gekürzt). Da es sich um eine valide Duration handelt, ist dieses Hochskalieren stets garantiert. Mithin ist dieser Faktor das garantierte Minimum (die schlechtest mögliche Genauigkeit ≙ 1e-6
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994539603" ID="ID_429120779" MODIFIED="1670000489650" TEXT="als Klasse formulieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669994561425" ID="ID_1491074333" MODIFIED="1669994574324" TEXT="Eingaben">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1669994578390" ID="ID_1554716694" MODIFIED="1669994592848" TEXT="f1 : der sichere Faktor"/>
|
|
<node CREATED="1669994594196" ID="ID_520285185" MODIFIED="1669994602847" TEXT="u : der zu kürzende Quantisierer"/>
|
|
<node CREATED="1669994606018" ID="ID_140283418" MODIFIED="1669994641085" TEXT="req: requantisation-Target ⟼ wird zu u"/>
|
|
<node CREATED="1669994645898" ID="ID_448193400" MODIFIED="1669994655184" TEXT="f2 : der limitierende Gegen-Faktor"/>
|
|
<node CREATED="1669995461568" ID="ID_1761342962" MODIFIED="1669995622760" TEXT="ist ein Kehrwert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aus Gründen der Symmetrie kann man das gleiche Argument jeweils auch auf den Kehrwert anwenden, deshalb haben wir ja 4 Fälle (bei zwei Eingangs-Faktoren). Man muß nur ggfs. dann den Kehrwert vom Ergebnis ausgeben. Beispiel: wir nehmen den Zähler vom ersten Faktor als Quantisierer. Dann ist f1 der Nenner vom ersten Faktor, und muß daher auch im Ergebnis im Nenner landen, nicht im Zähler wie beim regulären Schema
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6e8ddb" DESTINATION="ID_1560238867" ENDARROW="Default" ENDINCLINATION="-180;-19;" ID="Arrow_ID_1642921638" STARTARROW="None" STARTINCLINATION="-64;9;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994839828" ID="ID_418503319" MODIFIED="1670000487125" TEXT="Machbarkeits-Check">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1669994865016" ID="ID_361530418" MODIFIED="1670000482856" TEXT="Dimensions-Differenz von req auf u ermitteln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994886342" ID="ID_1735969091" MODIFIED="1670000480941" TEXT="prüfen ob eine Vergrößerung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994898347" ID="ID_494553186" MODIFIED="1670000484810" TEXT="prüfen ob diese Vergrößerung auf f2 angewendet werden kann">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669995258396" ID="ID_93063502" MODIFIED="1669997787709" TEXT="angebotene Genauigkeit">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1669995272224" ID="ID_1288818816" MODIFIED="1669997793129" TEXT="u"/>
|
|
<node COLOR="#435e98" CREATED="1669995281664" ID="ID_879911679" MODIFIED="1669997792445" TEXT="auf 0 setzen wenn nicht machbar"/>
|
|
<node COLOR="#338800" CREATED="1669997435820" ID="ID_841478882" MODIFIED="1669997789720" TEXT="Aufruf löst Machbarkeits-Check aus">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669995329084" ID="ID_1546053278" MODIFIED="1669997783595" TEXT="Resultat berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1669995234367" ID="ID_1696175264" MODIFIED="1669997781377" STYLE="fork" TEXT="f2 requantisieren auf u"/>
|
|
<node COLOR="#435e98" CREATED="1669995424654" ID="ID_363188688" MODIFIED="1669997781377" STYLE="fork" TEXT="neuer Rat{f2,u}"/>
|
|
<node COLOR="#435e98" CREATED="1669995396649" ID="ID_1560238867" MODIFIED="1669997781378" STYLE="fork" TEXT="ggfs Kehrwert bilden">
|
|
<linktarget COLOR="#6e8ddb" DESTINATION="ID_1560238867" ENDARROW="Default" ENDINCLINATION="-180;-19;" ID="Arrow_ID_1642921638" SOURCE="ID_1761342962" STARTARROW="None" STARTINCLINATION="-64;9;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994546102" ID="ID_1814759469" MODIFIED="1670000491434" TEXT="Maximum-Suche">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670688516976" ID="ID_69967327" MODIFIED="1670689395158" TEXT="Analyse: Existenz der Lösung ist garantiert">
|
|
<linktarget COLOR="#5365c2" DESTINATION="ID_69967327" ENDARROW="Default" ENDINCLINATION="196;-673;" ID="Arrow_ID_33256420" SOURCE="ID_66504136" STARTARROW="None" STARTINCLINATION="-593;729;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1670688528846" ID="ID_1754365321" MODIFIED="1670689380463" TEXT="wenn man die Einschränkung auf µ-Tick quantisierte Zeit fallen läßt">
|
|
<arrowlink COLOR="#4a9197" DESTINATION="ID_1765522524" ENDARROW="Default" ENDINCLINATION="-650;0;" ID="Arrow_ID_863565881" STARTARROW="None" STARTINCLINATION="255;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670688791683" ID="ID_249714028" MODIFIED="1670688830194" TEXT="einfach: prüfen ob die Division (gemeinsamer Faktor) einen Rest hatte"/>
|
|
<node CREATED="1670688831014" ID="ID_1316911018" MODIFIED="1670688851406" TEXT="⟹ dann gibt es nämlich keinen gemeinsamen Faktor der den Nenner auf Time::SCALE bringt"/>
|
|
<node CREATED="1670688852123" ID="ID_770782289" MODIFIED="1670688890442" TEXT="⟹ den zusätzlichen Faktor auf 1 setzen ⟺ auch die Duration damit unmodifiziert verwenden"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670688643175" ID="ID_1852182895" MODIFIED="1670688964874" TEXT="Argument: bereits ein Paar von Fällen hat garantiert eine Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1670688675371" ID="ID_1215939447" MODIFIED="1670688691423" TEXT="weil Zähler und Nenner in beide Richtungen versucht werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670688692078" ID="ID_1207417646" MODIFIED="1670688956661" TEXT="Annahme: die eine Richtung funktioniert nicht">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1670688714494" ID="ID_1833767124" MODIFIED="1670688731503" TEXT="⟹ bedeutet, der Gegenpartner ist größer und daher nicht beliebig vergrößerbar"/>
|
|
<node CREATED="1670688732451" ID="ID_766470201" MODIFIED="1670688756859" TEXT="⟹ dann ist das Paar aber in umgekehrter RIchtung beliebig vergrößerbar"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670688759175" ID="ID_144891898" MODIFIED="1670688944833" TEXT="⟺ die umgekehrte Orientierung kann jeden beliebigen Kürzugs-Faktor akkomodieren"/>
|
|
</node>
|
|
<node CREATED="1670688918210" ID="ID_1507149209" MODIFIED="1670688931076" TEXT="...und wir haben zwei Paare, können uns also sogar die bessere Lösung suchen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669911724009" ID="ID_289279043" MODIFIED="1670015959526" TEXT="verallgemeinert: addSafe()">
|
|
<linktarget COLOR="#2f7ca3" DESTINATION="ID_289279043" ENDARROW="Default" ENDINCLINATION="167;16;" ID="Arrow_ID_333407901" SOURCE="ID_797370792" STARTARROW="None" STARTINCLINATION="-174;-8;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669932544504" ID="ID_750418137" MODIFIED="1670015851933" TEXT="FSecs ⟼ µ-Tick absichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669932578600" ID="ID_974803158" MODIFIED="1669932591544" TEXT="das erweist sich als häufige Quelle von wrap-arounds">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1669932596081" ID="ID_1661291024" MODIFIED="1669932618249" TEXT="dabei ist es einfach bloß naiv gecodet">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669932620086" ID="ID_673992117" MODIFIED="1670015849357" TEXT="stattdessen die re-Quantisierung nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1669932632788" ID="ID_831065868" MODIFIED="1669932761462" TEXT="nur dann hier auf 1/1000000">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669932640820" ID="ID_1387350127" MODIFIED="1669932675887" TEXT="dazu eine Variante für den Zähler allein schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669932653473" ID="ID_120882361" MODIFIED="1669932684292" TEXT="kann sogar den Rat-Fall hierauf zurückführen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669932686823" FOLDED="true" ID="ID_1630699394" MODIFIED="1669932696052" TEXT="Numerik-Probleme">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1669932700323" ID="ID_1606021601" MODIFIED="1669932716796" TEXT="tja... Float bleibt Float selbst bei 128bit">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1669932728399" ID="ID_20790978" MODIFIED="1669932757508">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man <b>muß</b> Floating-point runden wenn man glatte Werte will
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669932772210" ID="ID_787506618" MODIFIED="1669933074821" TEXT="Runden oder Tuncate?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1669932795247" ID="ID_258240741" MODIFIED="1669932979085" TEXT="Zeit in Lumiera stets left-Truncate">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist essentiell wichtig. "Negative" Zeiten dürfen sich <i>keinesfalls</i>  anders verhalten. Eine andere Quantsierungs-Regel kann man dann ggfs. high-level auf ein left-Truncate aufsetzen (z.B. Mitte Frame-Intervall)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1669932981526" ID="ID_837170036" MODIFIED="1669933009189">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ also muß man hier <i>technisch runden</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1669933011434" ID="ID_1937730928" MODIFIED="1669933021860" TEXT="das bedeutet: auf 1/INT_MAX"/>
|
|
<node CREATED="1669933027664" ID="ID_1390211698" MODIFIED="1669933038658" TEXT="weil ein Bruch hier interpretiert wird als Quantisierung"/>
|
|
<node CREATED="1669933049926" ID="ID_1930108218" MODIFIED="1669933071839" TEXT="und wir daher auf die kleinstmöglich darstellbare rationale Zahl runden"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669933076257" ID="ID_68878490" MODIFIED="1669933203590" TEXT="geht das überhaupt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1669933097062" ID="ID_1298571080" MODIFIED="1669933101833" TEXT="mit double nicht...."/>
|
|
<node CREATED="1669933102558" ID="ID_561202442" MODIFIED="1669933112105" TEXT="aber ich arbeite hier ja bewußt mit long double"/>
|
|
<node CREATED="1669933113580" ID="ID_1052633426" MODIFIED="1669933130786" TEXT="aber selbst da sprengt ein absolutes ULP den Wertebereich"/>
|
|
<node CREATED="1669933140405" ID="ID_672266484" MODIFIED="1669933163530" TEXT="⟹ also relative ULP nehmen: *(1+ULP)"/>
|
|
<node CREATED="1669933167811" ID="ID_1558282411" MODIFIED="1669933183695" TEXT="das geht grade noch auf"/>
|
|
<node CREATED="1669933185842" ID="ID_1427917386" MODIFIED="1669933196158" TEXT="Schwein gehabt">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1669933204808" ID="ID_1033893690" MODIFIED="1669933252753" TEXT="WARNUNG: falls long double == double dann ist diese Rundung unwirksam">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669933257385" ID="ID_1774777202" MODIFIED="1669933428563" TEXT="Testfall: TimeParsing_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669933273591" ID="ID_1754745072" MODIFIED="1669933393067" TEXT="Darstellung von 1/250s">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das sind 4ms
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1669933281232" ID="ID_542233825" MODIFIED="1669933418231" TEXT="ohne Rundung: 3999µs">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
parsing '1/250sec' resulted in 0:00:00.003 instead of 0:00:00.004
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670015941129" ID="ID_1262505892" MODIFIED="1670015955338" TEXT="kann nun (wohl) nicht mehr entgleisen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668707398858" ID="ID_1529383789" MODIFIED="1671235811403" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1668707465449" ID="ID_1678870601" MODIFIED="1668736173820" TEXT="toxicDegree mit einigen Beispielen demonstrieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668707479892" ID="ID_1964644327" MODIFIED="1671235788141" TEXT="ansonsten durch Ausreizen der Extremwerte testen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1669682928809" ID="ID_499417740" MODIFIED="1670015827119" TEXT="setVisiblePos(gift)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669682950712" ID="ID_1730356591" MODIFIED="1669682974366" TEXT="macht was Anderes als nur die Zoom-Metrik anpassen"/>
|
|
<node CREATED="1669682975415" ID="ID_1386857509" MODIFIED="1669682993901" TEXT="die Verbindung mit Längen/Positions-Kalkulationen ist gefährlich">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669683004871" ID="ID_1503834170" MODIFIED="1669683025116" TEXT="wrap-around bekomme ich mit detox() und scaleSafe() in den Griff">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669683026004" ID="ID_1867241917" MODIFIED="1670015746454" TEXT="Ergebnis ist aber noch nicht plausibel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# _raw(win.overallSpan().duration()) ? = 307445734561825860 </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# _raw(targetPos) ?                    = 206435633551724864 </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# _raw(win.visible().start()) ?        =   2248731193323487 </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# _raw(win.visible().end()) ?          =   2248732049674178 </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# bool(win.visible().start() < targetPos) ? = 1 </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced">#--◆--# bool(win.visible().end() > targetPos) ? = 0 </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1669683157298" ID="ID_710000990" MODIFIED="1669943698789" TEXT="Fenster liegt verdächtig weit daneben">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1669911421774" ID="ID_1721803067" MODIFIED="1669943698789" TEXT="Umwandlung FSecs ⟼ µ-ticks entgleist">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1669911515423" ID="ID_245485754" MODIFIED="1669943698789" TEXT="detox() vorher">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1669911534853" ID="ID_1958976369" MODIFIED="1669943698789" TEXT="die Summe selber könnte auch wrappen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...tut sie zwar nicht in dem Beispiel hier, aber mit genügend krimineller Energie ließe sich ein valides Beispiel konstruieren, wobei
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Ziel-Position dann außerhalb des legalen Bereichs liegen würde
|
|
</li>
|
|
<li>
|
|
bei korrekter Behandlung daher das Ergebnis-Fenster in den legalen Bereich geschoben werden müßte
|
|
</li>
|
|
<li>
|
|
aber ohne weitere Schutzmaßname hier die Berechnung der Zielposition entgleist
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669911687704" ID="ID_797370792" MODIFIED="1669943698789" TEXT="könnte man im nun etablierten Schema auch ein addSafe() definieren">
|
|
<arrowlink COLOR="#2f7ca3" DESTINATION="ID_289279043" ENDARROW="Default" ENDINCLINATION="167;16;" ID="Arrow_ID_333407901" STARTARROW="None" STARTINCLINATION="-174;-8;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#338800" CREATED="1669911787964" ID="ID_147783330" MODIFIED="1669911798248" TEXT="Erkennung und Behandlung der Grenzbedingungen analog">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669911817888" ID="ID_493362427" MODIFIED="1669943698789" TEXT="Problem: Summe könnte trotzdem entgleisen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1669912456275" ID="ID_661856327" MODIFIED="1669912464070" TEXT="nur bei Addition / gleicher Richtung"/>
|
|
<node CREATED="1669912668224" ID="ID_1384499593" MODIFIED="1669914705545" TEXT="nur wenn bei mindestens einem Summanden das höchste Bit gesetzt ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0111 + 0111 = 1110
|
|
</p>
|
|
<p>
|
|
0011 + 0101 = 1000
|
|
</p>
|
|
<p>
|
|
aber...
|
|
</p>
|
|
<p>
|
|
0010 + 0101 = 0111
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#644f94" DESTINATION="ID_1384499593" ENDARROW="Default" ENDINCLINATION="-195;8;" ID="Arrow_ID_899257928" SOURCE="ID_41244947" STARTARROW="None" STARTINCLINATION="-101;-8;"/>
|
|
</node>
|
|
<node CREATED="1669913417600" ID="ID_175910999" MODIFIED="1669943698789" TEXT="⟹ re-Quantisierung muß außerdem beide Summanden aus der Gefahrenzone bringen"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669913560481" ID="ID_756192644" MODIFIED="1669943698789" TEXT="konkretes Rechenschema">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1669913571311" ID="ID_1313345585" MODIFIED="1669943698789" TEXT="verwende den (absolut) kleineren der beiden Nenner"/>
|
|
<node COLOR="#435e98" CREATED="1669914430412" ID="ID_41244947" MODIFIED="1669943698789" TEXT="überprüfe die Gefahrenzone für die Zähler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gefahr besteht...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wenn beide Vorzeichen gleichgerichtet sind
|
|
</li>
|
|
<li>
|
|
wenn mindestens einer der Zähler das 63te Bit gesetzt hat (2^62)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#644f94" DESTINATION="ID_1384499593" ENDARROW="Default" ENDINCLINATION="-195;8;" ID="Arrow_ID_899257928" STARTARROW="None" STARTINCLINATION="-101;-8;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1669914775664" ID="ID_1885451601" MODIFIED="1669943698789" TEXT="wenn ungefährlich, dann nur größeren Nenner requantisieren"/>
|
|
<node CREATED="1669914824383" ID="ID_999893302" MODIFIED="1669943698789" TEXT="wenn gefährlich, Nenner um ein Bit shiften und beide requantisieren"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669914866913" ID="ID_1877357496" MODIFIED="1669943698789" TEXT="Summation der angepaßten Zähler ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669914880928" ID="ID_1472462771" MODIFIED="1669943698789" TEXT="Ergebnis mit gemeinsamem Nenner konstruieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669914896208" ID="ID_370915623" MODIFIED="1669943698789" TEXT="Ergebnis entgiften">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669941951462" ID="ID_793235597" MODIFIED="1669943698789" TEXT="Problem: Fehler zu groß">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1669941967260" ID="ID_54342145" MODIFIED="1669943698789" TEXT="Faktor 10 im Beispiel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
206435709205.57568 - 206435709205575697/1e6  = abs(-0,000017) > 1e-6
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669942746884" ID="ID_1339303586" MODIFIED="1669943698789" TEXT="Ha! der guess ist zu ungenau">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1669942758191" ID="ID_1779789843" MODIFIED="1669943698789" TEXT="double precision reicht definitiv nicht hier"/>
|
|
<node CREATED="1669942769413" ID="ID_592526352" MODIFIED="1669943698789" TEXT="genauer gerechnete Ergebnisse erfüllen die Fehlerschwelle">
|
|
<arrowlink COLOR="#3f6fd5" DESTINATION="ID_198719131" ENDARROW="Default" ENDINCLINATION="58;4;" ID="Arrow_ID_802871126" STARTARROW="None" STARTINCLINATION="-13;48;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669942791302" ID="ID_198719131" MODIFIED="1669943698789" TEXT="⟹ muß Assertinon mit long double rechnen">
|
|
<linktarget COLOR="#3f6fd5" DESTINATION="ID_198719131" ENDARROW="Default" ENDINCLINATION="58;4;" ID="Arrow_ID_802871126" SOURCE="ID_592526352" STARTARROW="None" STARTINCLINATION="-13;48;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669943663699" ID="ID_693461392" MODIFIED="1670015348017" TEXT="Ergebnis nun im Fehlerband — aber leider immer noch daneben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1669943776106" ID="ID_1895721471" MODIFIED="1669943795208" TEXT="bei re-Quantisierung auf µ-Tick kann ich nicht genauer sein als 1e-6"/>
|
|
<node CREATED="1669943801006" ID="ID_1524475083" MODIFIED="1669943916288" TEXT="trotzdem will mir dieser Befund irgendwie logisch nicht in den Kopf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ich hab doch ohnehin Zeiten, die sind µ-Grid quantisiert; also müßte der Fehler einer einfachen Addition auf µ-Grid genau sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669943918742" ID="ID_1902626416" MODIFIED="1669994406710" TEXT="der Fehler wird relativ zur Ergebnishzahl wirksam — warum?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1669948612766" ID="ID_773874014" MODIFIED="1669948622948" TEXT="der Fehler tritt nicht in der Subtraktion auf"/>
|
|
<node CREATED="1669948623670" ID="ID_549263730" MODIFIED="1669948642617" TEXT="sondern bereits beim Berechnen der Bezugs-Position"/>
|
|
<node CREATED="1669948657379" ID="ID_765957465" MODIFIED="1669949047942" TEXT="dort re-Quantisieren wir auf 1e-6 weil das der einzige sichere Faktor ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da wir wissen, daß einer der Multiplikatoren eine bereits quantifizierte Zeit ist, können wir von einem Nenner 1e+6 ausgehen (ggfs noch reduziert um einen gekürzten Faktor). Das andere Argument, der Anteil-Faktor, stammt von außen und ist daher beliebig. Der einzige sichere Weg, den Kürzungs-Trick anzuwenden, ist daher, den Kehrwert des Anteil-Faktors zu re-Quantisieren, so daß sich dieses 1e+6 wegkürzt, und wir dann keine gefährliche Multiplikation mehr haben.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669949275009" ID="ID_276477045" MODIFIED="1670015719974" TEXT="letztlich geht es num darum, Funktionsfähigkeit in seltenen Randfällen zu erhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und damit die rationale Arithmetik als Möglichkeit zu erhalten; sie wäre nicht sinnvoll nutzbar, wenn man ständig die Sorge haben müßte, daß einem die Zahlen »explodieren« können. So ist es nun schon besser, im Regelfall eine hochpräzise Berechnung zu haben (präziser als floating-point), die in Grenzfällen ungenau wird, mit letztlich kontrollierbarem Fehler-Level
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1670015358471" ID="ID_1559004584" MODIFIED="1670015734747" TEXT="hatte erst so meine Zweifel">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1670015367683" ID="ID_1687855073" MODIFIED="1670015724868" TEXT="jetzt bin ich froh, daß ich's gemacht hab">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es fühlt sich gut an, das Problem nun doch befriedigend bezwungen zu haben; ich hatte immer das Bauchgefühl, daß da mehr Genauigkeit möglich sein sollte. Allerdings — wie sich zeigte — nur in günstigen Fällen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670015379779" ID="ID_636584956" MODIFIED="1670015481254" TEXT="...nun sind es eigentlich schon generische Library-Funktionen">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_636584956" ENDARROW="Default" ENDINCLINATION="-1629;69;" ID="Arrow_ID_1114152599" SOURCE="ID_1681510241" STARTARROW="None" STARTINCLINATION="3618;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1669949048959" ID="ID_595183859" MODIFIED="1669949241962" TEXT="im konkreten Einzelfall könnte man auch einen größeren Faktor nehmen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber nur nach Maßgabe der tatsächlichen Dimension der eingehenden Zahlen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fdf7a3" DESTINATION="ID_868173654" ENDARROW="Default" ENDINCLINATION="25;-20;" ID="Arrow_ID_190773880" STARTARROW="None" STARTINCLINATION="-207;8;"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1669994369691" ID="ID_1448820193" MODIFIED="1669994388355">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Fazit: es ist das <b>gesicherte Minimum</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1669994408813" ID="ID_868173654" MODIFIED="1670015809272" TEXT="Fehlergrenze im Einzelfall besser ausschöpfen">
|
|
<arrowlink COLOR="#2ddb4d" DESTINATION="ID_1865531371" ENDARROW="Default" ENDINCLINATION="381;70;" ID="Arrow_ID_1328969482" STARTARROW="None" STARTINCLINATION="-58;116;"/>
|
|
<linktarget COLOR="#fdf7a3" DESTINATION="ID_868173654" ENDARROW="Default" ENDINCLINATION="25;-20;" ID="Arrow_ID_190773880" SOURCE="ID_595183859" STARTARROW="None" STARTINCLINATION="-207;8;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1669994491114" ID="ID_301367323" MODIFIED="1669994520455" TEXT="Idee: größt möglichen Faktor kürzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1669994521693" ID="ID_983699676" MODIFIED="1670000518187" TEXT="muß dazu jeweils die Machbarkeit prüfen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670689122263" ID="ID_1347035051" MODIFIED="1670689329214" TEXT="ausarbeiten als generisches Rechenschema">
|
|
<arrowlink COLOR="#346573" DESTINATION="ID_583442094" ENDARROW="Default" ENDINCLINATION="54;970;" ID="Arrow_ID_1592379847" STARTARROW="None" STARTINCLINATION="-143;-9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670000524698" ID="ID_229993223" MODIFIED="1670000571148" TEXT="...und damit ist das Ergebnis nun hinreichend genau für diesen Testfall">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
#--◆--# _raw(targetPos) ?             = 206435633551724864
|
|
</p>
|
|
<p>
|
|
#--◆--# _raw(win.visible().start()) ? = 206435633106265625
|
|
</p>
|
|
<p>
|
|
#--◆--# _raw(win.visible().end()) ?   = 206435633962616316
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670015761936" ID="ID_1865531371" MODIFIED="1670015802640" TEXT="Test GRÜN">
|
|
<linktarget COLOR="#2ddb4d" DESTINATION="ID_1865531371" ENDARROW="Default" ENDINCLINATION="381;70;" ID="Arrow_ID_1328969482" SOURCE="ID_868173654" STARTARROW="None" STARTINCLINATION="-58;116;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670016158206" ID="ID_1376502254" MODIFIED="1670207142038" TEXT="setVisiblePos(weit-weg)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670017946731" ID="ID_410930969" MODIFIED="1670017960838" TEXT="erst mal das visibleWin nahe an Time::MAX"/>
|
|
<node CREATED="1670017961849" ID="ID_1322153373" MODIFIED="1670017996849" TEXT="dann als gewünschte Position Time::MIN"/>
|
|
<node CREATED="1670024841228" ID="ID_327609209" MODIFIED="1670024849028" TEXT="ist gar nicht so wirklich toxisch">
|
|
<node CREATED="1670024857602" ID="ID_10543296" MODIFIED="1670024880586" TEXT="oder meine Funktionen sind inzwischen hinreichend abgesichert">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1670024990169" ID="ID_737996846" MODIFIED="1670025107388" TEXT="die Division für den posFactor funktioniert (überraschenderweise)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also offensichtlich erkennt boost::rational die Möglichkeit, den gemeinsamen Faktor 1e6 aus Zähler und Nenner wegzukürzen. Da wir aber hier einen FSec-Wert als Offset zugeben, haben wir wenig Möglichkeiten, das zu <i>vergiften</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670024963460" ID="ID_16615073" MODIFIED="1670024981796" TEXT="parabolicAnchorRule kappt den Wert (da außerhalb 0...1)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670025133845" ID="ID_1582569279" MODIFIED="1670025153962" TEXT="infolgedessen sind alle weiteren Berechnungen trivial / no-op"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670025155874" FOLDED="true" ID="ID_725576556" MODIFIED="1670205093181" TEXT="aber: der Offset wird gekappt">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670025172247" ID="ID_962949808" MODIFIED="1670025190742" TEXT="konzeptionelles Problem im Time-handling-Framework">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670025194925" ID="ID_674387327" MODIFIED="1670025296382" TEXT="Offsets und Durations könnten 2*Time::MAX (bzw MIN) akzeptieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rein numerisch würde das gehen, da ich Time::MAX | MIN sinnigerweise auf INT_MAX / 30 gesetzt habe. Das war vorausschauend....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670025229777" ID="ID_1471304702" MODIFIED="1670025251370" TEXT="aber sie gehen alle stur durch TimeValue, und der kappt auf 1*Time::MAX (bzw MIN)"/>
|
|
<node COLOR="#435e98" CREATED="1670025302707" ID="ID_408211429" MODIFIED="1670517740842" TEXT="Lösung: Loch bohren">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1670025330923" ID="ID_664088863" MODIFIED="1670025372823" TEXT="das aktuelle Verhalten ist widersinnig und überraschend">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es untergräbt gradezu den Sinn dedizierter Zeit-Entitäten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1670025386651" ID="ID_1227027753" MODIFIED="1670025402822" TEXT="Idee: der copy-ctor ist nicht limitiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670025414136" ID="ID_1966020819" MODIFIED="1670517721820" TEXT="Probleme und Aufgaben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670025543263" ID="ID_528446508" MODIFIED="1670120677591" TEXT="neue Limitierungs-Funktion schaffen (± Duration::MAX)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670025513339" ID="ID_1622564783" MODIFIED="1670120675981" TEXT="der Differenz-ctor muß größere Offsets konstruieren können">
|
|
<arrowlink COLOR="#1bb78b" DESTINATION="ID_806986637" ENDARROW="Default" ENDINCLINATION="230;-11;" ID="Arrow_ID_613938878" STARTARROW="None" STARTINCLINATION="-266;12;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670025579708" ID="ID_967783770" MODIFIED="1670120673953" TEXT="neuer ctor für FSecs">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670025655456" ID="ID_79471093" MODIFIED="1670120670775" TEXT="die Funktion Offset::abs() neu definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670025671469" ID="ID_807444515" MODIFIED="1670025688298" TEXT="bisher konstruiert sie einen TimeValue, und kappt deshalb">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670025690862" ID="ID_1913450557" MODIFIED="1670080620421" TEXT="Idee: sie konstruiert eine Duration">
|
|
<arrowlink COLOR="#fefdb9" DESTINATION="ID_482497794" ENDARROW="Default" ENDINCLINATION="-192;-7;" ID="Arrow_ID_1014085079" STARTARROW="None" STARTINCLINATION="-207;16;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670025987045" ID="ID_1491328900" MODIFIED="1670120834295" TEXT="Duration braucht eine »Hintertür«">
|
|
<arrowlink COLOR="#26b81b" DESTINATION="ID_1754685572" ENDARROW="Default" ENDINCLINATION="331;-981;" ID="Arrow_ID_636518434" STARTARROW="None" STARTINCLINATION="-1095;84;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670026021871" ID="ID_1872786617" MODIFIED="1670026051423" TEXT="....durch welche man explizit einen Wert einbringen kann"/>
|
|
<node CREATED="1670026054003" ID="ID_873519529" MODIFIED="1670026069149" TEXT="und der nicht durch die Limitierung der Basis-Klasse TimeValue läuft"/>
|
|
<node CREATED="1670026074664" ID="ID_1460012408" MODIFIED="1670027376431" TEXT="diese Hintertür darf nicht offensichtlich sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
auf den ersten Blick darf es nicht aussehen wie "aha, und hier kann ich alles machen"
|
|
</li>
|
|
<li>
|
|
so wie der Zugang beschrieben ist, ist er völlig logisch und konsistent
|
|
</li>
|
|
<li>
|
|
die erweiterte Möglichkeit erschließt sich erst dem aufmerksamen Leser
|
|
</li>
|
|
<li>
|
|
diese erweiterte Möglichkeit erweist sich aber letztlich als nichts anderes als die Konsequenz der formalen Definition
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670026089995" ID="ID_5043644" MODIFIED="1670026098048" TEXT="und sie darf keinen Mißbrauch gestatten">
|
|
<node CREATED="1670026101388" ID="ID_848547621" MODIFIED="1670026120917" TEXT="also die µ-Ticks müssen nachher positiv sein"/>
|
|
<node CREATED="1670026121626" ID="ID_1970749903" MODIFIED="1670026130300" TEXT="und limitiert auf Duration::MAX"/>
|
|
</node>
|
|
<node COLOR="#690f14" CREATED="1670026155933" ID="ID_1357490453" MODIFIED="1670079761362" TEXT="Idee: die Limitierung auf TimeValue per ctor-Parameter steuerbar machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
das wäre dann ein ctor mit einem 2. Argument
|
|
</li>
|
|
<li>
|
|
wer so einen ctor aufruft, weiß was er tut
|
|
</li>
|
|
<li>
|
|
das könnte auch später in eine MicroTic-Basisklasse übernommen werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1670027393582" ID="ID_630920961" MODIFIED="1670027410287" TEXT="damit würden wir über den normalen Basis-ctor eintreten"/>
|
|
<node CREATED="1670027412179" ID="ID_558474187" MODIFIED="1670027420848" TEXT="und Werte über den copy-ctor übernehmen können"/>
|
|
<node CREATED="1670027457629" ID="ID_730521318" MODIFIED="1670027484830" TEXT="der TimeValue-ctor könnte dann sogar tatsächlich die Limitierung enforcen"/>
|
|
<node CREATED="1670079580092" ID="ID_1783175998" MODIFIED="1670079740173" TEXT="Idee verworfen! das wird zu explizit und zu offen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das versaut den bisher sehr sauberen Code von TimeValue, und läd gradezu dazu ein, hier beliebige Werte zu konstruieren. Im Hinblick darauf, daß ich umgestalten möchte TimeValue ⟶ MicroTicks, würde damit die Daseinsberechtigung untergraben, denn man kann nun nicht mehr sicher sein, daß MicroTicks ein <i>sicherer Wert </i>ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670079773858" ID="ID_1230606534" MODIFIED="1670120643313" TEXT="protected Delta-Konstruktur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670079791241" ID="ID_1046215971" MODIFIED="1670079812814" TEXT="wasseridcht, da nur von abgeleiteten Klassen aufgerufen"/>
|
|
<node CREATED="1670079817657" ID="ID_1263461807" MODIFIED="1670079837199" TEXT="nimmt zwei Argumente und macht unmittelbar die limitierte Offset-Berechnung"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670079953176" ID="ID_482497794" MODIFIED="1670120655974" TEXT="Duration muß selber für die Implementierung des Absolutbetrages sorgen">
|
|
<linktarget COLOR="#fefdb9" DESTINATION="ID_482497794" ENDARROW="Default" ENDINCLINATION="-192;-7;" ID="Arrow_ID_1014085079" SOURCE="ID_1913450557" STARTARROW="None" STARTINCLINATION="-207;16;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1670080498535" ID="ID_1961138610" MODIFIED="1670120658621" TEXT="der ctor Duration(Offset) macht diese Umwandlung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670080522251" ID="ID_1399417381" MODIFIED="1670120660266" TEXT="alle anderen Konstruktoren werden darauf aufgebaut">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670120920391" ID="ID_1544328925" MODIFIED="1670120940299" TEXT="bin nicht wirklich glücklich mit dem Ergebnis">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1670120943775" ID="ID_1968873669" MODIFIED="1670120966072" TEXT="wir verwenden nun doch an einigen Stellen buildRaw_() und _raw()"/>
|
|
<node CREATED="1670120968395" ID="ID_189852460" MODIFIED="1670121014289" TEXT="noch schlimmer: ich muß jetzt Duration::MAX explizit per reinterpret_cast konstruieren"/>
|
|
<node CREATED="1670121025020" ID="ID_1030076787" MODIFIED="1670121088591" TEXT="⟹ abgeleitete Klassen haben nicht wirklich den Zugangs-Weg, den sie brauchen"/>
|
|
<node CREATED="1670121089738" ID="ID_1726489244" MODIFIED="1670121157461" TEXT="und der Umweg über Raw ist notwendig, die Zeit-Rechenfunktionen reichen nicht"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670121166296" ID="ID_1078651329" MODIFIED="1670121217977" TEXT="heißt: die Limitierung sitzt an der falschen Stelle">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670120849448" FOLDED="true" ID="ID_633048851" MODIFIED="1670517734261" TEXT="QuantiserBasics_test scheitert">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670120873385" ID="ID_1718461090" MODIFIED="1670120892890" TEXT="er hat die bisher bestehende Limitierung von Duration explizit abgetestet"/>
|
|
<node CREATED="1670120893850" ID="ID_788600909" MODIFIED="1670120906512" TEXT="gut so, aber jetzt muß ich diesen Test wieder verstehen....">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1670191477920" ID="ID_1536550302" MODIFIED="1670191505143" TEXT="der Test ist ja wirklich schön „basic“">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1670191507368" ID="ID_1611277271" MODIFIED="1670191525161" TEXT="was hier scheitert ist eine Nebensache"/>
|
|
<node CREATED="1670191526749" ID="ID_1074184920" MODIFIED="1670191648400" TEXT="dokumentiert lediglich diese unsinnige Limitierung von Offset | Duration">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ganz dunkel kommt mir die Erinnerung an eine „kognitive Dissonanz“ — die ich dann schell unter den Teppich gekehrt hatte, indem ich sie mit einem Assert dokumentierte....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670191650385" ID="ID_1618349097" MODIFIED="1670191678988" TEXT="muß also eigentlich nur diese nebenbei-Assertion der besseren Lösung anpassen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670191680385" ID="ID_1961622718" MODIFIED="1670197933608" TEXT="sollte bei der Gelegenheit den Test erweitern und die Grenzen ausreizen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670191697554" ID="ID_1632102794" MODIFIED="1670191731569" TEXT="zwei weitere Test-Intervalle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1670191712394" ID="ID_1670947823" MODIFIED="1670191745192" TEXT="größer als Time::MAX aber kleiner als Duration::MAX">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670191723322" ID="ID_299394278" MODIFIED="1670191744039" TEXT="exakt Duration::MAX">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670191732657" ID="ID_1301403557" MODIFIED="1670191739848" TEXT="kombinieren mit Offset">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670191753771" ID="ID_838942043" MODIFIED="1670197700477" TEXT="Nebenbei bemerkt: das Grid::gridAligned() - API ist „überraschend“">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670191803951" ID="ID_62422663" MODIFIED="1670191874006" TEXT="das Ergebnis ist relativ zum Grid-Origin">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1670191815870" ID="ID_1441457979" MODIFIED="1670191824182" TEXT="tatsächlich so, ist auch so dokumentiert"/>
|
|
<node CREATED="1670191825469" ID="ID_64245414" MODIFIED="1670191888904" TEXT="trotzdem schräg — Input absolut, output relativ zum Origin">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670191890964" ID="ID_77008687" MODIFIED="1670192169799" TEXT="gibts dafür einen Grund?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1670191912001" ID="ID_1930426088" MODIFIED="1670191918387" TEXT="Verwendungen: nur Tests">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1670191945933" ID="ID_838705253" MODIFIED="1670192032827" TEXT="Grid::timeOf() funktioniert andres (und wie erwartet)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und die unterliegende lumiera_time_of_gridpoint weicht da ebenfalls auffällig ab...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670192005076" ID="ID_1578782665" MODIFIED="1670192067197" TEXT="Grid::timeOf() hat reale Verwendung in der Timecode-Handhabung"/>
|
|
<node CREATED="1670192068956" ID="ID_1880098778" MODIFIED="1670192159480" TEXT="Fazit: das ist ein »hexagonales Rad«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....also ein Feature, das zwar auf theoretischer Basis entwickelt wurde, aber nur im testgetriebenen Kontext; hier wohl entstanden aus der implementierungsmäßigen Symmetrie zu Grid::gridPoint(n)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#690f14" CREATED="1670192170956" ID="ID_1026606570" MODIFIED="1670201051650" TEXT="API ändern: gridAlign() soll den Origin mit einschließen">
|
|
<icon BUILTIN="yes"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1670200909516" ID="ID_1643706345" MODIFIED="1670200945558" TEXT="besser doch nicht: die Funtion wäre dann nämlich komplett redundant"/>
|
|
<node CREATED="1670200914583" ID="ID_316481460" MODIFIED="1670201239789" TEXT="die gewünschte Funktion gibt es bereits auf dem Quantiser-API">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">TimeValue Quantiser::materialise(TimeValue const& raw) { return timeOf (gridPoint (raw)); }</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1670201304802" ID="ID_1724553119" MODIFIED="1670201393006" TEXT="und letztere hat zudem den Vorteil, daß sie nicht clippt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
weil die Rechnung komplett auf Implementierungs-Ebene passiert, mit int64_t
|
|
</li>
|
|
<li>
|
|
unter der Maßgabe daß die auftretenden Werte dahingehend limititert sind, und daher auch noch die Summe zum Origin ohne wrap-around berechnet werden kann
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670200952970" ID="ID_2558241" MODIFIED="1670197706677" TEXT="API-Funtkion umbenennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670200964176" ID="ID_795458621" MODIFIED="1670201044967" TEXT="gridAlign() ⟼ gridLocal()"/>
|
|
<node CREATED="1670201059514" ID="ID_489288280" MODIFIED="1670201082523" TEXT="das macht dann wenigstens den Unterschied klar">
|
|
<node CREATED="1670201083498" ID="ID_1913733433" MODIFIED="1670201094684" TEXT="Input: eine globale freie Zeit"/>
|
|
<node CREATED="1670201095403" ID="ID_1247848116" MODIFIED="1670201105896" TEXT="Output: eine grit-relative, quantisierte Zeit"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670027504991" ID="ID_824635341" MODIFIED="1670207132035" TEXT="Tests ergänzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670207096977" ID="ID_1058283055" MODIFIED="1670207102076" TEXT="nicht mehr viel zu tun"/>
|
|
<node CREATED="1670207102815" ID="ID_379496016" MODIFIED="1670207118027" TEXT="füge ein paar Extremwerte für TimeValule_test hinzu"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670201406958" ID="ID_622847359" MODIFIED="1670205084655" TEXT="leider wird er aber immer noch gekappt....">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1670201771912" ID="ID_1540566423" MODIFIED="1670201786749" TEXT="das liegt nun daran, daß wir automatisch in eine TimeVar umrechnen"/>
|
|
<node COLOR="#338800" CREATED="1670204890068" ID="ID_671165920" MODIFIED="1670207195581" TEXT="als Offset markieren genügt">
|
|
<arrowlink COLOR="#46c71d" DESTINATION="ID_806986637" ENDARROW="Default" ENDINCLINATION="96;5;" ID="Arrow_ID_1094641771" STARTARROW="None" STARTINCLINATION="-3;83;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670204908278" ID="ID_947864676" MODIFIED="1670204917446" TEXT="einserseits schön..."/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670204918941" ID="ID_1258511726" LINK="#ID_1144294293" MODIFIED="1670204991899" TEXT="andererseits irritierend und ärgerlich">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1670205019071" ID="ID_699039716" MODIFIED="1670205030858" TEXT="nach logischen Prinzipien nicht wirklich nachvollziehbar"/>
|
|
<node CREATED="1670205031566" ID="ID_1841899173" MODIFIED="1670205041041" TEXT="liegt an der konkreten Definition der Operatoren"/>
|
|
<node CREATED="1670205042401" ID="ID_754662783" MODIFIED="1670205067436" TEXT="wenn Offset rechts ⟹ keine Limitierung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670207153549" ID="ID_806986637" MODIFIED="1670207252721" TEXT="mit diesem Fix im Time-Framework funktioniert der Test">
|
|
<linktarget COLOR="#1bb78b" DESTINATION="ID_806986637" ENDARROW="Default" ENDINCLINATION="230;-11;" ID="Arrow_ID_613938878" SOURCE="ID_1622564783" STARTARROW="None" STARTINCLINATION="-266;12;"/>
|
|
<linktarget COLOR="#46c71d" DESTINATION="ID_806986637" ENDARROW="Default" ENDINCLINATION="96;5;" ID="Arrow_ID_1094641771" SOURCE="ID_671165920" STARTARROW="None" STARTINCLINATION="-3;83;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235735966" ID="ID_1230717897" MODIFIED="1671235745618" TEXT="exzessives Expandieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235746837" ID="ID_1201391877" MODIFIED="1671235772450" TEXT="kombinieren sehr kleiner Pixelzahl mit sehr großer Metrik">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235773464" ID="ID_266930117" MODIFIED="1671235786406" TEXT="relatives Ansteuern extremer Positionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235820835" ID="ID_963558104" MODIFIED="1671235836226" TEXT="aber dadurch können wir nun bis an die Domain-Grenzen gehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1668180120032" ID="ID_346213896" MODIFIED="1671235860671" TEXT="Grenzen des Zeitformats">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1671235864869" ID="ID_234220527" MODIFIED="1671235876420" TEXT="Time::MAX und Time::MIN">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235876916" ID="ID_1550686390" MODIFIED="1671235881443" TEXT="Duration::MAX">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671235882256" ID="ID_1895654238" MODIFIED="1671235893107" TEXT="Einspeisen von Werten außerhalb der Domain">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1671324283797" ID="ID_867107887" MODIFIED="1679362063105" TEXT="gemäß Requirement-Konzept integrieren">
|
|
<arrowlink COLOR="#955977" DESTINATION="ID_748757781" ENDARROW="Default" ENDINCLINATION="-318;688;" ID="Arrow_ID_1882192055" STARTARROW="None" STARTINCLINATION="-49;-276;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1672708781597" ID="ID_1653405728" MODIFIED="1672708797527" TEXT="Change-Listener verdrahtet mit TimelineLayout::signalStructureChange">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672708802759" ID="ID_412094029" MODIFIED="1672708819294" TEXT="Interface DisplayMetric implementiert durch Rückgriff auf das ZoomWindow">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672883648918" FOLDED="true" ID="ID_1140551016" MODIFIED="1673918644481" TEXT="Zugangsweg schaffen für ZoomWindow-Aktuatoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1672883866721" ID="ID_265373712" MODIFIED="1672883891409" TEXT="jeweils anzubinden...">
|
|
<node CREATED="1672883669691" ID="ID_233898229" MODIFIED="1672883705186" TEXT="horizontale Scrollbar"/>
|
|
<node CREATED="1672883684145" ID="ID_1407291054" MODIFIED="1672883701874" TEXT="Ermittlung der realen Pixel-Weite"/>
|
|
</node>
|
|
<node CREATED="1672883854586" ID="ID_676447060" MODIFIED="1672952350546" TEXT="Interface/Architektur">
|
|
<node CREATED="1672883916450" ID="ID_624038632" MODIFIED="1672883920077" TEXT="Möglichkeiten">
|
|
<node CREATED="1672883927393" ID="ID_137422584" MODIFIED="1672883937611" TEXT="ZoomWindow& per DI">
|
|
<node CREATED="1672884659498" ID="ID_183190051" MODIFIED="1672952301593" TEXT="konzeptionell sauber">
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1672884699265" ID="ID_1546365198" MODIFIED="1672884715498" TEXT="jeweils ein zusätzliches (Referenz)-Feld">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
<node CREATED="1672942812195" ID="ID_113255429" MODIFIED="1672942843359" TEXT=" Zugang zu low-level-Funktionalität (breites Interface)">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672883940990" ID="ID_545229135" MODIFIED="1672883957585" TEXT="Proxy-Interface auf dem DisplayManager">
|
|
<node CREATED="1672884731013" ID="ID_648800678" MODIFIED="1672942853799" TEXT="typischerweise genau da wo auch DisplayManager ohnehin verdrahtet ist">
|
|
<icon BUILTIN="up"/>
|
|
<node CREATED="1672884819665" ID="ID_593694932" MODIFIED="1672884824476" TEXT="BodyCanvasWidget"/>
|
|
<node CREATED="1672884832528" ID="ID_202520630" MODIFIED="1672884839611" TEXT="AbstractTrackRenderer"/>
|
|
<node CREATED="1672884991017" ID="ID_1411622586" MODIFIED="1672884996861" TEXT="CanvasHook::getMetric">
|
|
<node CREATED="1672885022278" ID="ID_224159108" MODIFIED="1672885039960" TEXT="ClipPresenter::DragRelocateObserver"/>
|
|
<node CREATED="1672885043371" ID="ID_419966736" MODIFIED="1672885045903" TEXT="ClipWidget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672942888477" ID="ID_344109754" MODIFIED="1672957304300" TEXT="notwendigerweise virtual calls (2 Indirektionen)">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
<node CREATED="1672949981338" ID="ID_1962786517" MODIFIED="1672949994745" TEXT="überdehnt die Bedeutung des DisplayManager">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672956771420" ID="ID_593557107" MODIFIED="1672956799788" TEXT="Update-Signal(s) auf dem DisplayManager">
|
|
<node CREATED="1672957191000" ID="ID_76359433" MODIFIED="1672957382867" TEXT="explizit zweckgebunden">
|
|
<linktarget COLOR="#485dbf" DESTINATION="ID_76359433" ENDARROW="Default" ENDINCLINATION="-176;17;" ID="Arrow_ID_167764533" SOURCE="ID_1233770503" STARTARROW="None" STARTINCLINATION="77;-6;"/>
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1672957201677" ID="ID_358714069" MODIFIED="1672957257339" TEXT="ZoomWindow selber bleibt Implementierungs-Detail">
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1672957271741" ID="ID_1521993338" MODIFIED="1672957286257" TEXT="nur ein einfach-indirekter (funtion-pointer) call">
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1672957315863" ID="ID_934216010" MODIFIED="1672957330972" TEXT="Komplexer und Gesamt-Funktion ist undurchsichtig">
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672957336020" ID="ID_1233770503" MODIFIED="1672959113510" TEXT="Entscheidung: Signale!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ja!!!<br />Hat lange gedauert, bis ich da drauf gekommen bin; aber das ist so eindeutig die richtige und angemessene Lösung, daß ich jetzt ausgesprochen erleichtert bin.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#485dbf" DESTINATION="ID_76359433" ENDARROW="Default" ENDINCLINATION="-176;17;" ID="Arrow_ID_167764533" STARTARROW="None" STARTINCLINATION="77;-6;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672952339119" ID="ID_27417257" MODIFIED="1672952344269" TEXT="Art der Einbindung">
|
|
<node CREATED="1672952358471" ID="ID_577116696" MODIFIED="1672952449076" TEXT="spezieller Twist hier: Aktuatoren arbeiten pixel-basiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle Steuersignale aus dem GUI kommen in Pixel-Einheiten, entweder absolut oder relativ; das ZoomWindow selber aber arbeitet in Zeit-Einheiten (und das ist auch seine Aufgabe).
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1672952474418" ID="ID_1703019039" MODIFIED="1673918599660" TEXT="unnötige Umwege über Zeit-Werte möglichst vermeiden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1672952510381" ID="ID_557400282" MODIFIED="1672952543555" TEXT="insofern die Rechnungen als präzise gelten"/>
|
|
<node CREATED="1672952549168" ID="ID_1479986541" MODIFIED="1672952631231" TEXT="aber die Werte-Begrenzungen berücksichtigen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in Grenzbereichen greift das ZoomWindow ein und begrenzt Ausschläge; selbst wenn der angeschlossene Code direkt die Pixel-Werte verwendet, muß trotzdem auf solche Eingriffe geprüft werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673918575368" ID="ID_1602314348" MODIFIED="1673918594542" TEXT="aber zumindest die Ausdehnung muß ich über die Zeit-Werte ausrechnen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672952644887" ID="ID_393917969" MODIFIED="1672952661568" TEXT="ggfs aber Stellung der Scrollbars prüfen und rekalibrieren"/>
|
|
<node CREATED="1672956427506" ID="ID_1572841890" MODIFIED="1673918605435" TEXT="Struktur">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1672956446738" ID="ID_419294832" MODIFIED="1672960594911" TEXT="Adjustment::valueChanged() ⟼ syncZoomWindow(Adjustment&)"/>
|
|
<node CREATED="1672956504172" ID="ID_1390665381" MODIFIED="1672960626188" TEXT="BodyCanvasWidget::on_size_allocate() ⟼ sizeZoomWindow()">
|
|
<node CREATED="1672960628748" ID="ID_31432666" MODIFIED="1672960671941" TEXT="Display-Evaluation ⟶ update Adjustment based on ZoomWindow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1672787519757" ID="ID_37048779" MODIFIED="1673918673633" TEXT="Pixel-Weite kalibrieren: zu Beginn der Display-Evaluation einschleifen">
|
|
<arrowlink COLOR="#4a759a" DESTINATION="ID_1189311522" ENDARROW="Default" ENDINCLINATION="1548;60;" ID="Arrow_ID_751989601" STARTARROW="None" STARTINCLINATION="1439;57;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1672798860387" ID="ID_981451006" MODIFIED="1673747058376" TEXT="Feedback auf Scrolling">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1672798873057" ID="ID_133007183" MODIFIED="1678839568091" TEXT="horizontale Canvas-Breite kommt nicht korrekt an">
|
|
<arrowlink COLOR="#503fac" DESTINATION="ID_1699842831" ENDARROW="Default" ENDINCLINATION="-1384;79;" ID="Arrow_ID_927325344" STARTARROW="None" STARTINCLINATION="-1848;-74;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#338800" CREATED="1672969399236" ID="ID_105188286" MODIFIED="1672969452360" TEXT="Logik überarbeitet: Werte kommmen jetzt an">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672969412314" FOLDED="true" ID="ID_128441040" MODIFIED="1673917833235" TEXT="Fehler: horizontale Ausdehnung instabil">
|
|
<linktarget COLOR="#6a236e" DESTINATION="ID_128441040" ENDARROW="Default" ENDINCLINATION="-511;34;" ID="Arrow_ID_1077460507" SOURCE="ID_637545532" STARTARROW="None" STARTINCLINATION="-190;-19;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1673020358513" ID="ID_1745939268" MODIFIED="1673020364580" TEXT="Beobachtung(DUMP)">
|
|
<node CREATED="1673020365563" ID="ID_1034029673" MODIFIED="1673020378010" TEXT="layout_.getPixSpan().delta() verhält sich "zyklisch""/>
|
|
<node CREATED="1673824080045" ID="ID_1921636015" MODIFIED="1673824095119" TEXT="und zwar der End-Wert; dieser wird bisweilen negativ und wächst dann wieder"/>
|
|
<node CREATED="1673824100547" ID="ID_1250952994" MODIFIED="1673824127603" TEXT="auffällig: es tritt häufiger auf, wenn man die Allokation nach Verkleinerung wieder vergrößert..."/>
|
|
</node>
|
|
<node CREATED="1673917066250" ID="ID_275241960" MODIFIED="1673917076486" TEXT="Dump ausbauen">
|
|
<node CREATED="1673917077557" ID="ID_50462687" MODIFIED="1673917088547" TEXT="die Berechneten (raw) Zeitwerte sind stabil"/>
|
|
<node CREATED="1673917089296" ID="ID_1095682897" MODIFIED="1673917099017" TEXT="es muß in der Umwandlung in Pixel passieren"/>
|
|
<node CREATED="1673917099760" ID="ID_1219466338" MODIFIED="1673917118899" TEXT="hier wird's mühsam (wir rufen mehrere virtuelle Funktionen auf)">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1673917123418" ID="ID_1029230100" MODIFIED="1673917129773" TEXT="Implementierung aufdoppeln"/>
|
|
<node CREATED="1673917130673" ID="ID_346555789" MODIFIED="1673917143894" TEXT="aber einen Debugging-String zurückgeben"/>
|
|
<node CREATED="1673917144608" ID="ID_124621928" MODIFIED="1673917149465" TEXT="mit zwischenergebnissen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1673917195121" ID="ID_1093667497" MODIFIED="1673917846467" TEXT="Integer-wrap-around">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1673917211656" ID="ID_564112023" MODIFIED="1673917230992" TEXT="4508000000/7282711sec kann nicht als 32-bit int dargestellt werden"/>
|
|
<node CREATED="1673917231867" ID="ID_830241934" MODIFIED="1673917246230" TEXT="vor der Division in int64_t umwandeln!"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1673917712508" ID="ID_807239340" MODIFIED="1673917831460" TEXT="Lösung: Division und trucate in 64-bit ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1673917753318" ID="ID_381118842" MODIFIED="1673917764871" TEXT="Downcast Ergebnis in 32-bit"/>
|
|
<node CREATED="1673917765612" ID="ID_1287873753" MODIFIED="1673917780494" TEXT="Assertion daß das Ergebnis in den Wertebereich paßt"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1672969457755" ID="ID_1145571154" MODIFIED="1674598990613" TEXT="Fehler: run-away in der Höhe bei wiederholter Display-Evaluation">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1672969484624" ID="ID_1370033195" MODIFIED="1672969500955" TEXT="die allozierte Content-Höhe wächst monoton">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1672969501989" ID="ID_1513242412" MODIFIED="1674599018497" TEXT="Verdacht: da nun erstmals re-Evaluationen stattfinden, wird ein Init-Fehler sichtbar">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1673020204201" ID="ID_130901033" MODIFIED="1673020213759" TEXT="Beobachtung (DUMP)">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1673020215292" ID="ID_1472123011" MODIFIED="1673020256186" TEXT="in der Tat: accomodateContentHeight() fügt laufend hinzu"/>
|
|
<node CREATED="1673020257307" ID="ID_1535375022" MODIFIED="1673020292144" TEXT="was allerdings wächst ist der Beitrag von head_.calcContentHeight()">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1673021362882" ID="ID_954750461" MODIFIED="1673021435861" TEXT="TrackHeadWidget::accommodateContentHeight -> increaseContentHeight() ; size-request + Δ">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1673022453591" ID="ID_1189073820" MODIFIED="1673022471744" TEXT="der tatsächliche Aufschlag stammt jeweils aus der 2.Phase: DisplayFrame::sync_and_balance"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673027617885" ID="ID_1539603067" MODIFIED="1678839452688" TEXT="Feststellungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1673027738477" FOLDED="true" ID="ID_910627159" MODIFIED="1673027741960" TEXT="Problem-1">
|
|
<node CREATED="1673027628894" ID="ID_642294954" MODIFIED="1673027656160" TEXT="sync_and_balance schlägt zusätzliches Padding auf"/>
|
|
<node CREATED="1673027656904" ID="ID_748230993" MODIFIED="1673027704972">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im nächsten Zyklus wird das aber als Head-<b>content</b> gewertet ⟹ body-content wird erhöht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1673027710473" ID="ID_1922165032" MODIFIED="1673027727174" TEXT="⟹ sync_and_balance erkennt wieder eine Diskrepanz"/>
|
|
<node CREATED="1673027813155" ID="ID_217654042" MODIFIED="1673027871603" TEXT="padding und content im Head werden vermischt">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1673029325047" ID="ID_460101701" MODIFIED="1673029337394" TEXT="au weia: diese Berechnungen sind aber noch relativ "vorläufig""/>
|
|
<node CREATED="1673029338126" ID="ID_1059214961" MODIFIED="1673029685791">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damals war ich <i>zufrieden, </i>sobald es „halbwegs“ funktioniert hat
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
erster Draft ab718ed6aa9d<br />hat nicht funktioniert, vmtl da ich letztlich auf widget.get_allocation().hight() aufgesetzt habe, und das kann initial noch null sein
|
|
</li>
|
|
<li>
|
|
überarbeitet ab718ed6aa9db<br />dann habe ich rein auf Basis der einzelnen Zellen einen denfensiven Berechnungsweg verwendet: nimm MAX(preferred_height, reale Allokation); habe dies aber nicht angepaßt auf mehrere Kind-Tracks, oder vielleicht doch? oder die Logik verkehrt herum??
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1673029688327" ID="ID_1637216543" MODIFIED="1673029700984" TEXT="jedenfalls wurde nie klar definiert, was hier "content" sein soll">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1673303781860" ID="ID_1183053320" MODIFIED="1673303787059" TEXT="Belegung der Felder">
|
|
<node CREATED="1673303792878" ID="ID_15099340" MODIFIED="1673303858649" TEXT="0.Zeile / span=2 : Name (ElementBox)"/>
|
|
<node CREATED="1673303859525" ID="ID_1941277838" MODIFIED="1673303874479" TEXT="1.Zeile: Tree-Graph">
|
|
<node CREATED="1673303876412" ID="ID_1855860657" MODIFIED="1673303929005" TEXT="»Content« (falls leer)"/>
|
|
<node CREATED="1673303930118" ID="ID_450860952" MODIFIED="1673303937582" TEXT="1. Kind"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673031545264" ID="ID_52427355" MODIFIED="1673031561329" TEXT="das Padding wird aufgeschlagen auf (left=1, top=0)"/>
|
|
<node CREATED="1673031562629" ID="ID_1138131947" MODIFIED="1673031633192" TEXT="die calcContentHeitght() wertet aus MAX( (0,0), (1,0))">
|
|
<node CREATED="1673031610727" ID="ID_1604141819" MODIFIED="1673031618290" TEXT="also alle Zellen in der 1.Zeile"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1673312714420" ID="ID_152822454" MODIFIED="1673312733027" STYLE="fork" TEXT="das ist wohl die Inkonsistenz hier">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673314655497" ID="ID_525789725" MODIFIED="1673314662292" TEXT="also beides getrennt handhaben">
|
|
<node CREATED="1673314663880" ID="ID_935563695" MODIFIED="1673314699327" TEXT="die contentHeight wirklich im 4.Quadranten anwenden"/>
|
|
<node CREATED="1673314701753" ID="ID_1401546681" MODIFIED="1673314779597" TEXT="zusätzlich eine Expansion einführen, die aber nicht in die contentHeight eingeht!">
|
|
<node CREATED="1673745725545" ID="ID_527844757" MODIFIED="1673745739164" TEXT="für die "content height" wirklich nur die Content-Felder auswerten"/>
|
|
<node CREATED="1673745740224" ID="ID_321245152" MODIFIED="1673745785441" TEXT="zusätzliche Expansion in einem anderen Feld machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
z.B. in (0,1) = Struktur-Graph
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673320252819" ID="ID_754862223" MODIFIED="1674598984710" TEXT="bricht noch nicht den Zyklus">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1673320275690" ID="ID_1903820221" MODIFIED="1673745681092" TEXT="jetzt ist der Head-content von Anfang an zu groß">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673320299575" ID="ID_1836748064" MODIFIED="1674599062379" TEXT="aber warum stabilisiert sich dieser nicht?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1673745636138" ID="ID_1839905420" MODIFIED="1673745695183" TEXT="Grund-1: weil der Head-content sich selbständig expandiert"/>
|
|
<node CREATED="1674599035390" ID="ID_1364664491" MODIFIED="1674599060112" TEXT="Grund-2 : weil dann ein Feedback über die Body-Höhe stattfindet"/>
|
|
</node>
|
|
<node CREATED="1673705464388" ID="ID_1052559390" MODIFIED="1673705515338" TEXT="hilfreich ist: property_expand() = false im Content-Bereich"/>
|
|
<node COLOR="#338800" CREATED="1673747106233" ID="ID_830917303" MODIFIED="1673747119474" TEXT="damit ist das Problem für Blatt-Tracks gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1673747138573" ID="ID_1650195806" MODIFIED="1674598982406" TEXT="aber Tracks mit Content und Kind-Tracks wachsen weiterhin">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1674598748501" ID="ID_1842930323" MODIFIED="1674598977652" TEXT="die Berechnung im TrackHead ist insgesamt inkonsistent">
|
|
<arrowlink COLOR="#689ba2" DESTINATION="ID_43972117" ENDARROW="Default" ENDINCLINATION="198;928;" ID="Arrow_ID_1080676559" STARTARROW="None" STARTINCLINATION="-1589;-3311;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1674598781624" ID="ID_1267230309" MODIFIED="1674598980470" TEXT="Size-Requests werden inkrementiert anstatt sie festzusetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673027746843" FOLDED="true" ID="ID_484113914" MODIFIED="1673027750543" TEXT="Problem-2">
|
|
<node CREATED="1673027751867" ID="ID_1170742278" MODIFIED="1673027768260" TEXT="size-request im Head wächst monoton"/>
|
|
<node CREATED="1673027770065" ID="ID_1809846655" MODIFIED="1673027783498" TEXT="body content-height wächst monoton"/>
|
|
<node CREATED="1673027796693" ID="ID_162051390" MODIFIED="1673027805715" TEXT="es fehlt ein reset">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1678839045859" ID="ID_641819217" MODIFIED="1678839055425" TEXT="3/23: das gilt weiterhin">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1678839056977" ID="ID_1367619034" MODIFIED="1678839515363" TEXT="Problem vorläufig entschärft durch konsistente Handhabung im Track-Head">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Zwischenfazit</u>: das Problem wurde erst dadurch sichtbar, daß in der Logik im Track-Head innere Widersprüche bestanden; nach Durchlaufen eines Abstimmungszyklus bestand sofort wieder eine Diskrepanz, und das Layout konnte sich folglich nicht stabilisieren. <i><font color="#2e3084">Dies habe ich inzwischen behoben, </font></i>insofern nun das TrackHeadWidget grundsätzlich komplett ausformuliert ist, und alle Zuständigkeiten dort klar verteilt sind. Nach Durchlaufen einer Display-Evaluation ergibt sich nun in Summe genau der Wert, der der mit dem TrackBody abgestimmten Höhe entspricht.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dennoch besteht das grundsätzliche Problem weiterhin, und wird in dem Moment doch noch zu betrachten sein, wenn das Layout dynamisch auf Inhalte reagieren soll; denn immer noch <i>wachsen</i> die ermittelten Höhen <i>monoton an,</i> und es gibt keinen <i>Reset.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#57689a" DESTINATION="ID_1367619034" ENDARROW="Default" ENDINCLINATION="-147;128;" ID="Arrow_ID_50799002" SOURCE="ID_1930750315" STARTARROW="None" STARTINCLINATION="119;8;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1678839454033" ID="ID_1930750315" MODIFIED="1678839515363" TEXT="Problem vorläufig entschärft (und vertagt)">
|
|
<arrowlink COLOR="#57689a" DESTINATION="ID_1367619034" ENDARROW="Default" ENDINCLINATION="-147;128;" ID="Arrow_ID_50799002" STARTARROW="None" STARTINCLINATION="119;8;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673746034872" FOLDED="true" ID="ID_66895155" MODIFIED="1673747049281" TEXT="Segfault bei horizontalem Scroling">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1673746067311" ID="ID_154133331" MODIFIED="1673746074945" TEXT="Beobachtung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1673746076315" ID="ID_1475835480" MODIFIED="1673746096996" TEXT="TimelineLayout::syncZoomWindow(PAdjustment)"/>
|
|
<node CREATED="1673746101072" ID="ID_1560542600" MODIFIED="1673746109872" TEXT="Argument ist ein Null-ptr"/>
|
|
<node CREATED="1673746264291" ID="ID_920699526" MODIFIED="1673746274572" TEXT="Argument im Funktor gebunden auf: bodyCanvas_.get_focus_hadjustment()">
|
|
<node CREATED="1673746420584" ID="ID_175121956" MODIFIED="1673746454675" TEXT="was ist ein "focus_hadjustment"???">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">  /** Hooks up an adjustment to focus handling in a container, so when a child </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * of the container is focused, the adjustment is scrolled to show that </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * widget. This function sets the horizontal alignment. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * See Gtk::ScrolledWindow::get_hadjustment() for a typical way of obtaining </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * the adjustment and set_focus_vadjustment() for setting </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * the vertical adjustment. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * The adjustments have to be in pixel units and in the same coordinate </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * system as the allocation for immediate children of the container. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * @param adjustment An adjustment which should be adjusted when the focus is </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   * moved among the descendents of @a container. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">   */ </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">  void set_focus_hadjustment(const Glib::RefPtr<Adjustment>& adjustment); </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1673746457176" ID="ID_1981285766" MODIFIED="1673746728481" TEXT="da hab ich wohl die falsche Funktion erwischt???">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1673746730444" ID="ID_582249986" MODIFIED="1673746734951" TEXT="auto-complete...."/>
|
|
<node CREATED="1673746736759" ID="ID_893437203" MODIFIED="1673746739029" TEXT="bodyCanvas_.get_hadjustment()"/>
|
|
<node CREATED="1673746741315" ID="ID_513265997" MODIFIED="1673746750093" TEXT="das geht dann auf die contentArea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1673747021254" ID="ID_1805274819" MODIFIED="1673747047575" TEXT="richtig binden ⟹ Scrollbar reagiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673807997325" FOLDED="true" ID="ID_1009074242" MODIFIED="1673824061664" TEXT="Assertion-fail">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
0000001086: POSTCONDITION: body-canvas-widget.cpp:512: worker_3: maybeRebuildLayout: (not isnil (profile_)) DisplayEvaluation logic broken
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1673808698810" ID="ID_825689705" MODIFIED="1673808714792" TEXT="wahrscheinlicher Grund: signalStruktureChange ausgelöst"/>
|
|
<node COLOR="#435e98" CREATED="1673809260386" FOLDED="true" ID="ID_1757495179" MODIFIED="1673918456525" TEXT="Beobachtung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1673809555225" ID="ID_1752395100" MODIFIED="1673809557899" TEXT="stop-1">
|
|
<node CREATED="1673809269809" ID="ID_1319270486" MODIFIED="1673809274764" TEXT="im GUI-Thread"/>
|
|
<node CREATED="1673809352006" ID="ID_43730245" MODIFIED="1673809353849" TEXT="Gtk::Container_Class::check_resize_callback()"/>
|
|
<node CREATED="1673809381811" ID="ID_337647284" MODIFIED="1673809391005" TEXT="gtk_widget_size_allocate_with_baseline()"/>
|
|
<node CREATED="1673809276473" ID="ID_1203817142" MODIFIED="1673809295149" TEXT="bodyCanvas_.signal_size_allocate() ausgelöst"/>
|
|
<node CREATED="1673809430115" ID="ID_1967291627" MODIFIED="1673809442712" TEXT="⟼ TimelineLayout::sizeZoomWindow (Gtk::Allocation& alloc)"/>
|
|
<node CREATED="1673809466480" ID="ID_1184190765" MODIFIED="1673809494768" TEXT="ZoomWindow::calibrateExtension() ⟼ fireChangeNotification()"/>
|
|
<node CREATED="1673809517381" ID="ID_975841816" MODIFIED="1673809530033" TEXT="⟼ BodyCanvasWidget::slotStructureChange()"/>
|
|
</node>
|
|
<node CREATED="1673809653325" ID="ID_960514018" MODIFIED="1673809659071" TEXT="stop-2">
|
|
<node CREATED="1673809269809" ID="ID_963970163" MODIFIED="1673809274764" TEXT="im GUI-Thread"/>
|
|
<node CREATED="1673809685665" ID="ID_1008125357" MODIFIED="1673809693963" TEXT="Gtk::Widget_Class::draw_callback()"/>
|
|
<node CREATED="1673809708766" ID="ID_273943398" MODIFIED="1673809719360" TEXT="TimelineCanvas::on_draw()"/>
|
|
<node CREATED="1673809744969" ID="ID_1591443219" MODIFIED="1673821398443" TEXT="BodyCanvasWidget::maybeRebuildLayout() ⟼ layout_.triggerDisplayEvaluation()">
|
|
<arrowlink COLOR="#3c2f91" DESTINATION="ID_1442699048" ENDARROW="Default" ENDINCLINATION="95;12;" ID="Arrow_ID_1977514739" STARTARROW="None" STARTINCLINATION="-9;28;"/>
|
|
<arrowlink COLOR="#3c2f91" DESTINATION="ID_719594409" ENDARROW="Default" ENDINCLINATION="95;12;" ID="Arrow_ID_852227304" STARTARROW="None" STARTINCLINATION="-9;28;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673809820526" ID="ID_1282555495" MODIFIED="1673809823250" TEXT="stop-3">
|
|
<node CREATED="1673810027811" ID="ID_1442699048" MODIFIED="1673821392108" TEXT="im gleichen Callstack">
|
|
<linktarget COLOR="#3c2f91" DESTINATION="ID_1442699048" ENDARROW="Default" ENDINCLINATION="95;12;" ID="Arrow_ID_1977514739" SOURCE="ID_1591443219" STARTARROW="None" STARTINCLINATION="-9;28;"/>
|
|
</node>
|
|
<node CREATED="1673811079973" ID="ID_1459771595" MODIFIED="1673811082177" TEXT="TimelineLayout::establishLayout (DisplayEvaluation&)"/>
|
|
<node CREATED="1673810070508" ID="ID_285758476" MODIFIED="1673810073328" TEXT="bodyCanvas_.get_hadjustment()->set_value(pxOffset)">
|
|
<node CREATED="1673810084309" ID="ID_438775800" MODIFIED="1673810089799" TEXT="pxOffset=152"/>
|
|
<node CREATED="1673810159367" ID="ID_869315491" MODIFIED="1673810171891" TEXT="vorher: 153 (beim letzten Scrolliing)"/>
|
|
</node>
|
|
<node CREATED="1673810802131" ID="ID_1513475551" MODIFIED="1673810856912" TEXT="bodyCanvas_::hadjustment.property_value().signal_changed()">
|
|
<node CREATED="1673810863442" ID="ID_740887741" MODIFIED="1673810864566" TEXT="⟼ TimelineLayout::syncZoomWindow (PAdjustment hadj)"/>
|
|
<node CREATED="1673810881168" ID="ID_770428876" MODIFIED="1673810894275" TEXT="zoomWindow_.setVisibleStart (windowStart) ⟼ fireChangeNotification()"/>
|
|
<node CREATED="1673809517381" ID="ID_535606791" MODIFIED="1673812842543" TEXT="⟼ BodyCanvasWidget::slotStructureChange()">
|
|
<arrowlink COLOR="#4697c4" DESTINATION="ID_1775726398" ENDARROW="Default" ENDINCLINATION="80;-12;" ID="Arrow_ID_1301127863" STARTARROW="None" STARTINCLINATION="-284;18;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673812714835" ID="ID_1775726398" MODIFIED="1673812842543" TEXT="profile_.clear()">
|
|
<linktarget COLOR="#4697c4" DESTINATION="ID_1775726398" ENDARROW="Default" ENDINCLINATION="80;-12;" ID="Arrow_ID_1301127863" SOURCE="ID_535606791" STARTARROW="None" STARTINCLINATION="-284;18;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673812775683" ID="ID_1800881693" MODIFIED="1673812777742" TEXT="stop-4">
|
|
<node CREATED="1673810027811" ID="ID_719594409" MODIFIED="1673821395365" TEXT="im gleichen Callstack">
|
|
<linktarget COLOR="#3c2f91" DESTINATION="ID_719594409" ENDARROW="Default" ENDINCLINATION="95;12;" ID="Arrow_ID_852227304" SOURCE="ID_1591443219" STARTARROW="None" STARTINCLINATION="-9;28;"/>
|
|
</node>
|
|
<node CREATED="1673809744969" ID="ID_686562400" MODIFIED="1673821439684" TEXT="BodyCanvasWidget::establishLayout()">
|
|
<arrowlink COLOR="#3c2f91" DESTINATION="ID_1308718811" ENDARROW="Default" ENDINCLINATION="66;9;" ID="Arrow_ID_125967636" STARTARROW="None" STARTINCLINATION="32;22;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1673811186943" ID="ID_671439113" MODIFIED="1673811190535" TEXT="rootBody_->establishTrackSpace (profile_)"/>
|
|
<node CREATED="1673811200349" ID="ID_1198425081" MODIFIED="1673811206428" TEXT="baut Profile neu auf">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673820672711" ID="ID_1084465097" MODIFIED="1673820675362" TEXT="stop-5">
|
|
<node CREATED="1673810027811" ID="ID_1308718811" MODIFIED="1673821439684" TEXT="im gleichen Callstack">
|
|
<linktarget COLOR="#3c2f91" DESTINATION="ID_1308718811" ENDARROW="Default" ENDINCLINATION="66;9;" ID="Arrow_ID_125967636" SOURCE="ID_686562400" STARTARROW="None" STARTINCLINATION="32;22;"/>
|
|
</node>
|
|
<node CREATED="1673820676440" ID="ID_1428838878" MODIFIED="1673821379859" TEXT="BodyCanvasWidget::establishLayout ()">
|
|
<node CREATED="1673821503186" ID="ID_332793347" MODIFIED="1673821505330" TEXT="adjustCanvasSize(layout_.getPixSpan().delta(), contentHeight, rulerHeight)">
|
|
<node CREATED="1673821691053" ID="ID_1561772925" MODIFIED="1673821692313" TEXT="layout_.getPixSpan()"/>
|
|
<node CREATED="1673821707880" ID="ID_46999928" MODIFIED="1673821746745" TEXT="DUMP: ⟿ Δ(0, -476)"/>
|
|
</node>
|
|
<node CREATED="1673821574701" ID="ID_1681667823" MODIFIED="1673821855384">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
adjust (rulerCanvas_, canvasWidth <b><font color="#fc2020">≔0</font></b>, rulerHeight ≔11<font color="#41d448">✔</font>)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1673821774834" ID="ID_1418910368" MODIFIED="1673822078671" TEXT="rulerCanvas.set_size(0, 11);">
|
|
<arrowlink COLOR="#bf0e70" DESTINATION="ID_1137713906" ENDARROW="Default" ENDINCLINATION="128;6;" ID="Arrow_ID_184403276" STARTARROW="None" STARTINCLINATION="49;5;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1673821942380" ID="ID_1137713906" MODIFIED="1673822078671" TEXT="bodyCanvas_::hadjustment.property_value().signal_changed()">
|
|
<linktarget COLOR="#bf0e70" DESTINATION="ID_1137713906" ENDARROW="Default" ENDINCLINATION="128;6;" ID="Arrow_ID_184403276" SOURCE="ID_1418910368" STARTARROW="None" STARTINCLINATION="49;5;"/>
|
|
</node>
|
|
<node CREATED="1673822109021" ID="ID_1969505468" MODIFIED="1673822114353" TEXT="TimelineLayout::syncZoomWindow(hadjustment)">
|
|
<node CREATED="1673822205944" ID="ID_911661763" MODIFIED="1673822215169" TEXT="hadjustment wird nach pos gefract"/>
|
|
<node COLOR="#a41765" CREATED="1673822215895" ID="ID_145619270" MODIFIED="1673822785272" TEXT="pos ≔ 0">
|
|
<arrowlink COLOR="#ec5b91" DESTINATION="ID_847463371" ENDARROW="Default" ENDINCLINATION="151;-4;" ID="Arrow_ID_1064590055" STARTARROW="None" STARTINCLINATION="151;46;"/>
|
|
</node>
|
|
<node CREATED="1673822245795" ID="ID_1702472826" MODIFIED="1673822259565" TEXT="zoomWindow_.setVisibleStart (Time{0})"/>
|
|
</node>
|
|
<node CREATED="1673809517381" ID="ID_1945994324" MODIFIED="1673809530033" TEXT="⟼ BodyCanvasWidget::slotStructureChange()"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1673822368235" ID="ID_37222453" MODIFIED="1673822393376" TEXT="profile_.clear()">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1673822498449" ID="ID_969173291" MODIFIED="1673918448602" TEXT="Fazit: zwei Probleme">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1673822512176" ID="ID_838311135" MODIFIED="1673822561177">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
scrollPos ⟿ zoomWindow geändert, <i>nachdem</i> das Profil aufgebaut wurde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1673822842715" ID="ID_469521080" MODIFIED="1673822930226" TEXT="ohne den anderen Bug würde das hier aber nicht auftreten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn den pixSpan sollte sich ja grade eben nicht ändern, sondern nur der sichtbare Fenster-Ausschnitt; die Implementierung mit dem ZoomWindow zielt ja genau darauf, die Metrik konstant zu halten, selbst wenn sich das sichtbare Fenster (wie hier) ändert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1673822820583" ID="ID_1299254285" MODIFIED="1673822834376" TEXT="grundsätzilch kann man sowas nie ausschließen">
|
|
<node CREATED="1673822938342" ID="ID_62922350" MODIFIED="1673822959592" TEXT="es kann stets Dinge geben, die durch eine Layoutberechnung nachträglich invalidiert werden"/>
|
|
<node CREATED="1673822961603" ID="ID_1448263496" MODIFIED="1673822979878" TEXT="und deshalb müßte die Berechnung dann lediglich invalidiert und wiederholt werden"/>
|
|
<node CREATED="1673822981906" ID="ID_1546720017" MODIFIED="1673823013893" TEXT="...bis sie sich stabilisiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und <i>nur das </i>kann man vom Design her einfordern (daß sie sich stabilisiert und nicht in Oszillationen gerät)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1673823198796" ID="ID_1795675893" MODIFIED="1673824051687" TEXT="while-Schleife und nochmal berechnen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1673822589957" ID="ID_637545532" MODIFIED="1673822645422" TEXT="layout_.getPixSpan() entgleist">
|
|
<arrowlink COLOR="#6a236e" DESTINATION="ID_128441040" ENDARROW="Default" ENDINCLINATION="-511;34;" ID="Arrow_ID_1077460507" STARTARROW="None" STARTINCLINATION="-190;-19;"/>
|
|
<node COLOR="#435e98" CREATED="1673822656960" ID="ID_847463371" MODIFIED="1673918421685" TEXT="der End-Wert verhält sich »zyklisch« und wird bisweilen negativ">
|
|
<linktarget COLOR="#ec5b91" DESTINATION="ID_847463371" ENDARROW="Default" ENDINCLINATION="151;-4;" ID="Arrow_ID_1064590055" SOURCE="ID_145619270" STARTARROW="None" STARTINCLINATION="151;46;"/>
|
|
</node>
|
|
<node CREATED="1673822724035" ID="ID_1257160861" MODIFIED="1673822739708" TEXT="nur deshalb wird hier die Scroll-Position signifikant verschoben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1679358706913" ID="ID_1573983842" MODIFIED="1679358744427">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Erste Integration: <b>verhält sich korrekt</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678841457381" ID="ID_833023922" MODIFIED="1679362063105" TEXT="Breite an vorhandene Fensterbreite anmessen">
|
|
<linktarget COLOR="#748598" DESTINATION="ID_833023922" ENDARROW="Default" ENDINCLINATION="-1609;-94;" ID="Arrow_ID_1971623817" SOURCE="ID_81531339" STARTARROW="None" STARTINCLINATION="-140;338;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1678841652042" ID="ID_344873865" MODIFIED="1678916366193" TEXT="bezweifle ob das korrekt ankommt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel: Fenster vorher sehr schmal machen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1678916371168" ID="ID_1956699133" MODIFIED="1678916621731" TEXT="doch.... ⟶ works as designed">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
per Trace-Meldung überprüft: calibrateExtension() ist so programmiert, daß es die bestehende Metrik erhält, sondern das ZoomWindow entsprechend verkleinert. Der Code verwendet bisher nur default-Werte für die Timeline ⟹ die Metrik bleibt auf 25px/sec stehen, und damit wird die Gesamtlänge stets mindestens 575px sein; Ausnahme: wenn das Fenster ohnehin größer ist...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679358771623" ID="ID_1569651194" MODIFIED="1679358814716" TEXT="Integration mit erweiterten Mutatoren steht noch aus">
|
|
<arrowlink COLOR="#924a6f" DESTINATION="ID_1985216414" ENDARROW="Default" ENDINCLINATION="30;-53;" ID="Arrow_ID_990160035" STARTARROW="None" STARTINCLINATION="-186;10;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1672708648699" ID="ID_1985216414" MODIFIED="1672708769250" TEXT="#1264 fully integrate ZoomWindow mutators into Timeline display">
|
|
<linktarget COLOR="#954368" DESTINATION="ID_1985216414" ENDARROW="Default" ENDINCLINATION="1507;68;" ID="Arrow_ID_1698932113" SOURCE="ID_1466789019" STARTARROW="None" STARTINCLINATION="-35;216;"/>
|
|
<linktarget COLOR="#924a6f" DESTINATION="ID_1985216414" ENDARROW="Default" ENDINCLINATION="30;-53;" ID="Arrow_ID_990160035" SOURCE="ID_1569651194" STARTARROW="None" STARTINCLINATION="-186;10;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1672883774136" HGAP="85" ID="ID_135908111" MODIFIED="1672883794675" TEXT="anzubinden" VSHIFT="21">
|
|
<edge COLOR="#976c6c"/>
|
|
<node CREATED="1672883797610" ID="ID_1763437884" MODIFIED="1672883807253" TEXT="Canvas-Scrollbar"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667488193842" ID="ID_1347640673" MODIFIED="1667488208549" TEXT="Invarianten">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1667488212533" ID="ID_553762141" MODIFIED="1667488247411" TEXT="overall Span ist stets der gesamte Canvas"/>
|
|
<node CREATED="1667488258934" ID="ID_1924856810" MODIFIED="1667488270574" TEXT="visible Span ist ausnahmslos stets darin enthalten"/>
|
|
<node CREATED="1667488271316" ID="ID_1005066146" MODIFIED="1667488283070" TEXT="visible Span in Pixel umgerechnet bleibt absolut konstant"/>
|
|
<node CREATED="1667488303192" ID="ID_486782619" MODIFIED="1667488317608" TEXT="präzise Pixel-Werte sind Präferenz"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1666913274942" ID="ID_4743528" MODIFIED="1666913286194" TEXT="Design überprüfen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670015422301" ID="ID_1681510241" MODIFIED="1670015457619" TEXT="#1262 extract helpers for handling problematic factions">
|
|
<arrowlink DESTINATION="ID_636584956" ENDARROW="Default" ENDINCLINATION="-1629;69;" ID="Arrow_ID_1114152599" STARTARROW="None" STARTINCLINATION="3618;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664730879582" FOLDED="true" ID="ID_580266574" MODIFIED="1664731036535" TEXT="Performance-Aspekte">
|
|
<linktarget COLOR="#6e6b89" DESTINATION="ID_580266574" ENDARROW="Default" ENDINCLINATION="-1072;126;" ID="Arrow_ID_1760515184" SOURCE="ID_1774914566" STARTARROW="None" STARTINCLINATION="-1832;638;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1664730914274" ID="ID_352020246" MODIFIED="1664730918069" TEXT="Architektur"/>
|
|
<node CREATED="1664730918937" ID="ID_524082357" MODIFIED="1664730921221" TEXT="Empirie">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664728069849" ID="ID_46750178" MODIFIED="1664730924226" TEXT="#1240 evaluate performance of ElementBoxWidget">
|
|
<arrowlink COLOR="#652a49" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="-1026;116;" ID="Arrow_ID_977109999" STARTARROW="None" STARTINCLINATION="-985;55;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448070434915" HGAP="64" ID="ID_257833497" MODIFIED="1557498707234" VSHIFT="7">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
innere
|
|
</p>
|
|
<p>
|
|
Struktur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#3a8df0" DESTINATION="ID_1618124128" ENDARROW="Default" ENDINCLINATION="-25;-141;" ID="Arrow_ID_539627804" STARTARROW="Default" STARTINCLINATION="-18;110;"/>
|
|
<node CREATED="1523019258000" FOLDED="true" HGAP="-51" ID="ID_974158229" MODIFIED="1618678028294" TEXT="Struktur-Schemata" VSHIFT="-16">
|
|
<linktarget COLOR="#86889b" DESTINATION="ID_974158229" ENDARROW="Default" ENDINCLINATION="-381;-944;" ID="Arrow_ID_1816207037" SOURCE="ID_708518061" STARTARROW="None" STARTINCLINATION="1299;101;"/>
|
|
<linktarget COLOR="#4f5d91" DESTINATION="ID_974158229" ENDARROW="Default" ENDINCLINATION="383;-2505;" ID="Arrow_ID_1832380552" SOURCE="ID_48107354" STARTARROW="None" STARTINCLINATION="-730;103;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1523019333461" ID="ID_631113825" MODIFIED="1557498707234" TEXT="UI-Element - Hierarchie">
|
|
<node CREATED="1523019501198" ID="ID_531041967" MODIFIED="1557498707234" TEXT="Systematisches UI-Modell">
|
|
<linktarget COLOR="#5f7288" DESTINATION="ID_531041967" ENDARROW="Default" ENDINCLINATION="-964;-27;" ID="Arrow_ID_603305631" SOURCE="ID_790020807" STARTARROW="None" STARTINCLINATION="1678;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1541545653978" ID="ID_1534432315" MODIFIED="1557498707234" TEXT="UI-Element - Identität">
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541545674669" ID="ID_1585676322" MODIFIED="1557498707234" TEXT="UI-Elemente sind global eindeutig">
|
|
<arrowlink COLOR="#7894b4" DESTINATION="ID_189279804" ENDARROW="Default" ENDINCLINATION="272;-358;" ID="Arrow_ID_540125984" STARTARROW="None" STARTINCLINATION="-618;10;"/>
|
|
<linktarget COLOR="#6b83a8" DESTINATION="ID_1585676322" ENDARROW="Default" ENDINCLINATION="828;-65;" ID="Arrow_ID_174361092" SOURCE="ID_1706134856" STARTARROW="None" STARTINCLINATION="1067;-74;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1541545696185" ID="ID_1907010009" MODIFIED="1557498707234" TEXT="Grund: UI-Bus - Routing">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1541545933006" FOLDED="true" ID="ID_1850412206" MODIFIED="1561827465322" TEXT="Duplikate sind ein tückisches Problem">
|
|
<linktarget COLOR="#c9876a" DESTINATION="ID_1850412206" ENDARROW="Default" ENDINCLINATION="49;-155;" ID="Arrow_ID_1571993328" SOURCE="ID_787025622" STARTARROW="None" STARTINCLINATION="-11;173;"/>
|
|
<linktarget COLOR="#c9876a" DESTINATION="ID_1850412206" ENDARROW="Default" ENDINCLINATION="369;179;" ID="Arrow_ID_1229280605" SOURCE="ID_659707505" STARTARROW="None" STARTINCLINATION="586;-203;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1541545944079" ID="ID_1737663580" MODIFIED="1541545963000" TEXT="ein Duplikat ersetzt stillschweigend die Registrierung"/>
|
|
<node CREATED="1541545963822" ID="ID_1562348206" MODIFIED="1541546016778" TEXT="Identität beruht auf EntryID (Hash)"/>
|
|
<node CREATED="1541545975779" ID="ID_1748214927" MODIFIED="1541546024401" TEXT="diese(r) wird aber systematisch gebildet"/>
|
|
<node CREATED="1541790406153" ID="ID_966273732" MODIFIED="1541790408357" TEXT="relevant in Record<GenNode>">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1541546204541" HGAP="30" ID="ID_1625379453" MODIFIED="1561827465326" TEXT="speziell..." VSHIFT="3">
|
|
<arrowlink COLOR="#677dde" DESTINATION="ID_1099820897" ENDARROW="Default" ENDINCLINATION="-64;0;" ID="Arrow_ID_791650338" STARTARROW="None" STARTINCLINATION="18;42;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1541546209896" ID="ID_1049660229" MODIFIED="1541546245931" TEXT="Kind: _CHILD_<typ>.<cnt>">
|
|
<node CREATED="1541546489419" ID="ID_282481336" MODIFIED="1576282358021" TEXT="automatisch global eindeutig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil wir einen Mechanismus haben, die <cnt>-Dekoration pro Typ global hochzuzählen (treadsafe)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1541546556994" ID="ID_35993355" MODIFIED="1541546573135" TEXT="hash-seed: der <typ>-Hash"/>
|
|
</node>
|
|
<node CREATED="1541546415736" ID="ID_1483102981" MODIFIED="1541546432862" TEXT="Attribut: key">
|
|
<node CREATED="1541546579096" ID="ID_728290559" MODIFIED="1541546602798">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: key nur <i>innerhalb</i> des Objektes eindeutig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1541547820403" ID="ID_1229228521" MODIFIED="1541775004416" TEXT="Lösung: Hash-Chaining">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1541547837646" ID="ID_508395323" MODIFIED="1541547854627" TEXT="ähnlich wie im Merkle-Tree">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1541547855766" ID="ID_1691211097" MODIFIED="1541547867017" TEXT="Hash des Vaters als seed">
|
|
<node CREATED="1541552824556" ID="ID_42859602" MODIFIED="1541552831542" TEXT="geht nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1541552832731" ID="ID_346770424" MODIFIED="1576282358021" TEXT="bricht die Subsidiarität">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn dann müßte das Attribut
|
|
</p>
|
|
<p>
|
|
von dem Container (GenNode) wissen, der es zwei Ebenen höher enthält und umschließt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1541774981285" ID="ID_1038144488" MODIFIED="1541774996472" TEXT="ist letzten Endes auch bloß random()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541775187418" ID="ID_1058458763" MODIFIED="1576282358020" TEXT="Frage: Reproduzierbarkeit irrelevant?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es kommt (vielleicht) überhaupt nicht darauf an,
|
|
</p>
|
|
<p>
|
|
daß der Hash einer Attribut-ID <i>reproduzierbar</i> ist (auf Basis der symbilschen ID).
|
|
</p>
|
|
<p>
|
|
Der Hash kann genausogut eine Zufallszahl sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1541775381760" ID="ID_681940327" MODIFIED="1541775392922" TEXT="denn: get sucht per Symbol"/>
|
|
<node CREATED="1541775428125" ID="ID_1569956089" MODIFIED="1576282358020" TEXT="und: einige Attribute haben notwendig eine extern definierte ID">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nämlich diejenigen, die <i>selber </i>Modell-Elemente sind.
|
|
</p>
|
|
<p>
|
|
Und genau diese speziellen Objekt-Attribute sind der Anlaß,
|
|
</p>
|
|
<p>
|
|
sich über dieses Problem Gedanken zu machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1541790399905" ID="ID_552609912" MODIFIED="1541790483789">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber: zufällige ID macht Objekt-builder <i>stateful</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#f63025" DESTINATION="ID_791385927" ENDARROW="Default" ENDINCLINATION="142;6;" ID="Arrow_ID_1321696116" STARTARROW="None" STARTINCLINATION="7;68;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541790451266" ID="ID_791385927" MODIFIED="1541790474148" TEXT="Problem auf dieser Ebene nicht lösbar">
|
|
<linktarget COLOR="#f63025" DESTINATION="ID_791385927" ENDARROW="Default" ENDINCLINATION="142;6;" ID="Arrow_ID_1321696116" SOURCE="ID_552609912" STARTARROW="None" STARTINCLINATION="7;68;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1541790539737" HGAP="19" ID="ID_620633727" MODIFIED="1553904293410" TEXT="explizit zu handhaben" VSHIFT="9">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1541790564379" ID="ID_1099820897" MODIFIED="1541790869503" TEXT="das Problem läßt sich nicht implizit lösen">
|
|
<linktarget COLOR="#677dde" DESTINATION="ID_1099820897" ENDARROW="Default" ENDINCLINATION="-64;0;" ID="Arrow_ID_791650338" SOURCE="ID_1625379453" STARTARROW="None" STARTINCLINATION="18;42;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1541790588022" ID="ID_1242220321" MODIFIED="1541790627427" TEXT="Fazit: auf dem ETD-level ignorieren"/>
|
|
<node CREATED="1541790631410" ID="ID_1544767080" MODIFIED="1541790641506" TEXT="gehört in den Domain-level"/>
|
|
<node CREATED="1541790656124" ID="ID_279205741" MODIFIED="1576282358019" TEXT="Domain-IDs eindeutig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt.
|
|
</p>
|
|
<p>
|
|
die Konstruktion des Domain-Modelles ist dafür zuständig
|
|
</p>
|
|
<p>
|
|
für global eindeutige IDs an den relevanten Stellen zu sorgen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1541790717726" ID="ID_1884395735" MODIFIED="1576282358019" TEXT="explizites Attribut-Binding">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dem man eine EntryID geben kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1541790780342" ID="ID_683694576" MODIFIED="1541798900109" TEXT="DSL-Syntax">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1541790752619" ID="ID_826540621" MODIFIED="1541798905126" TEXT="in ETD-Objekt-Notation">
|
|
<node CREATED="1541791692837" ID="ID_1036110919" MODIFIED="1541791708256" TEXT="set() geht ohnehin schon mit GenNode-Argument">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1541791710149" ID="ID_1280894882" MODIFIED="1541798914030" TEXT="MakeRec().genNode(ID) ermöglichen!">
|
|
<arrowlink COLOR="#71cbc9" DESTINATION="ID_80733797" ENDARROW="Default" ENDINCLINATION="49;1;" ID="Arrow_ID_237980791" STARTARROW="None" STARTINCLINATION="22;30;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1541790797595" ID="ID_80733797" MODIFIED="1541798902638" TEXT="für SET / INS Diff-Verben">
|
|
<linktarget COLOR="#71cbc9" DESTINATION="ID_80733797" ENDARROW="Default" ENDINCLINATION="49;1;" ID="Arrow_ID_237980791" SOURCE="ID_1280894882" STARTARROW="None" STARTINCLINATION="22;30;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523021670034" FOLDED="true" ID="ID_1102842396" MODIFIED="1557498707234" TEXT="Einstiegspunkte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523021679960" ID="ID_1386792927" MODIFIED="1557498707234">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)-><b>InteractionDirector</b> (=Model Root)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1538956606744" ID="ID_165150753" MODIFIED="1557498707234" TEXT="erwartete Modell-Struktur">
|
|
<linktarget COLOR="#919fc6" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-902;329;" ID="Arrow_ID_651613049" SOURCE="ID_1996849782" STARTARROW="None" STARTINCLINATION="823;93;"/>
|
|
<linktarget COLOR="#919fc6" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-641;482;" ID="Arrow_ID_593956858" SOURCE="ID_580392349" STARTARROW="None" STARTINCLINATION="1171;75;"/>
|
|
<linktarget COLOR="#3041c7" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-3211;307;" ID="Arrow_ID_1316612875" SOURCE="ID_192625861" STARTARROW="None" STARTINCLINATION="-1533;0;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538956633404" ID="ID_266268175" MODIFIED="1557498707234" TEXT="Root">
|
|
<node CREATED="1538956680006" ID="ID_774059518" MODIFIED="1557498707234" TEXT="TODO Assets?"/>
|
|
<node CREATED="1538956635652" ID="ID_410609041" MODIFIED="1557498707234" TEXT="Sequence{Timeline}"/>
|
|
</node>
|
|
<node CREATED="1538956703435" ID="ID_275497582" MODIFIED="1557498707234" TEXT="Timeline">
|
|
<node CREATED="1538956945754" ID="ID_1216887436" MODIFIED="1557498707234" TEXT=""name""/>
|
|
<node CREATED="1538956717369" ID="ID_21520084" MODIFIED="1560172967031" TEXT=""fork" = Track">
|
|
<arrowlink DESTINATION="ID_1319425167" ENDARROW="Default" ENDINCLINATION="-1;-52;" ID="Arrow_ID_1260691192" STARTARROW="None" STARTINCLINATION="-79;17;"/>
|
|
</node>
|
|
<node CREATED="1538956709026" ID="ID_326010297" MODIFIED="1557498707234" TEXT="Sequence{Marker}"/>
|
|
<node CREATED="1560686038649" ID="ID_1520503504" MODIFIED="1561827465326" TEXT="pinned overview Rulers">
|
|
<arrowlink COLOR="#337fe3" DESTINATION="ID_1443277448" ENDARROW="Default" ENDINCLINATION="-2069;0;" ID="Arrow_ID_934863827" STARTARROW="Default" STARTINCLINATION="-702;0;"/>
|
|
<linktarget COLOR="#486ebf" DESTINATION="ID_1520503504" ENDARROW="Default" ENDINCLINATION="-1384;0;" ID="Arrow_ID_312917871" SOURCE="ID_1236432450" STARTARROW="None" STARTINCLINATION="689;0;"/>
|
|
<node CREATED="1560686062574" ID="ID_250993855" MODIFIED="1560686076868" TEXT="Timecode und Marker-Anzeige"/>
|
|
<node CREATED="1560686051799" ID="ID_1555560276" MODIFIED="1560686061961" TEXT="auch bei vertikalem Scrolling immer sichtbar"/>
|
|
<node COLOR="#435e98" CREATED="1560686078237" ID="ID_833522619" MODIFIED="1560686305545" TEXT="definiert durch Ruler des top-Level-Track">
|
|
<arrowlink COLOR="#8da0b6" DESTINATION="ID_1083901292" ENDARROW="Default" ENDINCLINATION="-248;-59;" ID="Arrow_ID_1788513078" STARTARROW="None" STARTINCLINATION="-133;-6;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538956769298" ID="ID_1319425167" MODIFIED="1560172967031" TEXT="Track">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1319425167" ENDARROW="Default" ENDINCLINATION="-1;-52;" ID="Arrow_ID_1260691192" SOURCE="ID_21520084" STARTARROW="None" STARTINCLINATION="-79;17;"/>
|
|
<node CREATED="1538956775249" ID="ID_1811758034" MODIFIED="1557498707234" TEXT="Sequence{Track}">
|
|
<node CREATED="1538957049292" ID="ID_1618683787" MODIFIED="1557498707234" TEXT="if typeID = "Fork""/>
|
|
<node CREATED="1544846114433" ID="ID_1306886572" MODIFIED="1557498707234" TEXT="die Sub-Tracks">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538956796214" ID="ID_337674261" MODIFIED="1557498707234" TEXT="Sequence{Clip}">
|
|
<node CREATED="1538957049292" ID="ID_100537539" MODIFIED="1557498707234" TEXT="if typeID = "Clip""/>
|
|
</node>
|
|
<node CREATED="1538956802701" ID="ID_840384156" MODIFIED="1557498707234" TEXT="Sequence{Marker}">
|
|
<node CREATED="1538957049292" ID="ID_1955645432" MODIFIED="1557498707234" TEXT="if typeID = "Marker""/>
|
|
</node>
|
|
<node CREATED="1544839585279" ID="ID_1083901292" MODIFIED="1560686299759" TEXT="Sequence{Ruler}">
|
|
<arrowlink DESTINATION="ID_433238862" ENDARROW="Default" ENDINCLINATION="-37;-96;" ID="Arrow_ID_472987279" STARTARROW="None" STARTINCLINATION="-69;14;"/>
|
|
<linktarget COLOR="#5f84b0" DESTINATION="ID_1083901292" ENDARROW="Default" ENDINCLINATION="-746;-75;" ID="Arrow_ID_1167484185" SOURCE="ID_43593052" STARTARROW="None" STARTINCLINATION="-981;0;"/>
|
|
<linktarget COLOR="#8da0b6" DESTINATION="ID_1083901292" ENDARROW="Default" ENDINCLINATION="-248;-59;" ID="Arrow_ID_1788513078" SOURCE="ID_833522619" STARTARROW="None" STARTINCLINATION="-133;-6;"/>
|
|
<node CREATED="1544846037083" ID="ID_667362504" MODIFIED="1557498707234" TEXT="if typeID = "Ruler""/>
|
|
<node CREATED="1544846062288" ID="ID_855083299" MODIFIED="1557498707234" TEXT="storage direkt (nested) im TrackBody"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538956769298" ID="ID_721666986" MODIFIED="1557498707234" TEXT="Clip">
|
|
<node CREATED="1538956775249" ID="ID_1108737612" MODIFIED="1557498707234" TEXT="Sequence{Channel}">
|
|
<node CREATED="1538957049292" ID="ID_977385993" MODIFIED="1557498707234" TEXT="if typeID = "Channel""/>
|
|
</node>
|
|
<node CREATED="1538956796214" ID="ID_698134552" MODIFIED="1557498707234" TEXT="Sequence{Effect}">
|
|
<node CREATED="1538957049292" ID="ID_339553268" MODIFIED="1557498707234" TEXT="if typeID = "Effect""/>
|
|
</node>
|
|
<node CREATED="1538956802701" ID="ID_1715846940" MODIFIED="1557498707234" TEXT="Sequence{Marker}">
|
|
<node CREATED="1538957049292" ID="ID_98299428" MODIFIED="1557498707234" TEXT="if typeID = "Marker""/>
|
|
</node>
|
|
<node CREATED="1612027392040" ID="ID_319683499" MODIFIED="1612027448852" TEXT=""timing" ≔ TimeSpan{start, len}">
|
|
<node CREATED="1612027460343" ID="ID_1526970445" MODIFIED="1612027635585" TEXT="Attribut soll bereits bei Konstruktion mitgegeben werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aus Performance-Gründen.
|
|
</p>
|
|
<p>
|
|
Weil dann sofort bei ins(clip) == Konstruktion ein ClipDelegate vom Typ ClipWidget erzeugt, und in den GTK-Canvas geheftet wird.  Andernfalls würde erst ein DormantClip erzeugt, der dann erst später, wenn das timing-Attribut gesetzt wird, sich in ein ClipWidget verwandelt. Das wäre dann im Normalfall eine zusätzliche, unnötige Allokation
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1612027475574" ID="ID_1569710848" MODIFIED="1612027531925" TEXT="es wird aber toleriert, wenn es fehlt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1612027485908" ID="ID_592528621" MODIFIED="1612029020769" TEXT="start == Time::NEVER ⟹ Clip im Anzeige-Modus "Pending"">
|
|
<arrowlink COLOR="#4663c4" DESTINATION="ID_619535893" ENDARROW="Default" ENDINCLINATION="-1983;81;" ID="Arrow_ID_309098301" STARTARROW="None" STARTINCLINATION="631;32;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1665966764677" ID="ID_865599543" MODIFIED="1665968944066" TEXT="Lösung gesucht: (Medien)Typ des Clip">
|
|
<arrowlink COLOR="#bb4f76" DESTINATION="ID_1632230778" ENDARROW="Default" ENDINCLINATION="-986;67;" ID="Arrow_ID_1432405411" STARTARROW="None" STARTINCLINATION="-1713;-126;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1665968738638" ID="ID_1311831391" MODIFIED="1665968767871" TEXT="Problem: Abweichung vom generischen diff-Format">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
schon analog zu dem, was wir hier mit dem "timing" machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1665968772935" ID="ID_1301845480" MODIFIED="1665968805850" TEXT="andererseits: ohne diese Info können wir das Widget gar nicht richtig konstruieren">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612027454614" ID="ID_210949800" MODIFIED="1612027457315" TEXT=""name""/>
|
|
</node>
|
|
<node CREATED="1544840312839" ID="ID_433238862" MODIFIED="1560173044668" TEXT="Ruler">
|
|
<linktarget COLOR="#3e63c5" DESTINATION="ID_433238862" ENDARROW="Default" ENDINCLINATION="-612;-125;" ID="Arrow_ID_1858329997" SOURCE="ID_1391546845" STARTARROW="None" STARTINCLINATION="-747;0;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_433238862" ENDARROW="Default" ENDINCLINATION="-37;-96;" ID="Arrow_ID_472987279" SOURCE="ID_1083901292" STARTARROW="None" STARTINCLINATION="-69;14;"/>
|
|
<node CREATED="1544840455429" ID="ID_1283986005" MODIFIED="1557498707234" TEXT=""timecode" = formatID"/>
|
|
<node CREATED="1544840496225" ID="ID_230755841" MODIFIED="1557498707234" TEXT=""contentFormat" = formatID (none|pivot|frames|wave|synopsis)"/>
|
|
<node CREATED="1544840634822" ID="ID_1138129422" MODIFIED="1557498707234" TEXT="Sequence{Marker.kind}">
|
|
<node CREATED="1544840669032" ID="ID_1798049608" MODIFIED="1557498707234" TEXT="what kinds of markers and selections to render"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538957120867" ID="ID_99923131" MODIFIED="1557498707234" TEXT="Marker">
|
|
<node CREATED="1538956945754" ID="ID_30162898" MODIFIED="1557498707234" TEXT=""name""/>
|
|
<node CREATED="1538956945754" ID="ID_39934842" MODIFIED="1557498707234" TEXT=""kind" = LOOP|MARK"/>
|
|
</node>
|
|
<node CREATED="1538956606744" ID="ID_388585037" MODIFIED="1557498707234" TEXT="Placement">
|
|
<linktarget COLOR="#919fc6" DESTINATION="ID_388585037" ENDARROW="None" ENDINCLINATION="-682;462;" ID="Arrow_ID_726807054" SOURCE="ID_1483911882" STARTARROW="Default" STARTINCLINATION="638;-81;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523019349923" ID="ID_353542665" MODIFIED="1557498707234" TEXT="UI-Koordinaten (UICoord)">
|
|
<node CREATED="1523019476817" ID="ID_1756924881" MODIFIED="1557498707234" TEXT="abstrahierte UI-Topologie">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1523021751558" ID="ID_816148300" MODIFIED="1557498707234" TEXT="Einstiegspunkte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523020094460" ID="ID_950968515" MODIFIED="1557498707234">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)->InteractionDirector-><b>Navigator</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1523021779698" ID="ID_1153977477" MODIFIED="1557498707234" TEXT="erforschen der aktuellen Topologie"/>
|
|
<node CREATED="1523021791784" ID="ID_1683105699" MODIFIED="1557498707234" TEXT="Navigation von einem Punkt weg"/>
|
|
</node>
|
|
<node CREATED="1523019770144" ID="ID_385008471" MODIFIED="1557498707234">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)->WindowLocator-><b>UIComponentAccessor</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1523021816637" ID="ID_217124542" MODIFIED="1557498707234" TEXT="Element zu gegebenen Koordinaten"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523019393893" ID="ID_1642953007" MODIFIED="1557498707234" TEXT="Component View">
|
|
<node CREATED="1523019457868" ID="ID_1319307429" MODIFIED="1557498707234" TEXT="Menge relevanter Entitäten">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1523021612818" ID="ID_366179512" MODIFIED="1557498707234" TEXT="Per Konvention festgelegt">
|
|
<node CREATED="1523022525819" ID="ID_1844877136" MODIFIED="1557498707234" TEXT="ViewSpec-DSL">
|
|
<arrowlink COLOR="#6a8499" DESTINATION="ID_1442345755" ENDARROW="Default" ENDINCLINATION="-1029;85;" ID="Arrow_ID_1191206769" STARTARROW="None" STARTINCLINATION="426;-63;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523021634614" ID="ID_1226976079" MODIFIED="1557498707234" TEXT="flacher Namensraum"/>
|
|
<node CREATED="1523021642573" ID="ID_488343933" MODIFIED="1557498707234" TEXT="komplett von ihrem Ort abstrahiert"/>
|
|
</node>
|
|
<node CREATED="1523020082453" ID="ID_1678299024" MODIFIED="1557498707234" TEXT="Einstiegspunkte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523020094460" ID="ID_970478590" MODIFIED="1557498707234">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)->InteractionDirector-><b>ViewLocator</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1523021575831" ID="ID_952406415" MODIFIED="1557498707234" TEXT="findet oder belegt"/>
|
|
<node CREATED="1523021593460" ID="ID_565564905" MODIFIED="1557498707234" TEXT="Prinzip: ein Stück vom Typ XYZ"/>
|
|
</node>
|
|
<node CREATED="1523019770144" ID="ID_435980488" MODIFIED="1557498707234">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)->WindowLocator-><b>UIComponentAccessor</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#48678b" DESTINATION="ID_435980488" ENDARROW="Default" ENDINCLINATION="-1768;-2819;" ID="Arrow_ID_689216354" SOURCE="ID_1224438713" STARTARROW="Default" STARTINCLINATION="309;919;"/>
|
|
<node CREATED="1523020311838" ID="ID_807452449" MODIFIED="1557498707234" TEXT="Bindeglied">
|
|
<node CREATED="1523020317117" ID="ID_1026544092" MODIFIED="1557498707234" TEXT="UI-Koordinaten"/>
|
|
<node CREATED="1523020328651" ID="ID_1384216871" MODIFIED="1557498707234" TEXT="Component Views"/>
|
|
<node CREATED="1523020334770" ID="ID_446983517" MODIFIED="1557498707235" TEXT="konkrete Widgets"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523019409939" ID="ID_13197399" MODIFIED="1557498707235" TEXT="Fenster - Panel - Widget">
|
|
<node CREATED="1523019435095" ID="ID_1087922610" MODIFIED="1557498707235" TEXT="die natürliche Ordnung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1523019528770" ID="ID_880857626" MODIFIED="1557498707235" TEXT="der real existierende konkrete Inhalt des UI"/>
|
|
<node CREATED="1523019583242" ID="ID_1200584395" MODIFIED="1557498707235" TEXT="ein Wildwuchs an nativen Komponenten"/>
|
|
<node CREATED="1523019593833" ID="ID_770462134" MODIFIED="1557498707235" TEXT="ausschließlich an das UI-Toolkit gebunden"/>
|
|
<node CREATED="1523019635739" ID="ID_883974404" MODIFIED="1576282358018" TEXT="Einzelfall-Wissen vorausgesetzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man muß die Implementierungs-Details <i>jeder einzelnen Komponente</i> kennen,
|
|
</p>
|
|
<p>
|
|
um damit überhaupt etwas anfangen zu können. Es gibt hier keine schematische Ordnung.
|
|
</p>
|
|
<p>
|
|
Selbst die Frage, ob es sich um ein Blatt handelt, oder um einen inneren Knoten,
|
|
</p>
|
|
<p>
|
|
erfordert bereits Kenntnis der Innereien
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523019753259" ID="ID_281223690" MODIFIED="1557498707235" TEXT="Einstiegspunkte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1523019770144" ID="ID_253563802" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)-><b>WindowLocator</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1523019793861" ID="ID_656158432" MODIFIED="1557498707235" TEXT="für die top-level WorkspaceWindows"/>
|
|
<node CREATED="1523019808196" ID="ID_674258018" MODIFIED="1557498707235" TEXT="kann diese erzeugen und zerstören"/>
|
|
</node>
|
|
<node CREATED="1523019770144" ID="ID_1782262126" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(GlobalCtx)->WindowLocator-><b>PanelLocator</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1523019918268" ID="ID_830201534" MODIFIED="1557498707235" TEXT="Zugang zu einzelnen docking-Panels"/>
|
|
<node CREATED="1523019928387" ID="ID_928262089" MODIFIED="1557498707235" TEXT="jedes Fenster hat eignen PanelManager">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1523019972924" ID="ID_1402741681" MODIFIED="1557498707235" TEXT="Grundbausteine">
|
|
<node CREATED="1523019978236" ID="ID_103533434" MODIFIED="1557498707235" TEXT="GTK-Container"/>
|
|
<node CREATED="1523019982331" ID="ID_533152750" MODIFIED="1557498707235" TEXT="Widget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664668670633" ID="ID_281557130" MODIFIED="1664668687274" TEXT="CSS-Schema für das Lumiera-GTK-UI">
|
|
<linktarget COLOR="#8b1d60" DESTINATION="ID_281557130" ENDARROW="Default" ENDINCLINATION="-986;-81;" ID="Arrow_ID_1840161927" SOURCE="ID_529832770" STARTARROW="None" STARTINCLINATION="-625;67;"/>
|
|
<node CREATED="1664668701652" ID="ID_1339380234" MODIFIED="1664668992057" TEXT="Einrichtung durch den UI-Manager">
|
|
<arrowlink COLOR="#4369a6" DESTINATION="ID_280366952" ENDARROW="Default" ENDINCLINATION="-566;432;" ID="Arrow_ID_1332353653" STARTARROW="None" STARTINCLINATION="-931;-99;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1664669003788" ID="ID_1496995299" MODIFIED="1664669012883" TEXT="laden der Applicaton Style-Sheet(s)"/>
|
|
<node CREATED="1664669017642" ID="ID_1750503334" MODIFIED="1664669048777" TEXT="synthetische CSS-Pfade für generische (Timeline)-Styles"/>
|
|
</node>
|
|
<node CREATED="1664669065764" ID="ID_1839743760" LINK="#ID_417783849" MODIFIED="1664669180575" TEXT="CSS-Style-Konventionen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1664669186884" ID="ID_458273565" MODIFIED="1664669799291" TEXT="BEM-Notation sinnvoll verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
block[__element][--modifier]
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664669206239" ID="ID_419151463" MODIFIED="1664669277092" TEXT="nicht übertreiben...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Hier besteht die Gefahr, das Stylesheet mit redundanten Definitionen zu fluten!<br />Die BEM-Notation ist sinnvoll, insodern sie die <b>intendierte Bedeutung</b> einer Klasse klar macht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664669329825" ID="ID_1131035647" MODIFIED="1664669851599" TEXT="erlaubt Styling relativ zu einem Ankerpunkt">
|
|
<linktarget COLOR="#4482cb" DESTINATION="ID_1131035647" ENDARROW="Default" ENDINCLINATION="1109;-797;" ID="Arrow_ID_860130995" SOURCE="ID_1102642211" STARTARROW="None" STARTINCLINATION="394;586;"/>
|
|
</node>
|
|
<node CREATED="1664669415850" ID="ID_550535214" MODIFIED="1664669442209">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
für <i>wirklich generische </i>Styles sollte man generische Klassen schaffen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1664669349154" ID="ID_1203947734" MODIFIED="1664669365231" TEXT="anwenden für frei kombinierbare Bausteine">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664669376402" ID="ID_1053064636" MODIFIED="1664669383965" TEXT="Ziel: flache Regelsätze"/>
|
|
<node CREATED="1664669384622" ID="ID_1136788054" MODIFIED="1664669404794" TEXT="Gefahr: nicht zu sehr mit Hierarchie mischen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664669483004" ID="ID_67069452" MODIFIED="1664669501696" TEXT="Element-IDs zur Ergänzung der (Widget)-Klassen">
|
|
<node CREATED="1664669510416" ID="ID_407846931" MODIFIED="1664669525650" TEXT="da wir nicht ohne Weiteres custom-Widget-Klassen schaffen können"/>
|
|
<node CREATED="1664669526998" ID="ID_692508044" MODIFIED="1664669597733">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dann immer besser noch ein: <font face="Monospaced" color="#3006cf">frame#element</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1678576343977" ID="ID_943672117" MODIFIED="1678576356597" TEXT="Konkret / speziell">
|
|
<node CREATED="1678576366604" ID="ID_1232986902" MODIFIED="1678576571070" TEXT="CSS-Schema zum Styling der Timeline">
|
|
<linktarget COLOR="#5f7783" DESTINATION="ID_1232986902" ENDARROW="Default" ENDINCLINATION="2218;-176;" ID="Arrow_ID_691307229" SOURCE="ID_650016552" STARTARROW="None" STARTINCLINATION="7697;843;"/>
|
|
<linktarget COLOR="#5f7783" DESTINATION="ID_1232986902" ENDARROW="Default" ENDINCLINATION="2218;-176;" ID="Arrow_ID_1708948555" SOURCE="ID_1568473205" STARTARROW="None" STARTINCLINATION="4285;319;"/>
|
|
<node CREATED="1679153039883" ID="ID_1200037530" MODIFIED="1679153044485" TEXT="light-theme-complement">
|
|
<node CREATED="1679153131574" ID="ID_94246546" MODIFIED="1679153138259" TEXT="@define-color">
|
|
<node CREATED="1679153145084" ID="ID_1658648144" MODIFIED="1679153149322" TEXT="lum_light">
|
|
<node CREATED="1679153164528" ID="ID_989833472" MODIFIED="1679153174252" TEXT="ivory + 0.2 alpha"/>
|
|
</node>
|
|
<node CREATED="1679153150171" ID="ID_746267827" MODIFIED="1679153154086" TEXT="lum_shade">
|
|
<node CREATED="1679153186788" ID="ID_660192995" MODIFIED="1679153194978" TEXT="conrsilk abgedunkelt + 0.15 alpha"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679153046735" ID="ID_210074374" MODIFIED="1679153052066" TEXT="Fork">
|
|
<node CREATED="1679153200733" ID="ID_333838761" MODIFIED="1679153213700" TEXT="nur inset box-shadow, als Alpha-overlay"/>
|
|
</node>
|
|
<node CREATED="1679153052705" ID="ID_1740941248" MODIFIED="1679153054572" TEXT="Ruler">
|
|
<node CREATED="1679153061488" ID="ID_233346374" LINK="#ID_555799552" MODIFIED="1679153102530" TEXT="verwende die @theme_bg_color"/>
|
|
</node>
|
|
<node CREATED="1679153055256" ID="ID_1629759220" MODIFIED="1679153056748" TEXT="Slope">
|
|
<node CREATED="1679153216817" ID="ID_1774634395" MODIFIED="1679153229573" TEXT="baut ebenfalls auf @lum_light | @lum_shade auf"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1448070545132" HGAP="31" ID="ID_1410368513" MODIFIED="1557498707235" TEXT="Element" VSHIFT="-7">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1448070580927" ID="ID_467382299" MODIFIED="1557498707235" TEXT="Ausprägungen" VSHIFT="18">
|
|
<node CREATED="1448070554963" ID="ID_579919554" MODIFIED="1557498707235" TEXT="Widget"/>
|
|
<node CREATED="1448070559466" ID="ID_182430638" MODIFIED="1557498707235" TEXT="Controller"/>
|
|
</node>
|
|
<node CREATED="1448070583679" HGAP="69" ID="ID_1248152908" MODIFIED="1557498707235" TEXT="Protokoll" VSHIFT="-1">
|
|
<node CREATED="1448078263344" FOLDED="true" ID="ID_1136748666" MODIFIED="1582388511425" TEXT="Verhaltensweisen">
|
|
<cloud COLOR="#e0d6ba"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1448078268223" ID="ID_1027574047" MODIFIED="1518487921085" TEXT="Lebenszyklus">
|
|
<node CREATED="1448078450375" ID="ID_459686936" MODIFIED="1576282358017" TEXT="zeugen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
heißt: Element registriert sich am UI-Bus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078473068" ID="ID_510866826" MODIFIED="1576282358017" TEXT="zerstören">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
heißt: Element deregistriert sich am UI-Bus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448078308690" ID="ID_185716114" MODIFIED="1518487921085" TEXT="Aktionen">
|
|
<node CREATED="1448078344541" ID="ID_1781183546" MODIFIED="1576282358016" TEXT="Subjekt einer Aktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist <i>immer</i> ein <b>tangible</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078516094" ID="ID_201691188" MODIFIED="1518487921085" TEXT="Commands"/>
|
|
<node CREATED="1448078325679" ID="ID_946047770" MODIFIED="1518487921085" TEXT="tweaks"/>
|
|
</node>
|
|
<node CREATED="1448078330703" ID="ID_1955501343" MODIFIED="1518487921085">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
presentation
|
|
</p>
|
|
<p>
|
|
state
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1448078381288" ID="ID_1570425925" MODIFIED="1518487921085" TEXT="state mark">
|
|
<node CREATED="1448078528725" ID="ID_1776152068" MODIFIED="1518487921085">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vom <i>tangible </i>initiiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078554385" ID="ID_181795198" MODIFIED="1518487921085" TEXT="wird zurückgespielt"/>
|
|
<node CREATED="1448078678961" ID="ID_1905336344" MODIFIED="1518487921085" TEXT="Arten">
|
|
<node CREATED="1448078682840" ID="ID_1545251839" MODIFIED="1518487921085" TEXT="zoom"/>
|
|
<node CREATED="1448078687176" ID="ID_357365613" MODIFIED="1518487921085" TEXT="scroll"/>
|
|
<node CREATED="1448078691727" ID="ID_1874307716" MODIFIED="1518487921085" TEXT="expand"/>
|
|
<node CREATED="1448078703294" ID="ID_784991533" MODIFIED="1518487921085" TEXT="Form"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448078385504" ID="ID_584410725" MODIFIED="1518487921085" TEXT="feedback">
|
|
<node CREATED="1448078569263" ID="ID_906985390" MODIFIED="1518487921085" TEXT="in Fokus bringen"/>
|
|
<node CREATED="1448078589997" ID="ID_1779705374" MODIFIED="1518487921085" TEXT="aufblitzen"/>
|
|
<node CREATED="1448078604115" ID="ID_666512041" MODIFIED="1518487921085" TEXT="Warn-Nachricht"/>
|
|
<node CREATED="1448078622048" ID="ID_1858518915" MODIFIED="1518487921085" TEXT="Fehler"/>
|
|
</node>
|
|
<node CREATED="1448078416612" ID="ID_1392022084" MODIFIED="1518487921085" TEXT="state reset">
|
|
<node CREATED="1448078722483" ID="ID_1661890520" MODIFIED="1518487921085" TEXT="auf default!">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1448078731130" ID="ID_1682515267" MODIFIED="1576282358016" TEXT="collapse / expand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dafür genügt der normale Reset
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1448078748448" ID="ID_1000763850" MODIFIED="1576282358015" TEXT="Nachrichten löschen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mark "clearMsg"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078778916" ID="ID_1657108949" MODIFIED="1576282358015" TEXT="Fehler löschen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mark "clearErr"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078798369" ID="ID_819750758" MODIFIED="1576282358014" TEXT="komplett-Reset">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mark "reset"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448078425594" ID="ID_686619553" MODIFIED="1518487921085" TEXT="Mutation">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1448078811895" ID="ID_1266803050" MODIFIED="1518487921085">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Nachricht an <i>irgend ein</i> Wurzel-Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448078835044" ID="ID_358413966" MODIFIED="1518487921085" TEXT="bezieht daraufhin einen Diff"/>
|
|
<node CREATED="1448078845419" ID="ID_189415188" MODIFIED="1518487921085" TEXT="wendet diesen rekursiv an"/>
|
|
<node CREATED="1448078856722" ID="ID_1770248185" MODIFIED="1518487921085" TEXT="Hinweis: kann Kinder zeugen und zerstören"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448658633478" FOLDED="true" HGAP="99" ID="ID_314439240" MODIFIED="1582388681066" TEXT="Design" VSHIFT="13">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1448658692023" FOLDED="true" ID="ID_339186676" MODIFIED="1582388523994">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
generisch
|
|
</p>
|
|
<p>
|
|
sinnvoll?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was haben alle UI-Elemente wirklich gemeinsam?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1448658692023" ID="ID_888978058" MODIFIED="1576282358013" TEXT="generische Commands">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Frage ist, wie generisch ist eigentlich ein Command-Aufruf selber?
|
|
</p>
|
|
<p>
|
|
Macht es daher Sinn, ein generisches API allgemein sichtbar zu machen,
|
|
</p>
|
|
<p>
|
|
oder handelt es sich nur um ein Implementierungsdetail der UI-Bus-Anbindung?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1448659456882" ID="ID_946761955" MODIFIED="1518487921085" TEXT="Notwendig: Command-Name + Varargs"/>
|
|
<node CREATED="1451093919426" ID="ID_56876272" MODIFIED="1518487921085" TEXT="generisch impliziert auch zentrale Definition">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1451093994135" ID="ID_1002329025" MODIFIED="1518487921085">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wird sinnvoll im Rahmen von <font color="#8e11a1">InteractionControl</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b567c4" DESTINATION="ID_1009169288" ENDARROW="Default" ENDINCLINATION="254;0;" ID="Arrow_ID_200182911" STARTARROW="None" STARTINCLINATION="162;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448659723879" ID="ID_197701429" MODIFIED="1518487921085" TEXT="UI-Grundverhalten">
|
|
<node CREATED="1448659735557" ID="ID_1553949303" MODIFIED="1518487921086" TEXT="Falten / Expandieren"/>
|
|
<node CREATED="1448659747476" ID="ID_1549415142" MODIFIED="1518487921086" TEXT="Grad der Explizitheit"/>
|
|
<node CREATED="1448659757378" ID="ID_1164836827" MODIFIED="1518487921086" TEXT="in Sicht bringen"/>
|
|
<node CREATED="1448659780743" ID="ID_1787132400" MODIFIED="1518487921086" TEXT="Fokus-Management"/>
|
|
<node CREATED="1448659792782" ID="ID_1547056651" MODIFIED="1518487921086" TEXT="räumliche Navigation"/>
|
|
<node CREATED="1448659824337" ID="ID_1734858009" MODIFIED="1518487921086" TEXT="Markierungen"/>
|
|
</node>
|
|
<node CREATED="1455236472002" HGAP="49" ID="ID_952544600" MODIFIED="1561827465351" TEXT="generische Eigenschaften" VSHIFT="15">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1455236491432" ID="ID_1268644179" MODIFIED="1518487921086" TEXT="Idee">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1455236501719" HGAP="35" ID="ID_540888754" MODIFIED="1518487921086" TEXT="man könnte Eigenschaften konfigurieren" VSHIFT="2"/>
|
|
<node CREATED="1455236512373" ID="ID_211355731" MODIFIED="1518487921086" TEXT="jede Eigenschaft hätte">
|
|
<node CREATED="1455236519677" ID="ID_1698754255" MODIFIED="1518487921086" TEXT="Namen"/>
|
|
<node CREATED="1455236522020" ID="ID_404018073" MODIFIED="1518487921086" TEXT="slot"/>
|
|
<node CREATED="1455236527443" ID="ID_45035009" MODIFIED="1518487921086" TEXT="passende »state mark«"/>
|
|
<node CREATED="1455236537802" ID="ID_1419063243" MODIFIED="1518487921086" TEXT="handler-funktor"/>
|
|
<node CREATED="1455236554927" ID="ID_772542993" MODIFIED="1518487921086" TEXT="installiert sich in generischen handler"/>
|
|
</node>
|
|
<node CREATED="1455236573173" HGAP="72" ID="ID_466911779" MODIFIED="1518487921086" TEXT="Bewertung" VSHIFT="16">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1455236781242" ID="ID_674694140" MODIFIED="1518487921086" TEXT="könnte interessant sein für Diff"/>
|
|
<node CREATED="1455236788424" ID="ID_1507269502" MODIFIED="1576282358013" TEXT="aber gegen das Grundkonzept">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich wollte explizit kein generisch-introspektives UI,
|
|
</p>
|
|
<p>
|
|
weil das die Tendenz hat, sich zu einem Framework auszuwachsen.
|
|
</p>
|
|
<p>
|
|
Für die UI-Programmierung muß man Spaghetticode akzeptieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455236851592" ID="ID_1599276883" MODIFIED="1518487921086" TEXT="YAGNI">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1455236869405" ID="ID_1141383110" MODIFIED="1518487921086" TEXT="später">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541546692289" ID="ID_189279804" MODIFIED="1541546864673">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Identität</b> == Bus-ID
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#7894b4" DESTINATION="ID_189279804" ENDARROW="Default" ENDINCLINATION="272;-358;" ID="Arrow_ID_540125984" SOURCE="ID_1585676322" STARTARROW="None" STARTINCLINATION="-618;10;"/>
|
|
<node CREATED="1541546715849" ID="ID_503690063" MODIFIED="1541546722489" TEXT="sollte global eindeutig sein"/>
|
|
<node CREATED="1541546733765" ID="ID_1010323480" MODIFIED="1541546741208" TEXT="wird per Diff übermittelt"/>
|
|
</node>
|
|
<node CREATED="1448658696638" ID="ID_1235910089" MODIFIED="1518487921086" TEXT="slots">
|
|
<node CREATED="1451177440022" ID="ID_1603816152" MODIFIED="1518487921086" TEXT="expand">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1451177449405" ID="ID_215708646" MODIFIED="1518487921086" TEXT="zunächst einfach auf/zu"/>
|
|
<node CREATED="1451177459667" ID="ID_1151970636" MODIFIED="1576282358012" TEXT="wird möglicherweise eine Enum">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint, eine ENUM von verschiedenen Graden der Aufgeklappt-heit
|
|
</p>
|
|
<p>
|
|
Dann mußte das allerdigns jeweils für alle Elemente sinnvoll sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1451177534345" ID="ID_524388510" MODIFIED="1518487921086" TEXT="impl">
|
|
<node CREATED="1451177542256" ID="ID_980888532" MODIFIED="1576282358012" TEXT="ruft einen konkreten hook doExpand() auf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und der muß vom konkreten Widget implementiert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1451177573108" ID="ID_1154342108" MODIFIED="1518487921086" TEXT="wenn dieser true zurückgibt, ist der Zustand persistent"/>
|
|
<node CREATED="1451177584435" ID="ID_1792154974" MODIFIED="1518487921086">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dann wird eine <i>state mark</i> ausgesendet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1451177442861" ID="ID_1257047796" MODIFIED="1518487921086" TEXT="reveal">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1451177636388" ID="ID_507693817" MODIFIED="1518487921086" TEXT=""bringe dies Element in Sicht"">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1451177626773" ID="ID_612921051" MODIFIED="1518487921086" TEXT="ist das eine gute Idee">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1451177659369" ID="ID_928484705" MODIFIED="1518487921086">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
need to <i>bubble up</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1451177719577" ID="ID_1175980404" MODIFIED="1518487921086" TEXT="wie finde ich den Vater..."/>
|
|
<node CREATED="1455236368345" ID="ID_1490676072" MODIFIED="1518487921086" TEXT="besser">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1455236382183" ID="ID_983670310" MODIFIED="1518487921086" TEXT="Einstiegspunkt: revealYourself"/>
|
|
<node CREATED="1455236393861" ID="ID_1638665625" MODIFIED="1518487921086">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
support ist <i>optional</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455236418290" ID="ID_1765760054" MODIFIED="1518487921086" TEXT="dieses ruft parent.reveal(myID)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535639028984" FOLDED="true" ID="ID_316446199" MODIFIED="1582388552498" TEXT="hilfs-Abstraktionen">
|
|
<linktarget COLOR="#709eaf" DESTINATION="ID_316446199" ENDARROW="Default" ENDINCLINATION="-354;-490;" ID="Arrow_ID_1105268233" SOURCE="ID_447101734" STARTARROW="None" STARTINCLINATION="-3385;0;"/>
|
|
<node CREATED="1535639151330" ID="ID_301022990" MODIFIED="1535639159958" TEXT="mix-in">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1535639038857" ID="ID_978884512" MODIFIED="1535639051322" TEXT="ermöglichen generische Implementierung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535639052671" ID="ID_1134562624" MODIFIED="1535639073976" TEXT="Expander">
|
|
<node CREATED="1535639110104" ID="ID_712715565" MODIFIED="1535639113355" TEXT="bool-Testbar"/>
|
|
<node CREATED="1535725570140" ID="ID_39824556" MODIFIED="1535725586590" TEXT="canExpand()"/>
|
|
<node CREATED="1535639114727" ID="ID_1791716176" MODIFIED="1535725472597" TEXT="Funktions-Operator(bool expand)"/>
|
|
</node>
|
|
<node CREATED="1535639174623" ID="ID_1755607605" MODIFIED="1535639177466" TEXT="Revealer">
|
|
<node CREATED="1535639368981" ID="ID_220149026" MODIFIED="1576282358011">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nicht</i> bool-Testbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ganz bewußt verzichten wir darauf,
|
|
</p>
|
|
<p>
|
|
festzustellen, ob ein Kind gegenwärtig zugänglich (revealed) ist.
|
|
</p>
|
|
<p>
|
|
Denn dies auf dem API zu exponieren bringt keinen Mehrwehrt.
|
|
</p>
|
|
<p>
|
|
Letztlich ist das ein lokales Detail des Layout-Managers.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Es ist nicht Sache des client-Codes, auf einem Widget ein anderes Verhalten auszulösen,
|
|
</p>
|
|
<p>
|
|
wenn es nicht sichtbar ist. Denn Sichtbarkeit gehört zur UI-Mechanik und geht den Client nix an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535725591561" ID="ID_1362809449" MODIFIED="1535725594837" TEXT="canReveal()"/>
|
|
<node CREATED="1535639517897" ID="ID_1175119585" MODIFIED="1535725607419" TEXT="Funktions-Operator(void) == reveal"/>
|
|
<node CREATED="1535640911061" ID="ID_777387548" MODIFIED="1535725678665" TEXT="reveal(canvasX,canvasY) auf dem Layout-Manager"/>
|
|
</node>
|
|
<node CREATED="1535640932722" FOLDED="true" ID="ID_1411372901" MODIFIED="1582388541734" TEXT="NavScope">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1535654864507" ID="ID_976171939" MODIFIED="1535654872624" TEXT="erst mal nur so eine Idee....">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1535654895926" ID="ID_518978388" MODIFIED="1535655662803" TEXT="zwei Fliegen mit einer Klappe">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1535654884104" ID="ID_1335278492" MODIFIED="1576282358011" TEXT="könnte für den ViewLocator nützlich sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn dort fehlt noch die konkrete Implementierung,
|
|
</p>
|
|
<p>
|
|
welche die Monaden-Baum-Repräsentation schließlich
|
|
</p>
|
|
<p>
|
|
auf konkrete Widgets abbildet. Das ist viel Arbeit, und es ließe sich vereinfachen,
|
|
</p>
|
|
<p>
|
|
wenn für gewisse Knoten erkannt werden kann, daß sie einen NavScope darstellen;
|
|
</p>
|
|
<p>
|
|
denn dann gäbe es eine Implementierung "von der Stange"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1535723854290" ID="ID_333598922" MODIFIED="1535723874600" TEXT="fällt aus diesem Thema heraus">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535655039395" FOLDED="true" ID="ID_1646511082" MODIFIED="1582388543675" TEXT="Diskussion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535655065175" ID="ID_702941818" MODIFIED="1535655069235" TEXT="Symmetrie?">
|
|
<node CREATED="1535655118800" ID="ID_1058761508" MODIFIED="1535655127308" TEXT="Expander ist nur pro Komponente">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1535655136902" ID="ID_126171743" MODIFIED="1535655170274" TEXT="Wunsch: Mix-ins in NavScope-Interface kombinieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535723351533" ID="ID_909635517" MODIFIED="1535723375219">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber die Operationen sind <i>der Sache nach</i> nicht symmetrisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1535725181176" ID="ID_1947404851" MODIFIED="1535725210681" TEXT="ins Kind verlagert lassen sie sich jedoch symmetrisieren">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535655069967" ID="ID_340217269" MODIFIED="1561827465363" TEXT="Expander und Revealer als Proxy?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1535655293760" ID="ID_1318206385" MODIFIED="1535655302082" TEXT="Syntax?">
|
|
<node CREATED="1535655199741" ID="ID_942388081" MODIFIED="1535655235119" TEXT="scope.getExpander(ID).expand(false)">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1535655252694" ID="ID_1462365996" MODIFIED="1535655259251" TEXT="scope.canExpand(ID)">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535655285938" ID="ID_1449182402" MODIFIED="1535655292365" TEXT="oder">
|
|
<node CREATED="1535655304095" ID="ID_482365383" MODIFIED="1535655319455" TEXT="scope.expand(ID, true)">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1535655363543" ID="ID_1383221002" MODIFIED="1535655385497" TEXT="scope.canReveal(ID)">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535655400386" ID="ID_1267051500" MODIFIED="1535655402638" TEXT="Storage">
|
|
<node CREATED="1535655416192" ID="ID_1700423924" MODIFIED="1535721537469" TEXT="value: Funktor">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1535655437493" ID="ID_949368248" MODIFIED="1535655450647" TEXT="kopierbar"/>
|
|
<node CREATED="1535655452419" ID="ID_338667405" MODIFIED="1535655462678" TEXT="besteht nur aus std::function"/>
|
|
<node CREATED="1535655501013" ID="ID_822333393" MODIFIED="1535655513719" TEXT="wird direkt im verwendenden Widget gespeichert"/>
|
|
<node CREATED="1535722990637" ID="ID_1278252704" MODIFIED="1535723000688" TEXT="aber es gibt verdeckte Heap-Allokationen"/>
|
|
<node CREATED="1535655479976" ID="ID_1685363954" MODIFIED="1535655485792" TEXT="Gefahr: dangling references">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535655427943" ID="ID_1559607876" MODIFIED="1535721543060" TEXT="ref: Proxy-Objekt">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1535655553598" ID="ID_714380046" MODIFIED="1535655564832" TEXT="nicht-kopierbar"/>
|
|
<node CREATED="1535655565420" ID="ID_1503255611" MODIFIED="1535655575607" TEXT="ist eine konkrete Subklasse"/>
|
|
<node CREATED="1535655576843" ID="ID_1432131188" MODIFIED="1535655585397" TEXT="storage...">
|
|
<node CREATED="1535655586265" ID="ID_267652544" MODIFIED="1535655612409" TEXT="entweder inline, aber mit vector<function>"/>
|
|
<node CREATED="1535655613518" ID="ID_146906659" MODIFIED="1535655634423" TEXT="direkt auf dem Heap, mit expliziter konkreter Impl"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535724509562" ID="ID_833385943" MODIFIED="1535724515909" TEXT="Implementierungs-Modell">
|
|
<node CREATED="1535724523160" ID="ID_1440345421" MODIFIED="1561827465364" TEXT="Parent-Container führt Index">
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1535724838670" ID="ID_1787800884" MODIFIED="1535724867702" TEXT="das Kind wird dort per ID registriert"/>
|
|
<node CREATED="1535724882528" ID="ID_1169954047" MODIFIED="1535724888883" TEXT="per ID bekommt man einen...">
|
|
<node CREATED="1535724890399" ID="ID_1544051424" MODIFIED="1535724893410" TEXT="Expander-Proxy"/>
|
|
<node CREATED="1535724894022" ID="ID_91331753" MODIFIED="1535724897842" TEXT="Revealer-Proxy"/>
|
|
</node>
|
|
<node CREATED="1535724910940" ID="ID_1389683609" MODIFIED="1535724922199" TEXT="das Kind hält eine Referenz auf seinen Parent"/>
|
|
</node>
|
|
<node CREATED="1535724555244" ID="ID_336857888" MODIFIED="1535724635442" TEXT="Parent-Container konfiguriert Funktor in das Kind">
|
|
<icon BUILTIN="full-2"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1535724936297" ID="ID_947922423" MODIFIED="1535724966529" TEXT="die default-Impl des Kindes enthält Storage für diese Funktoren"/>
|
|
<node CREATED="1535724976291" ID="ID_1742203413" MODIFIED="1535724996837" TEXT="beim Einbinden in einen Container verdrahtet dieser die Funktoren"/>
|
|
<node CREATED="1535724997873" ID="ID_493457848" MODIFIED="1535725010507" TEXT="und aktiviert damit ggfs die Fähigkeit Expand/Reveal"/>
|
|
<node CREATED="1535725011710" ID="ID_206250793" MODIFIED="1535725020409" TEXT="das Kind kennt seinen Parent nicht"/>
|
|
</node>
|
|
<node CREATED="1535724570738" ID="ID_1785171345" MODIFIED="1561827465365" TEXT="Funktor ist in Mix-in im Kind gespeichert">
|
|
<icon BUILTIN="full-3"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1535725026621" ID="ID_1063803104" MODIFIED="1535725041437" TEXT="Erweiterung zur Lösung">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1535725048130" ID="ID_1987768737" MODIFIED="1535725075314" TEXT="die Funktor-Storage wird in das Kind als Mix-in eingebaut"/>
|
|
<node CREATED="1535725076142" ID="ID_904760905" MODIFIED="1535725093936" TEXT="dieser Mix-In überschreibt auch die default-NOP-Implementierung"/>
|
|
<node CREATED="1535725100803" ID="ID_1869635653" MODIFIED="1535725113085" TEXT="man könnte auf Typ-Ebene Capabilities prüfen"/>
|
|
<node CREATED="1535725117080" ID="ID_417282292" MODIFIED="1535725140662" TEXT="diese Lösung erscheit cool, aber im Moment übertrieben">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535722960729" FOLDED="true" ID="ID_303674498" MODIFIED="1582388548725" TEXT="Abwägung">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1535723619257" ID="ID_1146060205" MODIFIED="1535723638348" TEXT="Ich folge dem appeal der Funktor-Lösung">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1535723641150" ID="ID_945428972" MODIFIED="1535723664351" TEXT="die beiden Fälle werden symmetrisch gemacht..."/>
|
|
<node CREATED="1535723665347" ID="ID_243620982" MODIFIED="1535723693571" TEXT="...indem sie als Funktor direkt in das Widget verlagert sind"/>
|
|
<node CREATED="1535723705158" ID="ID_1284580377" MODIFIED="1535723721479" TEXT="das API reveal(ID) auf dem Parent entfällt ersatzlos"/>
|
|
<node CREATED="1535723722763" ID="ID_751870134" MODIFIED="1535723735461" TEXT="das Herstellen der Funktoren wird ein Implementierungs-Detail"/>
|
|
<node CREATED="1535725684749" ID="ID_711293491" MODIFIED="1535725797751" TEXT="bubble-Up pasiert somit nur noch implizit">
|
|
<node CREATED="1535725711241" ID="ID_1059426307" MODIFIED="1535725743161" TEXT="sofern der Parent-Container seinen eigenen Revealer aufrufen kann"/>
|
|
<node CREATED="1535725744085" ID="ID_1761380382" MODIFIED="1535725770365" TEXT="dagegen das reveal(canvasX,canvasY) wird explizit auf den Layout-Manager verschoben"/>
|
|
<node CREATED="1535725771305" ID="ID_988494427" MODIFIED="1535725789821" TEXT="...welcher somit explizit an geeigneter Stelle verdrahtet sein muß">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1535723783155" ID="ID_1961294443" MODIFIED="1535725808284" TEXT="Konsequenz: die Idee mit den Mix-ins gebe ich auf">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1535723904043" HGAP="12" ID="ID_878787948" MODIFIED="1535725871700" TEXT="Struktur">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1535723916153" ID="ID_91381589" MODIFIED="1535723927220" TEXT="Tangible bekommt einen Expander und einen Revealer"/>
|
|
<node CREATED="1535723930631" ID="ID_1166620864" MODIFIED="1535723955464" TEXT="default-konstruiert sind diese Funktionen deaktiviert"/>
|
|
<node CREATED="1535723958404" ID="ID_1293339775" MODIFIED="1535723973358" TEXT="es gibt hierfür ein Konfigurations-API">
|
|
<node CREATED="1535723978137" ID="ID_1758020852" MODIFIED="1535724000466" TEXT="installExpander(lambda, lambda)"/>
|
|
<node CREATED="1535723987360" ID="ID_1134664898" MODIFIED="1535723995651" TEXT="installRevealer(lambda)"/>
|
|
</node>
|
|
<node CREATED="1535724283280" ID="ID_316168549" MODIFIED="1535724371580" TEXT="ein Container-Parent hat die Pflicht, diese Funktoren ggfs zu installieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1535724349855" ID="ID_782260645" MODIFIED="1535724369173" TEXT="aus einer Hierarchie herausgenommene Widgets sind unverzüglich zu zerstören">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537499427673" ID="ID_1035982675" MODIFIED="1537499435729" TEXT="#1162 helper abstractions for generic widgets">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455421282030" HGAP="54" ID="ID_1448430954" MODIFIED="1518487921086" TEXT="state mark" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455421310603" ID="ID_1677758546" MODIFIED="1518487921086" TEXT="slots und markXX sind aufgedoppelt"/>
|
|
<node CREATED="1455421372274" ID="ID_956411027" MODIFIED="1518487921086" TEXT="Implementierung muß emittieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1455421336808" ID="ID_520325590" MODIFIED="1518487921086" TEXT="wenn eine Änderung relevant für Persistenz"/>
|
|
<node CREATED="1455421392032" ID="ID_969248847" MODIFIED="1518487921086" TEXT="die doXXX() - Funktion gibt true zurück"/>
|
|
<node CREATED="1455421407646" ID="ID_480078096" MODIFIED="1518487921086" TEXT="dann erledigt die slot / mark-Funktion das"/>
|
|
</node>
|
|
<node CREATED="1455421435698" ID="ID_799737882" MODIFIED="1518487921086" TEXT="PresentationStateManager sammelt einfach">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455421453040" ID="ID_1195489674" MODIFIED="1518487921086" TEXT="pro Element (=ID)"/>
|
|
<node CREATED="1455421460671" ID="ID_1160333722" MODIFIED="1518487921086" TEXT="pro "property" == ID-sym der state mark - Nachricht"/>
|
|
</node>
|
|
<node CREATED="1455421490643" ID="ID_256291546" MODIFIED="1518487921086" TEXT="Lösch / Reset-Nachrichten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1455421507505" ID="ID_1382752422" MODIFIED="1518487921086" TEXT="sind auszusenden, wenn tatsächlich gelöscht wurde">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1455421520087" ID="ID_1219279890" MODIFIED="1518487921086" TEXT="werden vom PresentationStateManager speziell behandelt"/>
|
|
</node>
|
|
<node CREATED="1455421537717" ID="ID_562890111" MODIFIED="1518487921086" TEXT="können per Broadcast verbreitet werden">
|
|
<node CREATED="1455421549347" ID="ID_744479545" MODIFIED="1518487921086" TEXT="separates UI-Bus API"/>
|
|
<node CREATED="1455421557026" ID="ID_655863988" MODIFIED="1576282358010">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nach Broadcast von "reset"
|
|
</p>
|
|
<p>
|
|
sollte logischerweise der PresentationStateManager leer sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist er aber nicht notwendig,
|
|
</p>
|
|
<p>
|
|
denn er kann Zustand von nicht mehr existierenden Elementen aufgezeichnet haben.
|
|
</p>
|
|
<p>
|
|
Nur Elemente, die im Moment angeschlossen sind, bekommen die "reset"-Nachricht mit;
|
|
</p>
|
|
<p>
|
|
sofern sie tatsächlich abweichenden Zustand haben, sollten sie sich resetten
|
|
</p>
|
|
<p>
|
|
und eine state mark "reset" zurückschicken...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455422030995" FOLDED="true" HGAP="35" ID="ID_1455265273" MODIFIED="1576282443543" TEXT="mutation" VSHIFT="7">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1455666294927" ID="ID_373207685" MODIFIED="1518487921086" TEXT="Ausgangspunkt">
|
|
<node CREATED="1455666301630" ID="ID_933452284" MODIFIED="1518487921086" TEXT="Element-Protokoll steht"/>
|
|
<node CREATED="1455666310701" ID="ID_571166725" MODIFIED="1518487921086" TEXT="Bus-Semantik steht"/>
|
|
<node CREATED="1455666315061" ID="ID_1650938256" MODIFIED="1518487921086" TEXT="Konzept für Tree-Mutator steht"/>
|
|
<node CREATED="1455666330652" ID="ID_654052510" MODIFIED="1518487921086" TEXT="Tree-Diff-Applikator ist implementiert"/>
|
|
<node CREATED="1455666351784" ID="ID_1889806972" MODIFIED="1518487921086" TEXT="Entscheidung für 2-Phasiges Diff-Update ist gefallen"/>
|
|
</node>
|
|
<node CREATED="1455668350028" HGAP="43" ID="ID_1853535891" MODIFIED="1518487921086" TEXT="Ablauf" VSHIFT="5">
|
|
<node CREATED="1455668396398" ID="ID_1627727409" MODIFIED="1518487921086" TEXT="Diff-Nachricht kommt via UI-Bus">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1455668411867" ID="ID_1932196729" MODIFIED="1518487921086" TEXT="UI-Element baut Tree-Mutator "auf sich selbst"">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1455668689495" ID="ID_1046261411" MODIFIED="1518487921086" TEXT="UI-Element setzt Tree-Diff-Applikator auf diesen an">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455668897947" FOLDED="true" HGAP="211" ID="ID_1897861223" MODIFIED="1576200713578" TEXT="Konsequenzen" VSHIFT="23">
|
|
<node CREATED="1455668923175" ID="ID_1183550957" MODIFIED="1575133324169" TEXT="brauche passendes UI-Bus API">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....so harmlos hat alles angefangen
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Denn das heißt, ich muß konkret ausarbeiten,
|
|
</p>
|
|
<p>
|
|
<i>wie</i> man einen Diff gegen eine opaque Implementierungs-Datenstruktur aufspielt.
|
|
</p>
|
|
<p>
|
|
Und ich muß das in einem Test zumindest emulieren können!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1455668935142" ID="ID_1274632216" MODIFIED="1575133324202">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
muß DiffApplicationStrategy
|
|
</p>
|
|
<p>
|
|
<i>noch einmal</i> implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das mag überraschen --
|
|
</p>
|
|
<p>
|
|
ist aber im Sinne des Erfinders
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
DiffApplicationStrategy war von Anfang an als technisches Binding konzipiert
|
|
</li>
|
|
<li>
|
|
es ist besser, die gleiche Semantik der Sprache X-mal herunterzucoden
|
|
</li>
|
|
<li>
|
|
cleverer Code-re-Use zahlt sich i.d.R. nicht aus
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1455669272760" ID="ID_837691598" MODIFIED="1512926191890" TEXT="Call-Stack ist der Prozessor-Stack (Rekursion)">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1455899000582" ID="ID_1404453203" MODIFIED="1455899086452" TEXT="sorry, geht nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1455899005885" ID="ID_1920318464" MODIFIED="1512926191891" TEXT="denn sonst muß ich">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1455899015220" ID="ID_1476900463" MODIFIED="1455899023991" TEXT="entweder die Anwendung komplett neu schreiben"/>
|
|
<node CREATED="1455899024459" ID="ID_1562031965" MODIFIED="1455899033805" TEXT="oder den DiffApplicator umbauen"/>
|
|
<node CREATED="1455899034129" ID="ID_1505454112" MODIFIED="1455899053610" TEXT="und das reicht bis in die Diff-Verben..."/>
|
|
<node CREATED="1455899054575" ID="ID_1973501142" MODIFIED="1455899068441" TEXT="die dann rekursiv vom Diff-Typ abhängig werden"/>
|
|
<node CREATED="1455899068941" ID="ID_604248716" MODIFIED="1455899072752" TEXT="NEE DANKE"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455669266289" ID="ID_476883926" MODIFIED="1455899233976" TEXT="muß ebenfalls expliziten Stack verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1455899121277" ID="ID_1897194874" MODIFIED="1512926191891" TEXT="eigentlich ist das ganze Copy-n-Paste">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455899176175" ID="ID_589009361" MODIFIED="1455899183929" TEXT="gefühlsmäßig: hier kein Problem"/>
|
|
<node CREATED="1455899184397" ID="ID_933775328" MODIFIED="1455899191320" TEXT="denn die Implementierung ist gekoppelt"/>
|
|
<node CREATED="1455899191836" ID="ID_1325546784" MODIFIED="1455899200983" TEXT="muß gekoppelt sein, wg. Effizienz"/>
|
|
<node CREATED="1455899201435" ID="ID_1353317149" MODIFIED="1455899210798" TEXT="eine Abstraktion hat hier keinen Mehrwert"/>
|
|
<node CREATED="1455899211338" ID="ID_1152596163" MODIFIED="1455899216645" TEXT="und ist überall sonst eine Bürde"/>
|
|
</node>
|
|
<node CREATED="1472829783619" HGAP="28" ID="ID_1015946734" MODIFIED="1472829805342" TEXT="am Ende ist das die schönere Implementierung geworden" VSHIFT="5">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455669004941" ID="ID_853385575" MODIFIED="1575133324401">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dies setzt volle Implementierung
|
|
</p>
|
|
<p>
|
|
des Tree-Mutators voraus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der schwierigste Teil, das Mutieren von Attributen,
|
|
</p>
|
|
<p>
|
|
ist jedoch schon prototypisch implementiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1455899288247" ID="ID_635341866" MODIFIED="1512926191892" TEXT="Tree-Mutator hat echte (Assignment)-Mutation">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1455899303981" ID="ID_1584621992" MODIFIED="1455899333910" TEXT="paßt nicht auf die Semantik vom Diff">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1455899315092" ID="ID_1911158046" MODIFIED="1455899330748" TEXT="dann eben passend machen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1455899321418" ID="ID_802682081" MODIFIED="1455899337153" TEXT="Diff bekommt ein SET verb">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455669313986" ID="ID_1730130372" MODIFIED="1512926191893" TEXT="brauche generiischen Rahmen">
|
|
<node CREATED="1455669322561" ID="ID_1968219875" MODIFIED="1455669325957" TEXT="für skip"/>
|
|
<node CREATED="1455669326400" ID="ID_646237490" MODIFIED="1455669330996" TEXT="für ins / del"/>
|
|
<node CREATED="1455669331448" ID="ID_1852578403" MODIFIED="1455669333036" TEXT="für find"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#ad014c" CREATED="1455669200945" FOLDED="true" HGAP="85" ID="ID_880765624" MODIFIED="1576200677851" TEXT="Design-Fragen" VSHIFT="-14">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#4e1527" CREATED="1458408700205" ID="ID_685778920" MODIFIED="1512926191894" TEXT="Grundansatz">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1458408708004" ID="ID_239878029" MODIFIED="1458408717247" TEXT="Abstraktion / Adapter"/>
|
|
<node CREATED="1458408717739" ID="ID_579166238" MODIFIED="1458408726086" TEXT="(virtuelles) Interface"/>
|
|
<node CREATED="1458408730841" ID="ID_356597537" MODIFIED="1458408739164" TEXT="konkretes Binding"/>
|
|
<node CREATED="1458408742408" ID="ID_1733136177" MODIFIED="1512926191895" TEXT="Binding-Technik">
|
|
<node CREATED="1458408757478" ID="ID_1718466382" MODIFIED="1458408786501" TEXT="Mutator wird in jeweiliger Impl erzeugt"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#221c4f" CREATED="1458408790457" ID="ID_1892865523" MODIFIED="1561827465432" STYLE="fork" TEXT="Polymorphie vs. Funktoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1458408878574" ID="ID_1190262572" MODIFIED="1512926191896" TEXT="Abwägung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1458408895756" ID="ID_1422093195" MODIFIED="1533608413859" TEXT="polymorph">
|
|
<node CREATED="1458408909594" ID="ID_447360746" MODIFIED="1458409828754">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mutator verwendet einen <i>Binder</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458408965770" ID="ID_1892856741" MODIFIED="1458409828754" TEXT="jeweiliger Client implementiert den Binder"/>
|
|
<node CREATED="1458409675740" ID="ID_1319191337" MODIFIED="1458409828754" TEXT="Implementierung direkt durch Typsystem geleitet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1458408946813" ID="ID_86057383" MODIFIED="1458409828754" TEXT="Indirektion, virtuelle Funktionen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1458409155585" ID="ID_1985086830" MODIFIED="1458409828754" TEXT="Client muß explizit instantiieren und verbinden">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1458409202946" ID="ID_162172192" MODIFIED="1458409828754" TEXT="für jede Anwendungssituation eine neue Binder-Klasse"/>
|
|
<node CREATED="1458409270353" ID="ID_114384372" MODIFIED="1458409828754" TEXT="plus für jedes Anwendungs-Grundmuster eine Mutator-Implementierung"/>
|
|
</node>
|
|
<node CREATED="1458408904802" ID="ID_1569962545" MODIFIED="1533608413860" TEXT="generisch">
|
|
<node CREATED="1458409289263" ID="ID_1520752432" MODIFIED="1458409828754" TEXT="konkreter Mutator wird aus Bausteinen zusammengestellt"/>
|
|
<node CREATED="1458409313524" ID="ID_90057804" MODIFIED="1458409828754" TEXT="diese Bausteine verwenden Funktoren und Lambdas"/>
|
|
<node CREATED="1458409343504" ID="ID_1243373098" MODIFIED="1458409828754" TEXT="Mutator-Instantiierung und Lamdas im gleichen Scope"/>
|
|
<node CREATED="1458409357886" ID="ID_102579030" MODIFIED="1458409828754" TEXT="Bindung implizit, Inlining für Lambdas"/>
|
|
<node CREATED="1458409636857" ID="ID_410838714" MODIFIED="1458409828754" TEXT="Typ/Signaturfehler werden (erst) im generischen Code bemerkt">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1458409384661" ID="ID_599058435" MODIFIED="1458409828754" TEXT="für jede Anwendungssituation eine neue Mutator-Implementierung"/>
|
|
<node CREATED="1458409554491" ID="ID_1516498705" MODIFIED="1458409828754" TEXT="aber auch Builder-Zwischenstufen müsen als Funktionen instantiiert werden">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458408881773" ID="ID_649871974" MODIFIED="1512926191899" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#010101" CREATED="1458409428796" ID="ID_1590872717" MODIFIED="1458409828754" TEXT="generisch">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1458409480646" ID="ID_239846348" MODIFIED="1458409828754" TEXT="weniger Indirektion"/>
|
|
<node CREATED="1458409499547" ID="ID_734782069" MODIFIED="1458409828755" TEXT="geringfügig weniger Code-bloat"/>
|
|
<node CREATED="1458409506778" ID="ID_1696279423" MODIFIED="1458409828755" TEXT="bessere Chancen auf Inlining"/>
|
|
<node CREATED="1458409586672" ID="ID_902822558" MODIFIED="1533608413860" TEXT="Client-Code">
|
|
<node CREATED="1458409608924" ID="ID_1425639317" MODIFIED="1458409828755" TEXT="kompakter"/>
|
|
<node CREATED="1458409611484" ID="ID_1386932549" MODIFIED="1458409828755" TEXT="expliziter"/>
|
|
<node CREATED="1458409616980" ID="ID_1067167042" MODIFIED="1458409828755" TEXT="weniger technisch"/>
|
|
<node CREATED="1458409622475" ID="ID_858066487" MODIFIED="1458409828755" TEXT="lesbarer"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455669221255" ID="ID_1712552545" MODIFIED="1512926191900" TEXT="Repräsentation der "aktuellen Position"">
|
|
<node CREATED="1472829837156" ID="ID_1214532087" MODIFIED="1472829843934" TEXT="implizit lassen"/>
|
|
<node CREATED="1472829844387" ID="ID_1395134655" MODIFIED="1472829852134" TEXT="auf Implementierungs-Ebene verlagern"/>
|
|
<node CREATED="1472829853242" ID="ID_562014580" MODIFIED="1472829913272" TEXT="in jedem Layer / für jeden Typ gesondert">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_562014580" ENDARROW="Default" ENDINCLINATION="451;-8;" ID="Arrow_ID_543974195" SOURCE="ID_631826706" STARTARROW="None" STARTINCLINATION="322;-32;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455669345167" ID="ID_310849010" MODIFIED="1455669353721" TEXT="generischen Rahmen für Mut-Operationen"/>
|
|
<node CREATED="1455669238213" ID="ID_731780565" MODIFIED="1512926191900" TEXT="Einleiten der Rekursion">
|
|
<node CREATED="1455842313629" ID="ID_179960248" MODIFIED="1455842321264" TEXT="ich hätte es gern echt-rekursiv"/>
|
|
<node CREATED="1455842321828" ID="ID_1622068738" MODIFIED="1455842336974" TEXT="widerspricht aber unserem DiffApplicator"/>
|
|
</node>
|
|
<node CREATED="1455833678448" HGAP="47" ID="ID_1439118587" MODIFIED="1533684825451" TEXT="Probleme" VSHIFT="16">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1455833736586" ID="ID_1233162987" MODIFIED="1525124215054" TEXT="Analyse: Feld vs Attribut">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1455834007278" ID="ID_196347476" MODIFIED="1512926191903" TEXT="Feld">
|
|
<node CREATED="1455834060110" ID="ID_1872959165" MODIFIED="1455834067177" TEXT="ist da per Struktur"/>
|
|
<node CREATED="1455834067837" ID="ID_944456076" MODIFIED="1455834075400" TEXT="hat immer einen Wert"/>
|
|
</node>
|
|
<node CREATED="1455834010264" ID="ID_1604005834" MODIFIED="1512926191903" TEXT="Attribut">
|
|
<node CREATED="1455834109112" ID="ID_879864381" MODIFIED="1455834119178" TEXT="wird per Key angesprochen"/>
|
|
<node CREATED="1455834121926" ID="ID_504132661" MODIFIED="1455834189337" TEXT="kann abwesend sein"/>
|
|
</node>
|
|
<node CREATED="1455834013389" ID="ID_133168935" MODIFIED="1512926191904" TEXT="Widersprüche">
|
|
<node CREATED="1455834227528" ID="ID_1606302361" MODIFIED="1455834231179" TEXT="Feld hinzufügen"/>
|
|
<node CREATED="1455834231647" ID="ID_1275813367" MODIFIED="1455834236914" TEXT="Feld löschen"/>
|
|
<node CREATED="1455834237999" ID="ID_254859574" MODIFIED="1455834251313" TEXT="Feld suchen"/>
|
|
<node CREATED="1455834400273" ID="ID_54362263" MODIFIED="1455834403925" TEXT="Zuweisung"/>
|
|
<node CREATED="1455834252068" ID="ID_1918373755" MODIFIED="1455834285644" TEXT="Ordnung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455833774965" ID="ID_677756898" MODIFIED="1512926191904" TEXT="Ändern wider die Natur">
|
|
<node CREATED="1455898722195" ID="ID_1299759861" MODIFIED="1455898728644" TEXT="Problem delegieren..."/>
|
|
<node CREATED="1455898713124" ID="ID_1862448261" MODIFIED="1455898720143" TEXT="ignorieren bzw. scheitern lassen"/>
|
|
</node>
|
|
<node CREATED="1455833858794" ID="ID_483179827" MODIFIED="1512926191904" TEXT="zusätzliche Ordnungsstruktur">
|
|
<node CREATED="1455898689479" ID="ID_1223705901" MODIFIED="1455898696898" TEXT="Attribut: ignorieren"/>
|
|
<node CREATED="1455898698670" ID="ID_1532643598" MODIFIED="1455898705001" TEXT="Kind: delegieren"/>
|
|
</node>
|
|
<node CREATED="1455842653928" ID="ID_1996966445" MODIFIED="1561827465435">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Diff kennt keine <i>Zuweisung</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455842674973" ID="ID_1910702757" MODIFIED="1455842682008" TEXT="Löschen + Neueinfügen"/>
|
|
<node CREATED="1455842682524" ID="ID_1597781391" MODIFIED="1455842710444" TEXT="unnötiger Aufwand (Allokation)"/>
|
|
<node CREATED="1455842711008" ID="ID_1470911011" MODIFIED="1455842721083" TEXT="führt zu "Flackern" im UI"/>
|
|
<node CREATED="1455843001833" HGAP="46" ID="ID_617738816" MODIFIED="1512926191905" TEXT="Lösungen" VSHIFT="16">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1455843011048" ID="ID_1280199494" MODIFIED="1512926191905" TEXT="Spezialvereinbarung">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1455843048699" ID="ID_1949875245" MODIFIED="1455843054766" TEXT="Einfügen des gleichen Attributes"/>
|
|
<node CREATED="1455843055122" ID="ID_880285017" MODIFIED="1455843061285" TEXT="geht nur unmittelbar danach"/>
|
|
<node CREATED="1455843061633" ID="ID_1466937234" MODIFIED="1455843065597" TEXT="geht nur mit Attributen"/>
|
|
</node>
|
|
<node CREATED="1455843068672" ID="ID_695348733" MODIFIED="1512926191906" TEXT="neues Verb">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455843074288" ID="ID_251586851" MODIFIED="1455843077987" TEXT="SET"/>
|
|
<node CREATED="1455843120961" ID="ID_1340712241" MODIFIED="1455843131556" TEXT="setzt Element-Identität voraus"/>
|
|
<node CREATED="1455843134111" ID="ID_1830155209" MODIFIED="1455843174534" TEXT="funkioniert (theoretisch) auch bei Kindern"/>
|
|
<node CREATED="1455843262862" ID="ID_779223103" MODIFIED="1533608413862" TEXT="Frage: Auto-PICK">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1455843317119" ID="ID_755404987" MODIFIED="1455895650565" TEXT="Ja: aber was dann mit Umordnungen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1455843336405" ID="ID_1210482014" MODIFIED="1561827465436">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Nein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455895664140" ID="ID_639070488" MODIFIED="1455895669295">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber was dann wenn out-of-order
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1455895670603" FOLDED="true" ID="ID_1629566976" MODIFIED="1561827483835" TEXT="out-of-order">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1455895687377" ID="ID_742953981" MODIFIED="1455895691763" TEXT="wird unterstützt"/>
|
|
<node CREATED="1455895692304" ID="ID_1361195241" MODIFIED="1455895769838" TEXT="denn: analog zu mut-emu">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1455895701215" ID="ID_1720750220" MODIFIED="1455895710033" TEXT="ermöglicht Postfix-Order"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455913713933" ID="ID_155948375" MODIFIED="1561827465440" TEXT="getypte Kinder">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1455913726963" ID="ID_514338534" MODIFIED="1512926191909" TEXT="kommt es vor">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1455926476893" ID="ID_1938999393" MODIFIED="1455926499782" TEXT="ja"/>
|
|
<node CREATED="1455926509185" ID="ID_784567614" MODIFIED="1455926521747" TEXT="in der Filter-Pipe"/>
|
|
<node CREATED="1455926675370" ID="ID_572508223" MODIFIED="1512926191909" TEXT="»Zwei-Listen-Modell«">
|
|
<node CREATED="1455926709229" ID="ID_272389445" MODIFIED="1455926710513" TEXT="für generischen Diff"/>
|
|
<node CREATED="1455926710981" ID="ID_1449723679" MODIFIED="1455926717032" TEXT="mögliche Vereinheitlichung"/>
|
|
<node CREATED="1455926717452" ID="ID_1884046427" MODIFIED="1455926728191" TEXT="generisch, nicht polymorph"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455913731723" ID="ID_1269232747" MODIFIED="1512926191910" TEXT="Problem umgehen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1455926525990" ID="ID_1102781575" MODIFIED="1455926538168" TEXT="wäre möglich"/>
|
|
<node CREATED="1455926539204" ID="ID_650449853" MODIFIED="1455926543144" TEXT="Polymorphismus"/>
|
|
</node>
|
|
<node CREATED="1455913800081" ID="ID_552808081" MODIFIED="1512926191910" TEXT="Typ-Info transportieren">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1455926589909" ID="ID_1341677743" MODIFIED="1455926610247" TEXT="Form der ID"/>
|
|
<node CREATED="1455926610931" ID="ID_1390833573" MODIFIED="1455926615310" TEXT="Präfix in der ID"/>
|
|
<node CREATED="1455926617866" ID="ID_1667737141" MODIFIED="1455926631308" TEXT="Typ-Feld in geschachteltem Record"/>
|
|
<node CREATED="1455926632320" ID="ID_1323008809" MODIFIED="1455926641491" TEXT="Typ der Payload -> Visitor"/>
|
|
</node>
|
|
<node CREATED="1455913759727" HGAP="43" ID="ID_1318158783" MODIFIED="1512926191911" TEXT="Modell">
|
|
<node CREATED="1455913778429" ID="ID_884750408" MODIFIED="1575133325713" TEXT="sub-Collections">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eindeutig überlegen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
faktorisiert sauber
|
|
</li>
|
|
<li>
|
|
Zustand delegiert auf die jeweilige Kinder-Sammlung
|
|
</li>
|
|
<li>
|
|
diese wird damit auch zum generischen Element
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455913847683" ID="ID_1829117976" MODIFIED="1455913860029" TEXT="es gibt effektiv mehrere Kinder-Sammlungen"/>
|
|
<node CREATED="1455913860594" ID="ID_631826706" MODIFIED="1472829913272" TEXT="wir verwalten intern für jede eine Position">
|
|
<arrowlink DESTINATION="ID_562014580" ENDARROW="Default" ENDINCLINATION="451;-8;" ID="Arrow_ID_543974195" STARTARROW="None" STARTINCLINATION="322;-32;"/>
|
|
</node>
|
|
<node CREATED="1455913877183" ID="ID_1295733719" MODIFIED="1455913906711" TEXT="forwarding by type"/>
|
|
</node>
|
|
<node CREATED="1455913785555" ID="ID_1777441123" MODIFIED="1575133325785" TEXT="transparenter Filter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
schlechter....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
sammelt viel technische Komplexität auf top-level
|
|
</li>
|
|
<li>
|
|
wir müssen eine meta-Repräsentation aufbauen
|
|
</li>
|
|
<li>
|
|
wir müssen Adapter zentral generieren, anstatt uns vom Installieren von Closures treiben zu lassen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1455913912323" ID="ID_1775410993" MODIFIED="1455913922605" TEXT="es gibt nominell nur eine Kinder-Folge"/>
|
|
<node CREATED="1455913924857" ID="ID_505406246" MODIFIED="1455913935019" TEXT="wir müssen die intern repräsentieren"/>
|
|
<node CREATED="1455913938287" ID="ID_749740013" MODIFIED="1533608413864" TEXT="passenden Adapter">
|
|
<node CREATED="1455913959452" ID="ID_1132015088" MODIFIED="1455913969855" TEXT="erst beim Zugriff"/>
|
|
<node CREATED="1455913970443" ID="ID_164083502" MODIFIED="1455913995371" TEXT="jeweils Typ feststellen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#3a3785" CREATED="1455927009621" HGAP="148" ID="ID_153254427" MODIFIED="1576200687560" STYLE="fork" TEXT="»generic tree diff«" VSHIFT="22">
|
|
<cloud COLOR="#edd8ba"/>
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<node CREATED="1455927154554" ID="ID_1055035778" MODIFIED="1502453320550" TEXT="Prinzip">
|
|
<node CREATED="1455927162321" ID="ID_285833614" MODIFIED="1455927166972" TEXT="chained adapters"/>
|
|
<node CREATED="1455927169432" ID="ID_1685554012" MODIFIED="1455927207911" TEXT="inline closures"/>
|
|
<node CREATED="1455927216698" ID="ID_817434960" MODIFIED="1455927225756" TEXT="selector predicate"/>
|
|
</node>
|
|
<node CREATED="1455927270458" ID="ID_1471647972" MODIFIED="1502453310933" TEXT="Struktur">
|
|
<node CREATED="1455927276314" ID="ID_1425598677" MODIFIED="1525124215064" TEXT="Diff-verben">
|
|
<cloud COLOR="#fce9c0"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1455927329507" ID="ID_949976479" MODIFIED="1512926191917" TEXT="pick">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927396505" ID="ID_54934717" MODIFIED="1455927399733" TEXT="verify"/>
|
|
<node CREATED="1455927413191" ID="ID_1313233235" MODIFIED="1455982912941" TEXT="accept_src"/>
|
|
<node CREATED="1455927425726" ID="ID_1010708624" MODIFIED="1455982690058" TEXT="next_src"/>
|
|
</node>
|
|
<node CREATED="1455927334882" ID="ID_724923414" MODIFIED="1512926191918" TEXT="ins">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927474671" ID="ID_739710454" MODIFIED="1455982918963" TEXT="inject"/>
|
|
</node>
|
|
<node CREATED="1455927341473" ID="ID_573257215" MODIFIED="1512926191918" TEXT="del">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927479054" ID="ID_93562485" MODIFIED="1455927482234" TEXT="verify"/>
|
|
<node CREATED="1455927483301" ID="ID_1149563805" MODIFIED="1470522011715" TEXT="skipSrc"/>
|
|
</node>
|
|
<node CREATED="1455927346728" ID="ID_1236186762" MODIFIED="1512926191918" TEXT="find">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927510666" ID="ID_968873842" MODIFIED="1455927514101" TEXT="locate_src"/>
|
|
<node CREATED="1455927522081" ID="ID_476699106" MODIFIED="1455982923915" TEXT="accept_src"/>
|
|
</node>
|
|
<node CREATED="1455927354239" ID="ID_501366037" MODIFIED="1512926191918" TEXT="skip">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1470522026709" ID="ID_967937679" MODIFIED="1470522029792" TEXT="skipSrc"/>
|
|
<node CREATED="1470522030780" ID="ID_628304064" MODIFIED="1470522072842" TEXT="Problem: welcher Layer?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927357415" ID="ID_1730455685" MODIFIED="1512926191919" TEXT="after">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927556300" ID="ID_476640075" MODIFIED="1512926191919" TEXT="while not">
|
|
<node CREATED="1455927560940" ID="ID_1275606051" MODIFIED="1455982930194" TEXT="accept_src"/>
|
|
<node CREATED="1455982708749" ID="ID_355029700" MODIFIED="1455982708749" TEXT="next_src"/>
|
|
</node>
|
|
<node CREATED="1455927589560" ID="ID_1967720214" MODIFIED="1512926191919" TEXT="_ATTRIB_">
|
|
<node CREATED="1455927596055" ID="ID_829661861" MODIFIED="1455927600866" TEXT="attrib -> end"/>
|
|
</node>
|
|
<node CREATED="1455927603566" ID="ID_604132662" MODIFIED="1512926191920" TEXT="_END_">
|
|
<node CREATED="1455927607621" ID="ID_948240245" MODIFIED="1455927610465" TEXT="all -> end"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927360398" ID="ID_1123321103" MODIFIED="1512926191920" TEXT="set">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927661046" ID="ID_608131093" MODIFIED="1512926191920" TEXT="if not verify">
|
|
<node CREATED="1455927681491" ID="ID_1621577646" MODIFIED="1455927694621" TEXT="locate_target"/>
|
|
</node>
|
|
<node CREATED="1455927697105" ID="ID_1909489348" MODIFIED="1455927701684" TEXT="verify"/>
|
|
<node CREATED="1455927702465" ID="ID_321172748" MODIFIED="1455927704244" TEXT="assign"/>
|
|
</node>
|
|
<node CREATED="1455927363102" ID="ID_1117221392" MODIFIED="1512926191921" TEXT="mut">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927714615" ID="ID_958571239" MODIFIED="1512926191921" TEXT="if not verify">
|
|
<node CREATED="1455927718574" ID="ID_1870238884" MODIFIED="1455927721586" TEXT="locate_target"/>
|
|
</node>
|
|
<node CREATED="1455927724238" ID="ID_664459993" MODIFIED="1455927734345" TEXT="verify"/>
|
|
<node CREATED="1455927736084" ID="ID_1788904482" MODIFIED="1512926191921" TEXT="push">
|
|
<node CREATED="1455927739355" ID="ID_1160724761" MODIFIED="1455927741512" TEXT="mutator"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927365094" ID="ID_1567754459" MODIFIED="1512926191921" TEXT="emu">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927745131" ID="ID_1000032658" MODIFIED="1455927749590" TEXT="verify_end"/>
|
|
<node CREATED="1455927750490" ID="ID_1746587224" MODIFIED="1455927752838" TEXT="pop"/>
|
|
</node>
|
|
<node CREATED="1455927337321" ID="ID_1622487857" MODIFIED="1512926191921" TEXT="CTOR">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455927444275" ID="ID_643592318" MODIFIED="1512926191922" TEXT="push">
|
|
<node CREATED="1455927462641" ID="ID_14883638" MODIFIED="1455927465084" TEXT="mutator"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927276314" HGAP="91" ID="ID_1209647803" MODIFIED="1525124215074" VSHIFT="-3">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Primitive
|
|
</p>
|
|
<p>
|
|
<font size="2">(impl-ops)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<cloud COLOR="#fce9c0"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1455982947867" ID="ID_1339677569" MODIFIED="1512926191924" TEXT="injectNew">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455982969073" ID="ID_1885889112" MODIFIED="1455982974332" TEXT="inject new content"/>
|
|
<node CREATED="1457047512175" ID="ID_1126383522" MODIFIED="1457047519426" TEXT="at implicit "current" position"/>
|
|
</node>
|
|
<node CREATED="1455927425726" ID="ID_1776437339" MODIFIED="1512926191925" TEXT="hasSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928216420" ID="ID_662720483" MODIFIED="1464117064570" TEXT="further src elements available"/>
|
|
<node CREATED="1470527053136" ID="ID_1383280265" MODIFIED="1470527075712">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
of questionable use
|
|
</p>
|
|
<p>
|
|
with multiple layers
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927396505" ID="ID_392033275" MODIFIED="1512926191926" TEXT="matchSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928268589" ID="ID_97473072" MODIFIED="1512926191926" TEXT="ID comparison">
|
|
<node CREATED="1455928524530" ID="ID_545057240" MODIFIED="1457120284424" TEXT="implicit next pos"/>
|
|
<node CREATED="1455928530738" ID="ID_1035043901" MODIFIED="1455928533677" TEXT="ID"/>
|
|
</node>
|
|
<node CREATED="1470778603801" ID="ID_1808045935" MODIFIED="1575133326567" TEXT="needed to implement the `del` verb">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
since skipSrc performs both the `del` and the `skip` verb, it can not perform the match itself...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927425726" ID="ID_1759686725" MODIFIED="1512926191926" TEXT="skipSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1470527086660" ID="ID_13765501" MODIFIED="1470527097135" TEXT="guarded by selector">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1470772440180" ID="ID_1241607377" MODIFIED="1575133326608" TEXT="can not match by itself">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...because it is also used to discard garbage after a findSrc operation.
|
|
</p>
|
|
<p>
|
|
Thus we need to avoid touching the actual data in the src sequence, because this might lead to SEGFAULT.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
For this reason, the implementation of the `del` verb has to invoke matchSrc explicitly beforehand,
|
|
</p>
|
|
<p>
|
|
and this is the very reason `matchSrc` exists. Moreover, `matchSrc` must be written such
|
|
</p>
|
|
<p>
|
|
as to ensure to invoke the Selector before performing a local match. And skipSrc has to
|
|
</p>
|
|
<p>
|
|
proceed in precisely the same way. Thus, if the selector denies responsibility, we'll delegate
|
|
</p>
|
|
<p>
|
|
to the next lower layer in both cases, and the result and behaviour depends on this next lower layer solely
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455928216420" ID="ID_1581600385" MODIFIED="1470778395226" TEXT="thus just advance source position"/>
|
|
</node>
|
|
<node CREATED="1455927413191" ID="ID_1624797970" MODIFIED="1512926191927" TEXT="acceptSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1470527086660" ID="ID_410793564" MODIFIED="1470772489007" TEXT="guarded by selector">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1470772440180" ID="ID_836603881" MODIFIED="1470772503839" TEXT="verify match with next src position"/>
|
|
<node CREATED="1455928275316" ID="ID_702364156" MODIFIED="1512926191928">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
then <i>move</i> into target
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1455928537273" ID="ID_1036724915" MODIFIED="1457120296935" TEXT="implicit next pos"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928166683" ID="ID_238485247" MODIFIED="1512926191929" TEXT="accept_until">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928383765" ID="ID_522592769" MODIFIED="1455928389737" TEXT="accept until condition is met"/>
|
|
<node CREATED="1457231714541" ID="ID_1234563594" MODIFIED="1457231725704" TEXT="ID spec"/>
|
|
<node CREATED="1472829929343" ID="ID_797835614" MODIFIED="1472829944881" TEXT="special handling for Ref::END / Ref::ATTRIBS"/>
|
|
<node CREATED="1457231524839" ID="ID_1492447432" MODIFIED="1575133326760" TEXT="needs to establish responsible target beforehand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
since, on interface level, we're pretending that this mutator <i>is a single collection like thing,</i>
|
|
</p>
|
|
<p>
|
|
while in fact the implementation might bind to several opaque target structures.
|
|
</p>
|
|
<p>
|
|
Thus, internally we'll have a <b>selector</b> to determine which onion layer is responsible for
|
|
</p>
|
|
<p>
|
|
handling an element as designated by the argument. It is then the responsibility
|
|
</p>
|
|
<p>
|
|
of this specific onion layer to accept forward until meeting this element.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1457231727259" ID="ID_1318527107" MODIFIED="1575133326776">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#e72d0e">warning:</font> messed-up state in case of failure
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
this is (probably) the only operation which entirely messes up the mutator state
|
|
</p>
|
|
<p>
|
|
when the designated target does not exist. The assumption is that a diff application front-end
|
|
</p>
|
|
<p>
|
|
will check the bool return value and throw an exception in that case
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927413191" ID="ID_94560199" MODIFIED="1512926191930" TEXT="findSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1461946965569" ID="ID_803034273" MODIFIED="1461946980872" TEXT="locate designated src element"/>
|
|
<node CREATED="1455928275316" ID="ID_1937317223" MODIFIED="1512926191930">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>move</i> into target
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1455928537273" ID="ID_1177385447" MODIFIED="1457120296935" TEXT="implicit next pos"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928184504" ID="ID_836844042" MODIFIED="1512926191931" TEXT="assignElm">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928393788" ID="ID_403756991" MODIFIED="1512926191931" TEXT="locate target">
|
|
<node CREATED="1457190206827" ID="ID_1711690131" MODIFIED="1457190220485" TEXT="allready accepted element"/>
|
|
<node CREATED="1457190227089" ID="ID_1094585247" MODIFIED="1457190234435" TEXT="find by ID comparison"/>
|
|
<node CREATED="1457190235191" ID="ID_926146761" MODIFIED="1457190240027" TEXT="try current element first"/>
|
|
</node>
|
|
<node CREATED="1455928403931" ID="ID_1750063931" MODIFIED="1512926191931" TEXT="assign payload">
|
|
<node CREATED="1455928586506" ID="ID_1163700862" MODIFIED="1457190259104" TEXT="implicit Type context"/>
|
|
<node CREATED="1455928612239" ID="ID_588352525" MODIFIED="1455928619186" TEXT="embedded target data"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928189695" ID="ID_1319966604" MODIFIED="1512926191932" TEXT="mutateChild">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1457190279001" ID="ID_1000897100" MODIFIED="1512926191932" TEXT="locate target">
|
|
<node CREATED="1457190288624" ID="ID_1258290029" MODIFIED="1457190296115" TEXT="same as in 'assignElm'"/>
|
|
</node>
|
|
<node CREATED="1455928415161" ID="ID_1664558338" MODIFIED="1512926191932" TEXT="fabricate mutator">
|
|
<node CREATED="1457190370846" ID="ID_1146518798" MODIFIED="1457190374749" TEXT="suitable for target"/>
|
|
<node CREATED="1455928625269" ID="ID_1880024064" MODIFIED="1457190388167" TEXT="open / init mutator"/>
|
|
</node>
|
|
<node CREATED="1457190320444" ID="ID_1835423331" MODIFIED="1512926191933" TEXT="place into provided buffer">
|
|
<node CREATED="1457190396170" ID="ID_275107868" MODIFIED="1457190419158">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>throw </i>when
|
|
</p>
|
|
<p>
|
|
insufficent space
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464113688645" ID="ID_954516697" MODIFIED="1512926191934" STYLE="fork" TEXT="completeScope">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1464113727192" ID="ID_357369611" MODIFIED="1464113739514" TEXT="prüft, ob alles eingelöst wurde"/>
|
|
<node CREATED="1464113740005" ID="ID_1649881726" MODIFIED="1464113748425" TEXT="emöglicht Aufräum-Arbeiten"/>
|
|
<node CREATED="1464113754412" ID="ID_1095488369" MODIFIED="1575133327061" TEXT="kann NOP implementiert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...in Fällen, in denen der konkrete onion-layer
|
|
</p>
|
|
<p>
|
|
überhaupt nicht im Stande ist, das zu beurteilen.
|
|
</p>
|
|
<p>
|
|
Wichtigster solcher Fall ist die <b>Bindung auf Objekt-Felder</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#e5500c" CREATED="1461946693701" ID="ID_36720859" MODIFIED="1512926191934" STYLE="fork" TEXT="meta-Operationen">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928193863" ID="ID_1750104896" MODIFIED="1512926191935" TEXT="CTOR">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928427432" ID="ID_1760631999" MODIFIED="1461946914155" TEXT="take ownership of existing contents"/>
|
|
<node CREATED="1461946885292" ID="ID_1743121055" MODIFIED="1461946907948" TEXT="move them into source buffer"/>
|
|
</node>
|
|
<node CREATED="1455928193863" ID="ID_545402083" MODIFIED="1512926191935" TEXT="open_subScope">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928427432" ID="ID_1189452497" MODIFIED="1455928435275" TEXT="push mutator on stack"/>
|
|
<node CREATED="1457190622236" ID="ID_1347446227" MODIFIED="1461946862429">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
invoke <b>mutateChild</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928198718" ID="ID_1546579792" MODIFIED="1512926191936" TEXT="close_subScope">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928440366" ID="ID_33734026" MODIFIED="1457190669578" TEXT="just pop mutator"/>
|
|
<node CREATED="1457190670069" ID="ID_242879400" MODIFIED="1575133327206" TEXT="abandon mutator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>NOTE</b>: mutator need to be written in such a way
|
|
</p>
|
|
<p>
|
|
to be just discarded when done with the alterations.
|
|
</p>
|
|
<p>
|
|
That is, the mutator<i> must not</i> incorporate the target data, rather it is expected
|
|
</p>
|
|
<p>
|
|
to construct the new target data efficiently in place.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1457190826145" ID="ID_1342883622" MODIFIED="1457190834604" TEXT="return to previous mutator"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#85212c" CREATED="1455928782528" HGAP="-171" ID="ID_1300146872" MODIFIED="1533684815449" TEXT="kritische Aufgaben" VSHIFT="-207">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1455928917782" HGAP="40" ID="ID_812598653" MODIFIED="1512926191937" TEXT="failure Policy" VSHIFT="-11">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1455928937683" ID="ID_784708305" MODIFIED="1455928953041" TEXT="ignorieren">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1455928949346" ID="ID_1044467237" MODIFIED="1455928955415" TEXT="scheitern">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928800670" HGAP="83" ID="ID_1116973935" MODIFIED="1512926191937" TEXT="selector predicate" VSHIFT="-5">
|
|
<node CREATED="1455928838865" ID="ID_1505861137" MODIFIED="1455928845027" TEXT="konfigurierbarer Typ-Check"/>
|
|
<node CREATED="1455928846048" ID="ID_1278060510" MODIFIED="1455928856146" TEXT="TypCheck nur einmal"/>
|
|
<node CREATED="1455928856870" ID="ID_806857541" MODIFIED="1455928878335" TEXT="ggfs Sequenz von ID-Checks"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1455928805717" FOLDED="true" HGAP="76" ID="ID_496821508" MODIFIED="1576200699031" TEXT="mutator allocation" VSHIFT="-1">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1455930962188" ID="ID_1435085503" MODIFIED="1455930970295" TEXT="konkreter Mutator-Typ"/>
|
|
<node CREATED="1455930971027" ID="ID_1070880241" MODIFIED="1455930980789" TEXT="ist in jedem Einzelfall anders"/>
|
|
<node CREATED="1455931008750" ID="ID_643730154" MODIFIED="1575133327378" TEXT="Mutator enthält Closures">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mutator enthält die Bindung auf die konkreten Daten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455930997303" ID="ID_1710972681" MODIFIED="1455931003962" TEXT="kann erhebliche Größe haben"/>
|
|
<node CREATED="1455931025595" ID="ID_1695885971" MODIFIED="1575133327404" TEXT="ist a priori nicht bekannt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
stellt sich u.U erst während der Verarbeitung heraus:
|
|
</p>
|
|
<p>
|
|
bei "offenen Datenstrukturen" entscheided jeder Typ selber,
|
|
</p>
|
|
<p>
|
|
welchen Mutator er erzeugt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456011474920" HGAP="-25" ID="ID_1292432889" MODIFIED="1525124215078" TEXT="Lösungsansätze" VSHIFT="28">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1456011490414" ID="ID_215912114" MODIFIED="1512926191940" TEXT="doch rekursiv">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1456011497525" ID="ID_165091928" MODIFIED="1456011507880" TEXT="elegant"/>
|
|
<node CREATED="1456011508731" ID="ID_1951843758" MODIFIED="1456011513711" TEXT="Allokation nebenbei"/>
|
|
<node CREATED="1456011591427" ID="ID_167337651" MODIFIED="1512926191941">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber: Aufrufprinzip
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1456011595024" ID="ID_1268079925" MODIFIED="1456011598819" TEXT="muß konsumieren"/>
|
|
<node CREATED="1456011599455" ID="ID_862262812" MODIFIED="1456011634435">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verb muß den
|
|
</p>
|
|
<p>
|
|
Diff bekommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456011647057" ID="ID_905672765" MODIFIED="1456011652964" TEXT="verwirrendes API"/>
|
|
<node CREATED="1456011653904" ID="ID_1199841076" MODIFIED="1456011656396" TEXT="komplexe Typen"/>
|
|
<node CREATED="1456011660495" ID="ID_118747856" MODIFIED="1456011661939" TEXT="njet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456011666486" ID="ID_1076199754" MODIFIED="1512926191941" TEXT="Interpreter konsumiert">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1456011676086" ID="ID_1849622483" MODIFIED="1456011688340">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und delegiert iterativ
|
|
</p>
|
|
<p>
|
|
an die Verben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456011689043" ID="ID_1674393396" MODIFIED="1456011698214" TEXT="muß Verben untersuchen"/>
|
|
<node CREATED="1456011698970" ID="ID_845834851" MODIFIED="1456011717387" TEXT="aktiv in Rekursion einsteigen"/>
|
|
<node CREATED="1456011717951" ID="ID_1167483025" MODIFIED="1456011722666" TEXT="auch verwirrend"/>
|
|
</node>
|
|
<node CREATED="1456011734253" ID="ID_478177524" MODIFIED="1512926191942" TEXT="doch beim Stack bleiben">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1456011910869" ID="ID_182841484" MODIFIED="1456429740520" TEXT="kleineres Übel">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1456011918381" ID="ID_54237513" MODIFIED="1456011991777" TEXT="Rolle des Mutators">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456012543585" HGAP="26" ID="ID_1774389094" MODIFIED="1512926191942" TEXT="Struktur-Ideen" VSHIFT="20">
|
|
<node CREATED="1456012563942" ID="ID_842130823" MODIFIED="1456012570081" TEXT="Referenz zum Mutator"/>
|
|
<node CREATED="1456012572045" ID="ID_340104657" MODIFIED="1456012577752" TEXT="Mutator ist smart-ptr"/>
|
|
<node CREATED="1456012578868" ID="ID_1107535684" MODIFIED="1456012585103" TEXT="Frontend-Backend"/>
|
|
<node CREATED="1456012585835" ID="ID_1377280414" MODIFIED="1456012605260" TEXT="Mutator im Inline-Puffer"/>
|
|
<node CREATED="1456012665681" ID="ID_227844194" MODIFIED="1575133327718" TEXT="Größe initial festlegen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn in dem Moment, wo wir den top-level TreeMutator erzeugen,
|
|
</p>
|
|
<p>
|
|
können wir rekursiv abfragen, wie groß alle möglichen Kind-Mutatoren werden können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d8bba4" CREATED="1456011994442" HGAP="68" ID="ID_343687995" MODIFIED="1561827465475" TEXT="zur Entscheidung..." VSHIFT="37">
|
|
<edge COLOR="#93766f"/>
|
|
<arrowlink COLOR="#b10046" DESTINATION="ID_820279076" ENDARROW="Default" ENDINCLINATION="14;-46;" ID="Arrow_ID_103087571" STARTARROW="None" STARTINCLINATION="-137;-20;"/>
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1456012846185" ID="ID_714953132" MODIFIED="1512926191944" TEXT="was ist der Mutator">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1456012035837" ID="ID_180428099" MODIFIED="1456012039389" TEXT="Container"/>
|
|
<node CREATED="1456184290492" ID="ID_1860454535" MODIFIED="1456184298524" TEXT="Strategy"/>
|
|
<node CREATED="1456012028134" ID="ID_820709337" MODIFIED="1456012031953" TEXT="Adapter"/>
|
|
<node CREATED="1456012033085" ID="ID_755204065" MODIFIED="1456012034841" TEXT="Puffer"/>
|
|
</node>
|
|
<node CREATED="1456012859031" ID="ID_1120123290" MODIFIED="1512926191944" TEXT="wer erzeugt den Mutator">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1456013036967" ID="ID_1719719197" MODIFIED="1456013042330" TEXT="der Applikator"/>
|
|
<node CREATED="1456013043038" ID="ID_1263902491" MODIFIED="1456013047497" TEXT="die Zieldatenstruktur"/>
|
|
</node>
|
|
<node CREATED="1456013049909" HGAP="107" ID="ID_1581320145" MODIFIED="1512926191945" TEXT="Anwendungs-Fälle" VSHIFT="29">
|
|
<cloud COLOR="#d6c6a5"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1456013057420" ID="ID_1458089109" MODIFIED="1512926191945" TEXT="externe Datenstruktur">
|
|
<node CREATED="1456013290573" ID="ID_802953483" MODIFIED="1456013297208" TEXT="hat beliebig Platz"/>
|
|
<node CREATED="1456013298084" ID="ID_117703425" MODIFIED="1456013305071" TEXT="Closures in der Impl-Klasse"/>
|
|
<node CREATED="1456013306186" ID="ID_1397201984" MODIFIED="1456013330235" TEXT="effizient nur ohne Trennung"/>
|
|
<node CREATED="1456013359452" ID="ID_675424172" MODIFIED="1456013364783" TEXT="braucht Hilfe beim Lebenszyklus"/>
|
|
<node CREATED="1456013368426" ID="ID_1906604960" MODIFIED="1456013373717" TEXT="könnte Puffer selber allozieren"/>
|
|
</node>
|
|
<node CREATED="1456013068179" ID="ID_774826163" MODIFIED="1512926191945" TEXT="Rec<GenNode>">
|
|
<node CREATED="1456013114140" ID="ID_1057946691" MODIFIED="1456013123199" TEXT="hat keinen extra Platz"/>
|
|
<node CREATED="1456013123739" ID="ID_1081025245" MODIFIED="1456013132837" TEXT="Tick: in RecMutator umdeuten"/>
|
|
<node CREATED="1456013133386" ID="ID_1417100176" MODIFIED="1456013138077" TEXT="Puffer muß woanders leben"/>
|
|
<node CREATED="1456013149327" ID="ID_687443349" MODIFIED="1456013168385" TEXT="Impl-Collection in Puffer verschieben"/>
|
|
</node>
|
|
<node CREATED="1456013063011" ID="ID_908970422" MODIFIED="1512926191946" TEXT="Collection">
|
|
<node CREATED="1456013202760" ID="ID_1619699608" MODIFIED="1456013218586" TEXT="hat keinen extra Platz"/>
|
|
<node CREATED="1456013219750" ID="ID_1766379648" MODIFIED="1456013227785" TEXT="kann überhaupt nicht helfen"/>
|
|
<node CREATED="1456013231117" ID="ID_1899116139" MODIFIED="1456013238279" TEXT="Puffer muß woanders leben"/>
|
|
<node CREATED="1456013239820" ID="ID_1794944692" MODIFIED="1456013244911" TEXT="wieder Verschiebe-Trick"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456184583336" HGAP="125" ID="ID_1225582084" MODIFIED="1512926191947" TEXT="weitere Beobachtungen" VSHIFT="36">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1456184689466" ID="ID_1635861686" MODIFIED="1512926191947" TEXT="externe Struktur == Ausnahme">
|
|
<node CREATED="1456184725333" ID="ID_646480978" MODIFIED="1456184735783" TEXT="unterstützt keine Umordnung"/>
|
|
<node CREATED="1456184736827" ID="ID_171431775" MODIFIED="1456184746398" TEXT="unterstützt kein Hinzufügen"/>
|
|
<node CREATED="1456184746946" ID="ID_1768153345" MODIFIED="1456184756780" TEXT="Löschen wird uminterpretiert"/>
|
|
</node>
|
|
<node CREATED="1456184697944" ID="ID_1904390217" MODIFIED="1512926191947" TEXT="Mutator und subMutator">
|
|
<node CREATED="1456184816553" ID="ID_1019484567" MODIFIED="1456184832218" TEXT="getypte Kinder -> subMutator"/>
|
|
<node CREATED="1456184833446" ID="ID_1632860381" MODIFIED="1456184864038" TEXT="subMutator für subCollection"/>
|
|
<node CREATED="1461881226351" ID="ID_211513452" MODIFIED="1461881233506" TEXT="subMutator == "onon layer""/>
|
|
<node CREATED="1456184892870" ID="ID_1216247694" MODIFIED="1456184905433" TEXT="Rec<GenNode> -> zwei subCollections"/>
|
|
</node>
|
|
<node CREATED="1456186634006" ID="ID_310265994" MODIFIED="1512926191948" TEXT="Profil des Mutators">
|
|
<node CREATED="1456186654411" ID="ID_1341247857" MODIFIED="1575133328189" TEXT="Erzeugen geht schnell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur Zuweisung einiger Referenzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456186688671" ID="ID_1110994752" MODIFIED="1512926191948" TEXT="Allokation">
|
|
<node CREATED="1456186753094" ID="ID_653529641" MODIFIED="1456186771647" TEXT="Größenordnung der Zieldatenstruktur"/>
|
|
<node CREATED="1456186772163" ID="ID_1555284305" MODIFIED="1456186779750" TEXT="im Collection-Fall kann man durchreichen"/>
|
|
</node>
|
|
<node CREATED="1456186797568" ID="ID_1773938090" MODIFIED="1456186809890" TEXT="ausschließlich an die Diff-Anwendung gekoppelt"/>
|
|
<node CREATED="1456186915112" ID="ID_1560470636" MODIFIED="1512926191948" TEXT="Größe duch Binde-Voragang bestimmt">
|
|
<node CREATED="1456186933998" ID="ID_528314478" MODIFIED="1533608413864" TEXT="Zahl der subMutatoren">
|
|
<node CREATED="1456187166294" ID="ID_1282142171" MODIFIED="1456187174186" TEXT="ein Vector pro Collection"/>
|
|
<node CREATED="1456416605491" ID="ID_1722541208" MODIFIED="1456416614478" TEXT="eigentlicher Content wird durchgereicht"/>
|
|
</node>
|
|
<node CREATED="1456186946508" ID="ID_335779075" MODIFIED="1533608413865" TEXT="Zahl der Einzelbindungen">
|
|
<node CREATED="1456187264346" ID="ID_81725454" MODIFIED="1456187278539" TEXT="ein Slot pro Binding-Layer"/>
|
|
<node CREATED="1456187279408" ID="ID_954788495" MODIFIED="1561827465475" TEXT="Attribut-Map">
|
|
<node CREATED="1456187295550" ID="ID_534521654" MODIFIED="1456187329981" TEXT="Setter und Getter"/>
|
|
<node CREATED="1456187330641" ID="ID_1069743778" MODIFIED="1456187335684" TEXT="zwei Slots pro Attribut"/>
|
|
<node CREATED="1456416534525" ID="ID_1195638113" MODIFIED="1575133328373" TEXT="+Storage für den Key">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....denn der liegt (mind) einmal vor,
|
|
</p>
|
|
<p>
|
|
eingebettet in ein Selektor-Prädikat,
|
|
</p>
|
|
<p>
|
|
welches bestimmt, ob dieses Attribut angesprochen wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456187338288" ID="ID_1194536240" MODIFIED="1456187339692" TEXT="Heap"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456437116514" ID="ID_1766577674" MODIFIED="1512926191950" TEXT="Reflexion">
|
|
<cloud COLOR="#d2c2d9"/>
|
|
<node CREATED="1456187434491" ID="ID_860365577" MODIFIED="1456437137837" TEXT="alles ekelhaft">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1456187447618" ID="ID_1318283286" MODIFIED="1456187459568" TEXT="Sackgasse">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1456424184807" ID="ID_770700785" MODIFIED="1525124215095" TEXT="Alternativen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1456424237672" ID="ID_811857290" MODIFIED="1575133328443" TEXT="zu Fuß programmieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was man konventionellerweise auch macht.
|
|
</p>
|
|
<p>
|
|
Ich verstehe nun, warum. Es ist der <i>vernünftigste</i> Weg.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Leider scheidet das aber für uns hier genau aus,
|
|
</p>
|
|
<p>
|
|
denn das gesamte Projekt entstand, aufgrund der inhärenten Limitierungen
|
|
</p>
|
|
<p>
|
|
der "vernünftigen" (=pragmatischen) Lösung.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456424257381" ID="ID_740973686" MODIFIED="1575133328458" TEXT="introspektive Datenstruktur">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieser Ansatz löst tatsächlich das Problem,
|
|
</p>
|
|
<p>
|
|
aber zu dem Preis, daß er die Strukturen von innen her zersetzt.
|
|
</p>
|
|
<p>
|
|
Auf lange Sicht wird das System wuchern wie ein Krebsgeschwühr,
|
|
</p>
|
|
<p>
|
|
und man kann das nur mit Disziplin eindämmen, was <i>realistisch gesprochen</i> meint,
|
|
</p>
|
|
<p>
|
|
daß es vergeblich ist. Einen Kampf gegen das Menschliche, Allzumenschliche kann man nicht gewinnen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456424962239" ID="ID_933613304" MODIFIED="1575133328492" TEXT="einseitige Fernsteuerung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist die schlankeste Lösung, die ästhetisch befriedigt.
|
|
</p>
|
|
<p>
|
|
Sie hat aber das Problem, daß dadurch die Kollaboration im Kern ausgelöscht wird.
|
|
</p>
|
|
<p>
|
|
Wir haben eine Seite, die absolute Macht hat, und einen "Partner", der tatsächlich nur ferngesteuert ist.
|
|
</p>
|
|
<p>
|
|
Wir müssen dafür auf die Subsidiarität verzichten, und damit auf die Möglichkeit zur Entkoppelung.
|
|
</p>
|
|
<p>
|
|
Dazu kommt, daß die notwendige Fern-Wirkung stets eine zusätzliche Last bedeutet.
|
|
</p>
|
|
<p>
|
|
Denn wir müssen auf Umstände und Strukturen einwirken, die von dem Ort, an dem die
|
|
</p>
|
|
<p>
|
|
Steuerung stattfindet, entfernt ist, entfernt in einen anderen Kontext.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1456425646332" ID="ID_897964875" MODIFIED="1456425651999" TEXT="oberflächengetrieben"/>
|
|
<node CREATED="1456425652683" ID="ID_437402611" MODIFIED="1456425656575" TEXT="zentralgesteuert"/>
|
|
</node>
|
|
<node CREATED="1456424295296" ID="ID_791299475" MODIFIED="1533608413867" TEXT="DOM + Attribution">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1456424627860" ID="ID_1294496825" MODIFIED="1456424632247" TEXT="keine Alternative"/>
|
|
<node CREATED="1456424632907" ID="ID_1566098600" MODIFIED="1456424642598" TEXT="denn genau das machen wir hier"/>
|
|
<node CREATED="1456437181070" HGAP="23" ID="ID_1066542027" MODIFIED="1561827465476" STYLE="bubble" TEXT="Analyse" VSHIFT="44">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1456424664015" FOLDED="true" ID="ID_1032924247" MODIFIED="1561827483835" TEXT="Problem: Zusatz-Kosten">
|
|
<node CREATED="1456424675173" ID="ID_1585536570" MODIFIED="1456437520768" TEXT="...für das "+""/>
|
|
<node CREATED="1456424695123" ID="ID_331589423" MODIFIED="1456437520769" TEXT="also die Bindung"/>
|
|
<node CREATED="1456424722039" FOLDED="true" ID="ID_1926017913" MODIFIED="1561827482931" TEXT="notwendige Kosten">
|
|
<node CREATED="1456424725927" ID="ID_1322872728" MODIFIED="1456437520769" TEXT="denn das DOM ist rein"/>
|
|
<node CREATED="1456424730022" ID="ID_282791744" MODIFIED="1456437520769" TEXT="hat also keinen Platz für explizite Eigenschaften"/>
|
|
<node CREATED="1456424765113" ID="ID_1716539711" MODIFIED="1456437520770">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und nur letztere sind <i>tangibel</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456425913664" FOLDED="true" HGAP="28" ID="ID_1929919601" MODIFIED="1561827483835" TEXT="notwendig" VSHIFT="-1">
|
|
<node CREATED="1456426041626" FOLDED="true" ID="ID_101262346" MODIFIED="1561827482931" TEXT="Duplikation">
|
|
<node CREATED="1456425918071" ID="ID_18884187" MODIFIED="1456437520772" TEXT="DOM-IDs am Binde-Punkt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
um den Binde- bzw. Anknüpfungs-Punkt in den real-Daten überhaupt zu finden,
|
|
</p>
|
|
<p>
|
|
müssen IDs aus dem DOM innerhalb der real-Daten nochmal wiederholt, also redundant vorliegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456425930718" ID="ID_1301765327" MODIFIED="1456437520772" TEXT="real-Daten im DOM">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
damit das DOM ein echtes DOM ist, muß es die relevanten real-Daten duplizieren,
|
|
</p>
|
|
<p>
|
|
um sie in einem abstrahierten Kontext zugänglich zu machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456426052973" ID="ID_239653128" MODIFIED="1456437520772" TEXT="Binde-Daten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
noch zusätzlich zur genannten Duplikation muß
|
|
</p>
|
|
<p>
|
|
die Abblidung der Strukturen aufeinander
|
|
</p>
|
|
<p>
|
|
an irgend einer Stelle repräsentiert werden.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456426322482" ID="ID_1330880148" MODIFIED="1456437520773" TEXT="irreduzibel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man kann versuchen, die beiden Elemente der Duplikation aufzulösen.
|
|
</p>
|
|
<p>
|
|
Allerdings gibt es dafür überhaupt nur zwei mögliche Richtungen.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
man löst die Parallel-Strukturen auf
|
|
</li>
|
|
<li>
|
|
man ersetzt das DOM durch reine Bindungs-Strukturen
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Beide Ansätze laufen aber auf eine der schon genanten, anderen Alternativen hinaus.
|
|
</p>
|
|
<p>
|
|
Wenn man die Parallel-Strukturen beseitigt, enden wir bei irgend einer Form von Fernsteuerung.
|
|
</p>
|
|
<p>
|
|
Wenn man die Modell-Natur aus dem DOM entfernt, das heißt, dort nur noch reine<br />Binde-Strukturen speichert, dann endet man bei einer Form von Introspektion. Entweder,
|
|
</p>
|
|
<p>
|
|
das Rückgrat und die Navigation verbleibt bei dieser Introspektion; dann haben wir eines
|
|
</p>
|
|
<p>
|
|
der typischen Objekt-Systeme. Oder die Binde-Daten werden zu einem reinen Anhang
|
|
</p>
|
|
<p>
|
|
an eine selbständig bestehende Datenstruktur; dann enden wir bei klassischer Introspektion.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456428989206" FOLDED="true" HGAP="28" ID="ID_1999101531" MODIFIED="1561827483835" TEXT="Maßstab" VSHIFT="17">
|
|
<node CREATED="1456429002332" FOLDED="true" ID="ID_294696563" MODIFIED="1561827482931" TEXT="Trennung">
|
|
<node CREATED="1456429013283" ID="ID_462304497" MODIFIED="1456437520773" TEXT="abstrakt"/>
|
|
<node CREATED="1456429016050" ID="ID_403266218" MODIFIED="1456437520774" TEXT="tangibel"/>
|
|
</node>
|
|
<node CREATED="1456429046358" FOLDED="true" ID="ID_327619080" MODIFIED="1561827482931" TEXT="Fokussierung innerhalb">
|
|
<node CREATED="1456429106894" ID="ID_345392088" MODIFIED="1456437520774" TEXT="Belange des UI"/>
|
|
<node CREATED="1456429110702" ID="ID_1531485619" MODIFIED="1456437520774" TEXT="Notwendigkeiten des Edit-Vorganges"/>
|
|
<node CREATED="1456429159559" ID="ID_4036488" MODIFIED="1456437520774" TEXT="nach der inhärenten Form suchen"/>
|
|
</node>
|
|
<node CREATED="1456429053206" ID="ID_643637016" MODIFIED="1456437520774" TEXT="wenig Überlapp"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456423477045" HGAP="146" ID="ID_1294023197" MODIFIED="1512926191957" TEXT="Stand der Überlegungen" VSHIFT="11">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1456423615274" ID="ID_40789197" MODIFIED="1512926191958" TEXT="Performance">
|
|
<node CREATED="1456423617763" ID="ID_524247634" MODIFIED="1456423622197" TEXT="wird von der Allokation bestimmt"/>
|
|
<node CREATED="1456423642687" ID="ID_1252228590" MODIFIED="1456423660940">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
reflektiert die Zahl der <i>Struktur</i>-Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456423661669" ID="ID_1064355256" MODIFIED="1575133328660" TEXT="Collections sind außen vor">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen:
|
|
</p>
|
|
<p>
|
|
für die habe ich bereits eine effiziente Implementierung,
|
|
</p>
|
|
<p>
|
|
die darauf beruht, den Content beiseite zu schieben.
|
|
</p>
|
|
<p>
|
|
Ich brauche also nur ein Container-Frontend (z.B. einen Vector ohne Inhalt) zusätzlich,
|
|
</p>
|
|
<p>
|
|
um den verschobenen Inhalt erst mal aufzunehmen.
|
|
</p>
|
|
<p>
|
|
Also zählen Kinder-Collections nur als <i>ein </i>Strukturelement.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456423839637" ID="ID_1087136823" MODIFIED="1512926191958" TEXT="Platzbedarf">
|
|
<node CREATED="1456423848028" ID="ID_212325084" MODIFIED="1456423851935" TEXT="ist signifikant"/>
|
|
<node CREATED="1456423860130" ID="ID_1592353572" MODIFIED="1456423872404" TEXT="Größenordnung der Ziel-Struktur (ohne Collections)"/>
|
|
<node CREATED="1456423883159" ID="ID_229501623" MODIFIED="1456423918662" TEXT="permanentes Vorhalten in der Ziel-Datenstruktur ist keine gute Idee"/>
|
|
<node CREATED="1456423940695" ID="ID_301596165" MODIFIED="1456423963088" TEXT="Platz wird ausschließlich zur Diff-Anwendung gebraucht"/>
|
|
<node CREATED="1456423964572" ID="ID_1023557891" MODIFIED="1456423986445" TEXT="Stack-Struktur ist sinnvoll"/>
|
|
<node CREATED="1456424025228" ID="ID_1821511383" MODIFIED="1456424051133" TEXT="Kacheln, blockweise"/>
|
|
</node>
|
|
<node CREATED="1456428753110" ID="ID_900159058" MODIFIED="1512926191959" TEXT="Struktur">
|
|
<node CREATED="1456428763108" ID="ID_158540274" MODIFIED="1456428768063" TEXT="Frontend-Backend"/>
|
|
<node CREATED="1456428768579" ID="ID_1251866964" MODIFIED="1456428772654" TEXT="aber das Backend ist inline"/>
|
|
<node CREATED="1456428774171" ID="ID_745180197" MODIFIED="1456428896734" TEXT="Puffergröße initial festlegen"/>
|
|
<node CREATED="1456429302212" ID="ID_377071784" MODIFIED="1456429313666">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rekursiv,
|
|
</p>
|
|
<p>
|
|
duch Bindung bestimmt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456429330129" ID="ID_1923625809" MODIFIED="1512926191960" TEXT="technische Probleme">
|
|
<node CREATED="1456429337736" ID="ID_398416910" MODIFIED="1456429344154" TEXT="runtime - compiletime"/>
|
|
<node CREATED="1456429403455" ID="ID_166294730" MODIFIED="1456429408386" TEXT="Festlegen der Binde-Struktur"/>
|
|
<node CREATED="1456429465015" ID="ID_1980478069" MODIFIED="1456429476745" TEXT="Übersetzen in eine Typ-Spezifikation"/>
|
|
<node CREATED="1456429488492" ID="ID_393439057" MODIFIED="1456429496150" TEXT="aus dem Typ eine Größe ableiten"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456430088803" HGAP="129" ID="ID_481518617" MODIFIED="1576282411283" TEXT="Lösung" VSHIFT="25">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1456430099658" ID="ID_820279076" MODIFIED="1512926191960" TEXT="Entscheidung">
|
|
<linktarget COLOR="#b10046" DESTINATION="ID_820279076" ENDARROW="Default" ENDINCLINATION="14;-46;" ID="Arrow_ID_103087571" SOURCE="ID_343687995" STARTARROW="None" STARTINCLINATION="-137;-20;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1456430153555" ID="ID_1609974475" MODIFIED="1456430170074" TEXT="es ist wesentlich"/>
|
|
<node CREATED="1456430115696" ID="ID_546849410" MODIFIED="1456430120227" TEXT="es ist notwendig"/>
|
|
<node CREATED="1456430109105" ID="ID_366046751" MODIFIED="1456430172153" TEXT="es ist machbar"/>
|
|
</node>
|
|
<node CREATED="1456430178935" HGAP="22" ID="ID_1069025314" MODIFIED="1512926191961" TEXT="der Weg..." VSHIFT="5">
|
|
<node CREATED="1456430183863" ID="ID_464613085" MODIFIED="1456430193433" TEXT="expliziter Stack"/>
|
|
<node CREATED="1456430194117" ID="ID_943734591" MODIFIED="1456430211847" TEXT="enthält Front-End"/>
|
|
<node CREATED="1456430212811" ID="ID_90339221" MODIFIED="1456430233644" TEXT="und Backend in Puffer"/>
|
|
<node CREATED="1456430234656" ID="ID_1583269810" MODIFIED="1456430240155" TEXT="der Puffer ist eingebettet"/>
|
|
<node CREATED="1456430240887" ID="ID_1308625708" MODIFIED="1512926191961" TEXT="Grundmuster der Bindung">
|
|
<node CREATED="1456430374141" ID="ID_1551177855" MODIFIED="1456430398830" TEXT="Collection + Element-Konstruktur"/>
|
|
<node CREATED="1456430440196" ID="ID_1922438930" MODIFIED="1456430445551" TEXT="Attribut-Map als Getter/Setter"/>
|
|
<node CREATED="1456430515186" ID="ID_831818012" MODIFIED="1456430519166" TEXT="Rec<GenNode>"/>
|
|
</node>
|
|
<node CREATED="1457120439360" ID="ID_1972741688" MODIFIED="1576282358009" TEXT="ID match ist Aufgabe der Implementierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist der wesentliche Kniff,
|
|
</p>
|
|
<p>
|
|
durch den das Problem mit der "absrakten, opaquen" Position entschärft wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456430363599" ID="ID_1608232847" MODIFIED="1456505525321" TEXT="erlaube typ-gefilterte Kinder"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576201938680" HGAP="146" ID="ID_486184645" MODIFIED="1576202931124" VSHIFT="62">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font size="4">Implementierung: <b>Diff-Bindung</b></font> -> Diff-System
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#47e573" DESTINATION="ID_61713493" ENDARROW="Default" ENDINCLINATION="-3400;234;" ID="Arrow_ID_1763921751" STARTARROW="None" STARTINCLINATION="-792;48;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576203018747" FOLDED="true" HGAP="-50" ID="ID_645743424" MODIFIED="1576282432827" TEXT="Diff: Einbindung in das UI-Framework" VSHIFT="38">
|
|
<edge COLOR="#5d7d78"/>
|
|
<linktarget COLOR="#298c9e" DESTINATION="ID_645743424" ENDARROW="Default" ENDINCLINATION="-928;-33;" ID="Arrow_ID_653906070" SOURCE="ID_1903460265" STARTARROW="None" STARTINCLINATION="-2105;61;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1473352465473" ID="ID_158999012" MODIFIED="1518487921086" TEXT="in Tangible">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475250911087" ID="ID_1042895809" MODIFIED="1518487921086" TEXT="zu klären">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475250919286" ID="ID_211228413" MODIFIED="1518487921086" TEXT="wie sieht die initiale (diff)Nachricht aus">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475355977081" ID="ID_1302138609" MODIFIED="1518487921087" TEXT="dediziertes API"/>
|
|
<node CREATED="1475356001462" ID="ID_1339165799" MODIFIED="1518487921087" TEXT="Nexus zerlegt das"/>
|
|
<node CREATED="1475356007860" ID="ID_1405013613" MODIFIED="1518487921087" TEXT="löst direkt Anwendung aus"/>
|
|
</node>
|
|
<node CREATED="1475251507800" ID="ID_1645310973" MODIFIED="1518487921087" TEXT="wo/wie wird Diff-Nachricht behandelt">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475355925880" ID="ID_464242009" MODIFIED="1576282358009" TEXT="...analog zur "mark"-Nachricht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
diese wird im Nexus behandelt, in dem die Tangible::mark()-Methode aktiviert wird
|
|
</li>
|
|
<li>
|
|
in dieser wiederum steckt eine Default-Handler-Sequenz, plus ein Strategy-Pattern
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475250930756" ID="ID_509435943" MODIFIED="1518487921087" TEXT="wo steckt der Diff selber">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475251013513" ID="ID_1464747905" MODIFIED="1518487921087" TEXT="Diff == iterierbare <DiffStep>-Sequenz">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1475251032255" ID="ID_824967618" MODIFIED="1518487921087" TEXT="paßt nicht in eine GenNode">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1475355960899" ID="ID_1468155641" MODIFIED="1518487921087">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Marker-Typ <b>MutationMessage</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475250947858" ID="ID_1438298132" MODIFIED="1518487921087" TEXT="wer ist der Kommunikationspartner">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475356021762" ID="ID_1261042951" MODIFIED="1518487921087" TEXT="irrelevant, da abstrahiert"/>
|
|
</node>
|
|
<node CREATED="1475250957097" ID="ID_1839306136" MODIFIED="1518487921087" TEXT="wie kennt das Tangible diesen Partner">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1475342135193" FOLDED="true" HGAP="31" ID="ID_336806935" MODIFIED="1576203487696" TEXT="Problem: Diff-Nachricht" VSHIFT="7">
|
|
<arrowlink COLOR="#a7afc1" DESTINATION="ID_1363153586" ENDARROW="Default" ENDINCLINATION="931;-187;" ID="Arrow_ID_324877454" STARTARROW="Default" STARTINCLINATION="835;592;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1475342157302" ID="ID_1383404259" MODIFIED="1475342166025" TEXT=""Diff" ist kein Typ"/>
|
|
<node CREATED="1475342185707" ID="ID_787925049" MODIFIED="1475342190662" TEXT="Lumiera-Iteratoren sind generisch"/>
|
|
<node CREATED="1475342218598" ID="ID_686706998" MODIFIED="1502453541592" TEXT="Alternativen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1475342242123" ID="ID_996905586" MODIFIED="1512926192149" TEXT="implizite Diff-Facade">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1475342267168" ID="ID_1015562836" MODIFIED="1475342372677" TEXT="nur ID eines Diff senden..."/>
|
|
<node CREATED="1475342283158" ID="ID_859890341" MODIFIED="1475342287497" TEXT="Diff ist dann hinterlegt"/>
|
|
<node CREATED="1475342309914" ID="ID_1398047498" MODIFIED="1475342360640" TEXT="Wo? im GuiModel??">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1475342301331" ID="ID_496549205" MODIFIED="1475342346474" TEXT="zwar implizit, aber starr">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475342230013" ID="ID_129545687" MODIFIED="1502453545312" TEXT="UI-Bus-Interface erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475342469085" ID="ID_218240539" MODIFIED="1475342487060" TEXT="Ausgangspunkt: DiffMutable">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1475342391631" ID="ID_1330153391" MODIFIED="1502599884276" TEXT="Transport per MutationMessage">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1475342401278" ID="ID_1020722080" MODIFIED="1502453642509" TEXT="abstrakte Koppelung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475444207483" ID="ID_920212553" MODIFIED="1502550756115" TEXT="Festlegung: Tangible als Zieltyp">
|
|
<linktarget COLOR="#9287b2" DESTINATION="ID_920212553" ENDARROW="Default" ENDINCLINATION="398;0;" ID="Arrow_ID_52222580" SOURCE="ID_62520790" STARTARROW="None" STARTINCLINATION="360;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1475356047496" HGAP="29" ID="ID_667427572" MODIFIED="1502454682718" TEXT="Implementierung" VSHIFT="14">
|
|
<arrowlink COLOR="#71e5ac" DESTINATION="ID_60387485" ENDARROW="Default" ENDINCLINATION="50;-12;" ID="Arrow_ID_1384671312" STARTARROW="None" STARTINCLINATION="12;195;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475356059342" ID="ID_1039482059" MODIFIED="1475444176904" TEXT="wie wird Diff eingebettet">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1475439403514" ID="ID_1619035258" MODIFIED="1502453694045" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1502453744365" ID="ID_452337305" MODIFIED="1512926192150" TEXT="Schritt-1">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1475439416185" ID="ID_963854956" MODIFIED="1575133340883" TEXT="Builder-Funktion nicht sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....denn dann müßte der Benutzer die Mechanik sehr genau verstehen, und stets eine auto-Variable definieren.
|
|
</p>
|
|
<p>
|
|
Sinnvoll wäre dieser Ansatz nur, wenn das UI-Bus-API eine MutationMessage const& nehmen würde,
|
|
</p>
|
|
<p>
|
|
denn dann könnte man den Builder-Aufruf inline schreiben.
|
|
</p>
|
|
<p>
|
|
Da wir aber stets den Diff moven und dann iterieren, scheidet const& aus
|
|
</p>
|
|
<p>
|
|
Und für eine reine Ref erzeugt C++ niemals eine anonyme Instanz!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1475439429055" ID="ID_1383518557" MODIFIED="1575133340899" TEXT="also: embeded Buffer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und diesen mit VTable bestücken.
|
|
</p>
|
|
<p>
|
|
Dafür wird die äußere Hülle non-virtual
|
|
</p>
|
|
<p>
|
|
und kann noncopyable gemacht werden..
|
|
</p>
|
|
<p>
|
|
Das erlaubt dem Benutzer, einfach zu schreiben
|
|
</p>
|
|
<p>
|
|
MutationMessage(blaBlubb())
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1475439436134" ID="ID_583247605" MODIFIED="1475444176904" TEXT="verwende InPlaceBuffer"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1475356066853" ID="ID_821643910" MODIFIED="1533608413996" TEXT="Problem: Puffergröße">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1475444135180" ID="ID_1434100612" MODIFIED="1475444176904" TEXT="sinnvoll: Spezialfall für Tangible"/>
|
|
<node CREATED="1475444145458" ID="ID_62520790" MODIFIED="1502550756115" TEXT="kann dann DiffSizeTraits spezialisieren">
|
|
<arrowlink COLOR="#9287b2" DESTINATION="ID_920212553" ENDARROW="Default" ENDINCLINATION="398;0;" ID="Arrow_ID_52222580" STARTARROW="None" STARTINCLINATION="360;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502453753155" ID="ID_89098030" MODIFIED="1564495786621" TEXT="Schritt-2">
|
|
<linktarget COLOR="#bdbad3" DESTINATION="ID_89098030" ENDARROW="Default" ENDINCLINATION="600;-1189;" ID="Arrow_ID_554743885" SOURCE="ID_1584846573" STARTARROW="None" STARTINCLINATION="1459;870;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502453814499" ID="ID_727706359" MODIFIED="1533608413997" TEXT="Puffer-Ansatz...">
|
|
<node CREATED="1502453828721" ID="ID_1337002332" MODIFIED="1502453830621" TEXT="komplex"/>
|
|
<node CREATED="1502453831233" ID="ID_443299660" MODIFIED="1502453835332" TEXT="unflexibel"/>
|
|
<node CREATED="1502453842463" ID="ID_1995272746" MODIFIED="1502453861969" TEXT="unnötiges Kopieren"/>
|
|
<node CREATED="1502453836112" ID="ID_1547334309" MODIFIED="1502453841067" TEXT="insgeheim doch gekoppelt"/>
|
|
</node>
|
|
<node CREATED="1502454064930" ID="ID_1876117833" MODIFIED="1502454072133" TEXT="brauche Entkoppelung"/>
|
|
<node CREATED="1502454072649" ID="ID_1325287539" MODIFIED="1533608413997">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Abstraktion
|
|
</p>
|
|
<p>
|
|
nach beiden Setien
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1502454089783" ID="ID_104095093" MODIFIED="1502454093290" TEXT="zum Erzeuger"/>
|
|
<node CREATED="1502454093814" ID="ID_1063793799" MODIFIED="1502454099337" TEXT="zum Empfänger"/>
|
|
</node>
|
|
<node CREATED="1502454117907" ID="ID_995116747" MODIFIED="1533608413998" TEXT="abstrakter Iterator">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1502454128617" ID="ID_1019985292" MODIFIED="1502454135844" TEXT="muß Interface sein"/>
|
|
<node CREATED="1502454136368" ID="ID_1196043940" MODIFIED="1502454138836" TEXT="IterSource"/>
|
|
<node CREATED="1502454139496" ID="ID_455247221" MODIFIED="1561827465611" TEXT="Problem: Übergabe">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1502454152431" ID="ID_1452648004" MODIFIED="1502454163000" TEXT="Diff über Thread-Grenzen hinweg"/>
|
|
<node CREATED="1502454163685" ID="ID_1591230048" MODIFIED="1502454169704" TEXT="Pull-Prinzip"/>
|
|
<node CREATED="1502454183682" ID="ID_1647826766" MODIFIED="1502454194490" TEXT="Callback aus anderen Thread"/>
|
|
<node CREATED="1502454170228" ID="ID_1401327421" MODIFIED="1502454181097" TEXT="muß Erzeugungskontext weitergeben">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475449460694" HGAP="13" ID="ID_425831735" MODIFIED="1525124215236" TEXT="Prototyp: MockElm" VSHIFT="32">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475449491378" ID="ID_1309107114" MODIFIED="1475449505548" TEXT="führe Spiel-Attribute und Kinder ein"/>
|
|
<node CREATED="1475449507224" ID="ID_1783640184" MODIFIED="1512926192154" TEXT="Kinder">
|
|
<node CREATED="1475449530565" ID="ID_284330532" MODIFIED="1475449531825" TEXT="collection von MockElm"/>
|
|
<node CREATED="1475449532556" ID="ID_1804332542" MODIFIED="1576282358008" TEXT="MockElm ist noncopyable">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aus gutem Grund!
|
|
</p>
|
|
<p>
|
|
Der Nexus speichert nämlich eine direkte Referenz in der Routingtabelle
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1475449544379" ID="ID_1132064603" MODIFIED="1475449583284" TEXT="also nur per shared_ptr">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475449589725" ID="ID_460570633" MODIFIED="1512926192155" TEXT="Attribute">
|
|
<node CREATED="1475449594060" HGAP="27" ID="ID_1311933287" MODIFIED="1512926192155" TEXT="Typ" VSHIFT="14">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475449959916" ID="ID_573697431" MODIFIED="1475449966244" TEXT="map<string,string>"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1475449611754" HGAP="33" ID="ID_275833424" MODIFIED="1576204191297" TEXT="Grundsatzfrage: Attribute-Manipulation per Map unterstützen?" VSHIFT="1">
|
|
<arrowlink COLOR="#ef6e6e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="-571;0;" ID="Arrow_ID_524729956" STARTARROW="None" STARTINCLINATION="886;42;"/>
|
|
<linktarget COLOR="#c48c7d" DESTINATION="ID_275833424" ENDARROW="Default" ENDINCLINATION="-975;32;" ID="Arrow_ID_454192352" SOURCE="ID_789920101" STARTARROW="None" STARTINCLINATION="937;102;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1475546298721" HGAP="24" ID="ID_1646756860" MODIFIED="1475546316260" TEXT="vorkonfiguriertes TreeMutator-Binding" VSHIFT="10">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1473352470896" HGAP="21" ID="ID_864450713" MODIFIED="1518487921087" TEXT="Unit-Tests" VSHIFT="18">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1473352475375" ID="ID_731425414" MODIFIED="1518487921087" TEXT="AbstractTangible_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1473352482502" ID="ID_1891838260" MODIFIED="1518487921087" TEXT="BusTerm_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502453280050" ID="ID_60387485" MODIFIED="1518487921087" TEXT="MutationMessage_test">
|
|
<linktarget COLOR="#71e5ac" DESTINATION="ID_60387485" ENDARROW="Default" ENDINCLINATION="50;-12;" ID="Arrow_ID_1384671312" SOURCE="ID_667427572" STARTARROW="None" STARTINCLINATION="12;195;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1502459245238" ID="ID_1193318639" MODIFIED="1518487921087" TEXT="Basisfall: Producer / Consumer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502459264523" ID="ID_640036069" MODIFIED="1518487921087" TEXT="Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502459259123" ID="ID_372973959" MODIFIED="1518487921087" TEXT="Diagnose-Dekorator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1502459266371" ID="ID_883276790" MODIFIED="1518487921087" TEXT="Integrationstest">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448658726090" HGAP="18" ID="ID_37610818" MODIFIED="1518487921087" TEXT="Commands" VSHIFT="36">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1448658755071" ID="ID_1033500384" MODIFIED="1518487921087" TEXT="wie definieren">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1448658974985" ID="ID_974207484" MODIFIED="1518487921087" TEXT="Definition braucht Session-Modell"/>
|
|
<node CREATED="1448659018412" ID="ID_1988707066" MODIFIED="1518487921087" TEXT="zentral">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1448659021803" ID="ID_1800666256" MODIFIED="1518487921087" TEXT="nah an der Session"/>
|
|
<node CREATED="1448659026042" ID="ID_831434285" MODIFIED="1518487921087" TEXT="ein Schnittstellen-Paket"/>
|
|
<node CREATED="1448669306480" ID="ID_1009169288" MODIFIED="1518487921087">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: <b><font color="#8d02e1">InteractionControl</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5f0ac8" DESTINATION="ID_329609486" ENDARROW="Default" ENDINCLINATION="219;-148;" ID="Arrow_ID_1101633958" STARTARROW="None" STARTINCLINATION="-315;0;"/>
|
|
<linktarget COLOR="#b567c4" DESTINATION="ID_1009169288" ENDARROW="Default" ENDINCLINATION="254;0;" ID="Arrow_ID_200182911" SOURCE="ID_1002329025" STARTARROW="None" STARTINCLINATION="162;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448659051823" ID="ID_1995941804" MODIFIED="1518487921087" TEXT="dezentral">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1448659059734" ID="ID_1682547207" MODIFIED="1518487921087" TEXT="im GUI-Kontext"/>
|
|
<node CREATED="1448659079044" ID="ID_508900352" MODIFIED="1576282358008" TEXT="muß Session referenzieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was andernfalles komplett vermeidbar wäre,
|
|
</p>
|
|
<p>
|
|
da im Übrigen das UI-Modell nur mit LUIDs und generischen Namen arbeitet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448658773972" ID="ID_1826752340" MODIFIED="1518487921087" TEXT="referenzieren">
|
|
<node CREATED="1448659283641" ID="ID_209203268" MODIFIED="1518487921087" TEXT="letztlich ein String"/>
|
|
<node CREATED="1448659347728" ID="ID_508578010" MODIFIED="1518487921087" TEXT="Konstante bei der Command-Funktion"/>
|
|
<node CREATED="1448659334058" ID="ID_683316035" MODIFIED="1518487921087" TEXT="Makro + Namenskonvention">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1448683561882" ID="ID_839961131" MODIFIED="1518487921087">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Idee: <b>context-bound</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#81759f" DESTINATION="ID_1690039650" ENDARROW="Default" ENDINCLINATION="513;-275;" ID="Arrow_ID_838588653" STARTARROW="None" STARTINCLINATION="702;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448658819990" FOLDED="true" ID="ID_405705528" MODIFIED="1582388565907" TEXT="API explizit">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1448658861760" ID="ID_1373851015" MODIFIED="1518487921087" TEXT="pro">
|
|
<node CREATED="1448658867680" ID="ID_766147415" MODIFIED="1518487921087" TEXT="sauber"/>
|
|
<node CREATED="1448659206251" ID="ID_1542057563" MODIFIED="1518487921087" TEXT="nah am konkreten Widget"/>
|
|
<node CREATED="1448659217489" ID="ID_214385592" MODIFIED="1518487921087" TEXT="integriert in sonstiges UI-Verhalten"/>
|
|
<node CREATED="1448658947429" ID="ID_302940509" MODIFIED="1518487921087" TEXT="Fehlaufrufe ausgeschlossen"/>
|
|
</node>
|
|
<node CREATED="1448658873767" ID="ID_1028163948" MODIFIED="1518487921087" TEXT="con">
|
|
<node CREATED="1448658883341" ID="ID_543652783" MODIFIED="1518487921087" TEXT="Aufwand"/>
|
|
<node CREATED="1448658885973" ID="ID_1734626095" MODIFIED="1518487921087" TEXT="ctxt-Menü aufbauen"/>
|
|
<node CREATED="1448659158177" ID="ID_1496901578" MODIFIED="1518487921087" TEXT="Namen müssen matchen"/>
|
|
<node CREATED="1448659163089" ID="ID_431765107" MODIFIED="1518487921087" TEXT="man muß Korrektheit prüfen"/>
|
|
<node CREATED="1448683674443" ID="ID_1931753413" MODIFIED="1518487921087" TEXT="Einheitlichkeit gefährdet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448683454504" FOLDED="true" HGAP="42" ID="ID_510876193" MODIFIED="1582388564341" TEXT="API generisch" VSHIFT="-1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1448683636672" ID="ID_1485949406" MODIFIED="1518487921087" TEXT="verhindert Wildwuchs"/>
|
|
<node CREATED="1448683475853" ID="ID_24599710" MODIFIED="1518487921087">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Command und Verhaltensmuster
|
|
</p>
|
|
<p>
|
|
bleiben zusammen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448683496794" ID="ID_821199097" MODIFIED="1518487921087" TEXT="unterstützt weiterreichende Konzepte">
|
|
<node CREATED="1448683518496" ID="ID_1987782234" MODIFIED="1518487921087" TEXT="Perspektiven"/>
|
|
<node CREATED="1448683522359" ID="ID_723377610" MODIFIED="1518487921087" TEXT="Fokus-Konzept"/>
|
|
<node CREATED="1448683525822" ID="ID_1395068730" MODIFIED="1518487921087" TEXT="Gesten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448691191042" FOLDED="true" HGAP="35" ID="ID_1710578352" MODIFIED="1561827465618" TEXT="Lebenszyklus" VSHIFT="-1">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1448691210544" ID="ID_242337741" MODIFIED="1448691218906" TEXT="Command-Skript: im Code"/>
|
|
<node CREATED="1448691219614" ID="ID_992447056" MODIFIED="1512926192187" TEXT="Bildungs-Regeln: ebenda">
|
|
<node CREATED="1448691243259" ID="ID_692910736" MODIFIED="1448691256433" TEXT="Frage: wie injizieren">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448691264512" FOLDED="true" ID="ID_1193936433" MODIFIED="1582388577398" TEXT="InvocationTrail erstellen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1450490467952" ID="ID_1453525628" MODIFIED="1450490480705" TEXT="verwendet zwei GenNode-bindings"/>
|
|
<node CREATED="1450490481270" ID="ID_1603770702" MODIFIED="1576282358007" TEXT="fertig implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was ich einen Monat später schon wieder vergessen hatte...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1492442129540" ID="ID_284311341" MODIFIED="1492442138750" TEXT="Konzept wurde verworfen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492442175974" ID="ID_23690520" MODIFIED="1512926192189" TEXT="Instanz-Management">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492442182205" ID="ID_1076303592" MODIFIED="1492442188344" TEXT="erfolgt automatisch und transparent"/>
|
|
<node CREATED="1492442190644" ID="ID_1654649004" MODIFIED="1492442204598" TEXT="kann optional explizit gemacht werden (Command-Cycle)"/>
|
|
<node CREATED="1492442207674" ID="ID_259490518" MODIFIED="1492442212700" TEXT="CommandInstanceManager"/>
|
|
<node CREATED="1492442213265" ID="ID_1455743867" MODIFIED="1492442221044" TEXT="sitzt in SessionCommandService"/>
|
|
<node CREATED="1448692240015" ID="ID_58254695" MODIFIED="1448692245826" TEXT="es geht um Allokationen in Proc"/>
|
|
<node CREATED="1448692247478" ID="ID_1199512787" MODIFIED="1492442343267" TEXT="Instanz">
|
|
<node CREATED="1492442343855" ID="ID_1475597297" MODIFIED="1492442351322" TEXT="benannt == Eintrag in der Command-Registry"/>
|
|
<node CREATED="1492442352269" ID="ID_1319878028" MODIFIED="1492442362576" TEXT="anonym == nur smart-Handle">
|
|
<node CREATED="1492442366676" ID="ID_52781679" MODIFIED="1492442372625" TEXT="Regelfall">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1492442373619" ID="ID_752576891" MODIFIED="1492442378644" TEXT="Prototype-Pattern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492442383849" ID="ID_1676576926" MODIFIED="1492442399303" TEXT="CommandDef == Prototyp">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448691315849" FOLDED="true" ID="ID_1198560195" MODIFIED="1582388582841" TEXT="Bindugs-Regel">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1448691343406" ID="ID_642235825" MODIFIED="1448691350558" TEXT="funktor"/>
|
|
<node CREATED="1448691324304" ID="ID_1103199702" MODIFIED="1448691338522" TEXT="definiert Bezugs-Quellen"/>
|
|
<node CREATED="1448691355340" ID="ID_724965495" MODIFIED="1448691465633" TEXT="liefert Record<GenNode>"/>
|
|
<node CREATED="1452560897720" ID="ID_1869468443" MODIFIED="1576282358007" TEXT="vorerst noch nicht impl...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier geht es darum, eine Regel zu generieren,
|
|
</p>
|
|
<p>
|
|
die dann den zugrundeliegenden Command-Prototyp automatisch mit konkreten Aufrufparametern binden kann,
|
|
</p>
|
|
<p>
|
|
sobald bestimmte Umstände im UI einschlägig werden
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das ist ein erweiterter / komplexerer Anwendungsfall.
|
|
</p>
|
|
<p>
|
|
Der einfache Standard-Anwendungsfall ist, direkt die Command-ID zu senden
|
|
</p>
|
|
<p>
|
|
das reicht für die erste Integrationsrunde völlig aus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492443650460" ID="ID_223885519" MODIFIED="1512926192189" TEXT="einfacher direkter Aufruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492443656859" ID="ID_1242818576" MODIFIED="1492443663663" TEXT="Tangible / Bus-Term"/>
|
|
<node CREATED="1492443664602" ID="ID_263362527" MODIFIED="1576282358006" TEXT="reine Command-ID">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Instanz-Management ist automatisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492443693582" ID="ID_1398931015" MODIFIED="1492443713695" TEXT="Argumente direkt in diff::Record einpacken"/>
|
|
<node CREATED="1492443715587" ID="ID_1695168160" MODIFIED="1492443719574" TEXT="dieser wird durchgereicht"/>
|
|
<node CREATED="1492443720234" ID="ID_1597671253" MODIFIED="1492443733860" TEXT="und im Command-Framework per Visitor ausgewertet"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582388591087" HGAP="65" ID="ID_457412600" MODIFIED="1582388675571" TEXT="Technik" VSHIFT="41">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1582388650742" ID="ID_681444782" MODIFIED="1582388698969">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
»<b>Tangible</b>« : Basis
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<node CREATED="1582388710734" ID="ID_763140844" MODIFIED="1582388714337" TEXT="Komponenten"/>
|
|
<node CREATED="1582388714901" ID="ID_1965183860" MODIFIED="1582388717017" TEXT="Funktionen">
|
|
<node CREATED="1582388720805" ID="ID_1679585515" MODIFIED="1582388727816" TEXT="Diagnostik">
|
|
<node COLOR="#338800" CREATED="1582388728476" ID="ID_1154344311" MODIFIED="1582390885990" TEXT="operator string: Typ und ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582390900917" ID="ID_1137278126" MODIFIED="1582390969068" TEXT="ID (Bus-Term-ID) bekommt man per getID()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anfangs hatte ich da eine implizite Konvertierung. Man konnte schreiben ID{xyz}. Das war cool; und verwirrend; und hat jede Menge Ärger gemacht, wie immer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448669332204" FOLDED="true" HGAP="76" ID="ID_329609486" MODIFIED="1566955621429" TEXT="InteractionControl">
|
|
<arrowlink COLOR="#b694bf" DESTINATION="ID_430949603" ENDARROW="Default" ENDINCLINATION="178;425;" ID="Arrow_ID_1062305149" STARTARROW="Default" STARTINCLINATION="-629;-2354;"/>
|
|
<linktarget COLOR="#715f85" DESTINATION="ID_329609486" ENDARROW="Default" ENDINCLINATION="-368;-2533;" ID="Arrow_ID_575977434" SOURCE="ID_932507511" STARTARROW="None" STARTINCLINATION="1641;-256;"/>
|
|
<linktarget COLOR="#5f0ac8" DESTINATION="ID_329609486" ENDARROW="Default" ENDINCLINATION="219;-148;" ID="Arrow_ID_1101633958" SOURCE="ID_1009169288" STARTARROW="None" STARTINCLINATION="-315;0;"/>
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<node CREATED="1448669439582" HGAP="41" ID="ID_307071507" MODIFIED="1518487921087" TEXT="ad-hoc oder systematisch" VSHIFT="-2">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1448669512988" ID="ID_1184892495" MODIFIED="1518487921087" TEXT="fundamentale Frage"/>
|
|
<node CREATED="1448669517796" ID="ID_1165902172" MODIFIED="1518487921087" TEXT="für mich eigentlich sofort klar"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1448669527274" ID="ID_129855368" MODIFIED="1518487921087" TEXT="aber Vorsicht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1448669556607" ID="ID_493021007" MODIFIED="1518487921087" TEXT="das wird nie fertig...">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1448669562478" ID="ID_869338862" MODIFIED="1518487921087" TEXT="niemand wird es verstehen">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1448669567765" ID="ID_1254931544" MODIFIED="1518487921087" TEXT="bürstet die UI-Toolkits »gegen den Strich«"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448669636900" HGAP="51" ID="ID_1111001545" MODIFIED="1518487921087" TEXT="Einführen einer Zwischenebene" VSHIFT="-24">
|
|
<node CREATED="1448669646474" ID="ID_1590745326" MODIFIED="1518487921087" TEXT="hyper-räumliche Anordnung"/>
|
|
<node CREATED="1448669657633" ID="ID_1054403772" MODIFIED="1518487921087" TEXT="Focus-Bewegung"/>
|
|
<node CREATED="1448669662417" ID="ID_828883183" MODIFIED="1518487921087" TEXT="Einteilung in Arbeits-Räume"/>
|
|
<node CREATED="1448669679694" ID="ID_729190965" MODIFIED="1518487921087" TEXT="Konfigurierbarkeit"/>
|
|
<node CREATED="1448669675495" ID="ID_1257367197" MODIFIED="1518487921088" TEXT="Perspektiven"/>
|
|
<node CREATED="1448669699148" ID="ID_1264820517" MODIFIED="1518487921088" TEXT="Gesten"/>
|
|
</node>
|
|
<node CREATED="1448669742334" HGAP="41" ID="ID_1679641405" MODIFIED="1518487921088" TEXT="InteractionState" VSHIFT="-4">
|
|
<linktarget COLOR="#382ab9" DESTINATION="ID_1679641405" ENDARROW="Default" ENDINCLINATION="-962;-111;" ID="Arrow_ID_1636278357" SOURCE="ID_1765572056" STARTARROW="None" STARTINCLINATION="-502;101;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="13"/>
|
|
<node CREATED="1448669742334" FOLDED="true" HGAP="41" ID="ID_1690039650" MODIFIED="1618498433404" TEXT="Plan: InteractionStateManager" VSHIFT="-4">
|
|
<linktarget COLOR="#81759f" DESTINATION="ID_1690039650" ENDARROW="Default" ENDINCLINATION="513;-275;" ID="Arrow_ID_838588653" SOURCE="ID_839961131" STARTARROW="None" STARTINCLINATION="702;0;"/>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1448669816476" ID="ID_1895677880" MODIFIED="1518487921088" TEXT="lauscht als Observer mit"/>
|
|
<node CREATED="1448669824243" ID="ID_1225519733" MODIFIED="1518487921088" TEXT="hängt sich in diverse Punkte ein"/>
|
|
<node CREATED="1448669838745" ID="ID_1663939304" MODIFIED="1518487921088" TEXT="hällt ein lokales Zustansmodell"/>
|
|
<node CREATED="1448669854119" ID="ID_874080079" MODIFIED="1518487921088" TEXT="wertet Regeln aus"/>
|
|
<node CREATED="1448669869973" ID="ID_1259588429" MODIFIED="1518487921088" TEXT="sendet Enablement">
|
|
<node CREATED="1448669889514" ID="ID_1191247113" MODIFIED="1518487921088" TEXT="an die konkreten Trigger-Orte"/>
|
|
<node CREATED="1448669899113" ID="ID_990871123" MODIFIED="1518487921088" TEXT="er sendet jeweils die passende Command-ID"/>
|
|
</node>
|
|
<node CREATED="1618498269433" HGAP="14" ID="ID_1337185518" MODIFIED="1618498378416" VSHIFT="44">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Stand 2021</u>:
|
|
</p>
|
|
<p>
|
|
läuft ehr auf ein Framework hinaus,<br />denn auf eine zentrale Einrichtung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#c91d1d" STYLE="linear"/>
|
|
<linktarget COLOR="#cf4c6f" DESTINATION="ID_1337185518" ENDARROW="Default" ENDINCLINATION="306;59;" ID="Arrow_ID_1170485905" SOURCE="ID_379254820" STARTARROW="None" STARTINCLINATION="-233;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618493709187" FOLDED="true" ID="ID_1168598401" MODIFIED="1618495853582" TEXT="Komplexe zusammengesetze Interaktionen im Allgemeinen">
|
|
<linktarget COLOR="#436b85" DESTINATION="ID_1168598401" ENDARROW="Default" ENDINCLINATION="-1067;53;" ID="Arrow_ID_811903885" SOURCE="ID_1188739544" STARTARROW="None" STARTINCLINATION="325;54;"/>
|
|
<icon BUILTIN="edit"/>
|
|
<node CREATED="1618495879293" ID="ID_1360772859" MODIFIED="1618495885480" TEXT="systematisch-hierarchisch">
|
|
<node CREATED="1618496027489" ID="ID_433642660" MODIFIED="1618496038562" TEXT="Geten können zusammengesetzt sein"/>
|
|
<node CREATED="1618496039575" ID="ID_447958440" MODIFIED="1618496053097" TEXT="Gesten können aus verschiednen Interaktions-Systemen kommen">
|
|
<node CREATED="1618496175709" ID="ID_295780689" MODIFIED="1618496178440" TEXT="Beispiele">
|
|
<node CREATED="1618496180165" ID="ID_1445994046" MODIFIED="1618496198598" TEXT="mit der Maus ziehen bei gedrückten Modifier-Tasten"/>
|
|
<node CREATED="1618496199625" ID="ID_254053569" MODIFIED="1618496214248" TEXT="mit der Maus ziehen, nachdem ein Modus (per Tastenkombi) eingeleitet wurde"/>
|
|
<node CREATED="1618496228147" ID="ID_388393264" MODIFIED="1618496241259" TEXT="Hardware-Controller (linke Hand) + Maus (rechte Hand)"/>
|
|
</node>
|
|
<node CREATED="1618496287798" ID="ID_36219632" MODIFIED="1618496306375" TEXT="Maus + Tastatur wird sehr gut im UI-Toolkit unterstützt">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1618496307555" ID="ID_21337541" MODIFIED="1618496363210" TEXT="das ist tatsächlich ein Architektur-Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
weil es einer generischen Lösung im Weg steht
|
|
</li>
|
|
<li>
|
|
weil die partikuläre Ebene tief in das UI-Toolkit verwoben ist
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1618496370865" ID="ID_1338391945" MODIFIED="1618496636196" TEXT="Stichwort: GTK »grabbing widget«">
|
|
<arrowlink COLOR="#6578a3" DESTINATION="ID_1346101076" ENDARROW="Default" ENDINCLINATION="-2521;108;" ID="Arrow_ID_1579913575" STARTARROW="None" STARTINCLINATION="-4417;512;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618496053958" ID="ID_19157814" MODIFIED="1618496066054" TEXT="Gesten können mehrere Interaktionssysteme übergreifen">
|
|
<node CREATED="1618496071304" ID="ID_78497449" MODIFIED="1618496104797" TEXT="hierfür fehlt jedwede Basis">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1618496127068" ID="ID_1355352407" MODIFIED="1618496134433" TEXT="warum fällt das niemandem auf?"/>
|
|
<node CREATED="1618496135139" ID="ID_1442135716" MODIFIED="1618496162854">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Spaltung in <b>Pragmatismus</b> und <b>Vision</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618496079577" ID="ID_563221674" MODIFIED="1618496098344" TEXT="das heißt, man löst das »ad hoc«"/>
|
|
</node>
|
|
<node CREATED="1618496658035" ID="ID_135287349" MODIFIED="1618496668822" TEXT="Gesten können miteinander konkurrieren">
|
|
<node CREATED="1618496682104" ID="ID_1913068365" MODIFIED="1618496695090" TEXT="erst der Abschluß trifft die Entscheidung"/>
|
|
<node CREATED="1618496744993" ID="ID_1229062418" MODIFIED="1618496754547" TEXT="Problem: was passiert mit den unterlegenen Gesten"/>
|
|
<node CREATED="1618496755358" ID="ID_716551546" MODIFIED="1618498427806" TEXT="Lösungsansätze">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1618496761069" ID="ID_379254820" MODIFIED="1618498420683" TEXT="zentral">
|
|
<arrowlink COLOR="#cf4c6f" DESTINATION="ID_1337185518" ENDARROW="Default" ENDINCLINATION="306;59;" ID="Arrow_ID_1170485905" STARTARROW="None" STARTINCLINATION="-233;0;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1618496875438" ID="ID_1506165136" MODIFIED="1618496888277" TEXT="entspricht genau der Situation in einem LR-Parser"/>
|
|
<node CREATED="1618496888986" ID="ID_1950167576" MODIFIED="1618497035456" TEXT="läuft auf einen Table-driven-Approach hinaus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Auf theoretischer Ebene handel es sich um eine (nicht notwendigerweise deterministische) State-Machine. Allerdings ist diese sehr breit, und daher nicht sinnvoll direkt zu konstruieren. Wohingegen eine Tabellen-Implementierung aus Regeln dynamisch populiert werden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618498401639" ID="ID_507606816" MODIFIED="1618498415609" TEXT="nur sinnvoll bei einer geschlossenen Grammatik">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618496767069" ID="ID_1798540136" MODIFIED="1618498423780" TEXT="dezentral">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1618496774556" ID="ID_1999438460" MODIFIED="1618496815452" TEXT="paßt gut in bestehende UI-Toolkits">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GTK macht das auch in der Tat genau so
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618496819919" ID="ID_1097969614" MODIFIED="1618496835033" TEXT="es gibt dedizierte Gesten-Controller">
|
|
<node CREATED="1618497392949" ID="ID_88952849" MODIFIED="1618497404458" TEXT="jeder realisiert eine einzige Regel"/>
|
|
<node CREATED="1618497434424" ID="ID_1014765909" MODIFIED="1618497441669" TEXT="und feuert bei Abschluß"/>
|
|
<node CREATED="1618497485166" ID="ID_595584701" MODIFIED="1618497505049" TEXT="Konsequenz: "Rückmeldung" steht neben "Feuern"">
|
|
<node CREATED="1618497536204" ID="ID_1376398950" MODIFIED="1618497584286" TEXT="wird relevant wenn man Gesten wiederverwendet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Also eine generische Implementierung einer Gesten-Erkennung (z.B. dragging), welche dann durch Parametrisierung eingebunden wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618497591954" ID="ID_1424456420" MODIFIED="1618497607007" TEXT="wenn eine Geste aus Elementargesten zusammengesetzt wird"/>
|
|
<node CREATED="1618497615124" ID="ID_379280777" MODIFIED="1618497622069" TEXT="Stichwort: Multi-touch"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618497244266" ID="ID_1420529728" MODIFIED="1618497255222" TEXT="Konflikt wird ad hoc oder gar nicht gelöst">
|
|
<node CREATED="1618497261101" ID="ID_1256260657" MODIFIED="1618497268700" TEXT="entweder beide konkurrieren um ein Widget">
|
|
<node CREATED="1618497357042" ID="ID_1520371593" MODIFIED="1618497369234" TEXT="das fürhrt dann entweder zu einem Defekt"/>
|
|
<node CREATED="1618497369928" ID="ID_731581277" MODIFIED="1618497376382" TEXT="oder wird im Einzelfall gelöst"/>
|
|
</node>
|
|
<node CREATED="1618497269745" ID="ID_1183185638" MODIFIED="1618497294713" TEXT="und wenn nicht, kann die 2.Geste u.U. auch noch zum Zuge kommen"/>
|
|
<node CREATED="1618497299262" ID="ID_891092207" MODIFIED="1618497331892" TEXT=""wen das stört, der soll's es eben nicht so machen""/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618495906753" ID="ID_119188335" MODIFIED="1618495911709" TEXT="Konfigurierbarkeit">
|
|
<node CREATED="1618495927271" ID="ID_1746632538" MODIFIED="1618495993283" TEXT="mehrfach problematisch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1618495945349" ID="ID_920863702" MODIFIED="1618495955348" TEXT="Konfigurations-System muß verständlich sein"/>
|
|
<node CREATED="1618495958122" ID="ID_74493493" MODIFIED="1618495986674" TEXT="ist ein »cross-cutting Concern«"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1618498463806" HGAP="-1" ID="ID_420683622" MODIFIED="1618499095806" TEXT="Framework-Anforderungen" VSHIFT="13">
|
|
<arrowlink COLOR="#5c4052" DESTINATION="ID_1822212049" ENDARROW="Default" ENDINCLINATION="-834;0;" ID="Arrow_ID_1506237506" STARTARROW="None" STARTINCLINATION="112;439;"/>
|
|
<arrowlink COLOR="#5c4052" DESTINATION="ID_1267546019" ENDARROW="Default" ENDINCLINATION="-834;0;" ID="Arrow_ID_1826514843" STARTARROW="None" STARTINCLINATION="-58;-277;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1618498492515" ID="ID_434535661" MODIFIED="1618498499278" TEXT="wachstumsfähig und erweiterbar">
|
|
<node CREATED="1618498697295" ID="ID_985799133" MODIFIED="1618498710022" TEXT="die Grammatik bleibt auf Dauer offen"/>
|
|
</node>
|
|
<node CREATED="1618498500504" ID="ID_1449824942" MODIFIED="1618498513276" TEXT="nur relativ generische Bausteine">
|
|
<node CREATED="1618498677130" ID="ID_1157411868" MODIFIED="1618498680757" TEXT="Komposition"/>
|
|
<node CREATED="1618498683938" ID="ID_1253283120" MODIFIED="1618498686868" TEXT="Rückmeldung"/>
|
|
<node CREATED="1618498687576" ID="ID_1585243737" MODIFIED="1618498690994" TEXT="Konfigurierbarkeit"/>
|
|
</node>
|
|
<node CREATED="1618498580703" ID="ID_1269910425" MODIFIED="1618498648892" TEXT="konkrete Systembezüge an den Rand schieben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
also entweder auf den top-Level
|
|
</li>
|
|
<li>
|
|
oder auf die Blätter hinunter<br />
|
|
</li>
|
|
<li>
|
|
oder in Hilfskomponenten
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1618498735650" ID="ID_1694960381" MODIFIED="1618498748164" TEXT="einige Aspekte zentralisieren">
|
|
<node CREATED="1618498749104" ID="ID_1756775375" MODIFIED="1618498754793" TEXT="Namens-Schema"/>
|
|
<node CREATED="1618498755479" ID="ID_1965831950" MODIFIED="1618498759650" TEXT="Konfigurations-Service">
|
|
<node CREATED="1618498773365" ID="ID_855501540" MODIFIED="1618498780622" TEXT="im Besonderen: die Modifier"/>
|
|
<node CREATED="1618498781540" ID="ID_1040416937" MODIFIED="1618498794523" TEXT="in erster Näherung: Lambda vorsehen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487213803525" HGAP="36" ID="ID_735655054" MODIFIED="1518487921088" TEXT="InteractionDirector" VSHIFT="-3">
|
|
<arrowlink COLOR="#1b3863" DESTINATION="ID_362749694" ENDARROW="Default" ENDINCLINATION="-518;1012;" ID="Arrow_ID_959577029" STARTARROW="Default" STARTINCLINATION="-376;-568;"/>
|
|
<linktarget COLOR="#586d86" DESTINATION="ID_735655054" ENDARROW="Default" ENDINCLINATION="549;166;" ID="Arrow_ID_1031406920" SOURCE="ID_1980246174" STARTARROW="None" STARTINCLINATION="1;-366;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1487270206369" ID="ID_582649017" MODIFIED="1518487921088" TEXT="betreibt SpotLocator"/>
|
|
<node CREATED="1487275297855" ID="ID_417844993" MODIFIED="1518487921088" TEXT="betreibt FocusTracker"/>
|
|
<node CREATED="1487273437019" ID="ID_1600127727" MODIFIED="1518487921088" TEXT="betreibt Navigator"/>
|
|
</node>
|
|
<node CREATED="1487270226342" HGAP="32" ID="ID_1501993794" MODIFIED="1561827465627" TEXT="SpotLocator">
|
|
<node CREATED="1487270240084" ID="ID_1171094973" MODIFIED="1518487921088" TEXT="Erfüllungsgehilfe">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1487270245884" ID="ID_1688031043" MODIFIED="1518487921088" TEXT="zwei Aspekte">
|
|
<node CREATED="1487270262137" ID="ID_1256894684" MODIFIED="1518487921088" TEXT="Query">
|
|
<node CREATED="1487270288630" ID="ID_744259530" MODIFIED="1518487921088" TEXT=""wo sind wir"?"/>
|
|
<node CREATED="1487270294269" ID="ID_903348018" MODIFIED="1518487921088" TEXT="aktuelle WorkSite"/>
|
|
<node CREATED="1487270397967" ID="ID_1021036860" MODIFIED="1518487921088" TEXT="LRU history"/>
|
|
<node CREATED="1487270732305" ID="ID_702780522" MODIFIED="1518487921088" TEXT="current MediaObject"/>
|
|
</node>
|
|
<node CREATED="1487270263705" ID="ID_302637820" MODIFIED="1518487921088" TEXT="Act">
|
|
<node CREATED="1487270473421" ID="ID_911216598" MODIFIED="1518487921088" TEXT="go to FocusPath"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487270846218" ID="ID_419002057" MODIFIED="1561827465631" TEXT="WorkSite">
|
|
<node CREATED="1487270854793" ID="ID_1953389172" MODIFIED="1518487921088" TEXT="management">
|
|
<node CREATED="1487270860976" ID="ID_1497253556" MODIFIED="1518487921088" TEXT="Speicher">
|
|
<node CREATED="1487270865216" ID="ID_685718473" MODIFIED="1518487921088" TEXT="ref counted"/>
|
|
<node CREATED="1487270874103" ID="ID_1447761407" MODIFIED="1518487921088" TEXT="registration"/>
|
|
</node>
|
|
<node CREATED="1487270895587" ID="ID_167087353" MODIFIED="1518487921088" TEXT="established">
|
|
<node CREATED="1487270906322" ID="ID_1777452351" MODIFIED="1518487921088" TEXT="automatically"/>
|
|
<node CREATED="1487270909074" ID="ID_837195046" MODIFIED="1518487921088" TEXT="explicitly"/>
|
|
<node CREATED="1487270914353" ID="ID_810579522" MODIFIED="1518487921088" TEXT="derived">
|
|
<node CREATED="1487270924112" ID="ID_594873450" MODIFIED="1518487921088" TEXT="split"/>
|
|
<node CREATED="1487270926887" ID="ID_1400861012" MODIFIED="1518487921088" TEXT="clone"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487271257011" ID="ID_322579744" MODIFIED="1518487921088" TEXT="Bezugs-Rahmen">
|
|
<node CREATED="1487271264969" ID="ID_1714809239" MODIFIED="1518487921088" TEXT="Befehle/Aktionen binden"/>
|
|
<node CREATED="1487271279399" ID="ID_1349326625" MODIFIED="1518487921088" TEXT="Toolbar"/>
|
|
</node>
|
|
<node CREATED="1487272549027" ID="ID_380137967" MODIFIED="1518487921088" TEXT="Abgrenzung">
|
|
<node CREATED="1487272553075" ID="ID_743796483" MODIFIED="1518487921088" TEXT="schwierige Aufgabe"/>
|
|
<node CREATED="1487272557314" ID="ID_1783972929" MODIFIED="1518487921088" TEXT="muß dynamisch passieren"/>
|
|
<node CREATED="1487272580751" ID="ID_1313858813" MODIFIED="1518487921088" TEXT="verlassene WorkSites"/>
|
|
<node CREATED="1487273190221" ID="ID_1338036086" MODIFIED="1518487921088" TEXT="Genzen">
|
|
<node CREATED="1487273192636" ID="ID_1111226069" MODIFIED="1518487921088" TEXT="Dinge innerhalb"/>
|
|
<node CREATED="1487273196763" ID="ID_412767726" MODIFIED="1518487921088" TEXT="Dinge außerhalb"/>
|
|
<node CREATED="1487273226775" ID="ID_303777362" MODIFIED="1518487921088" TEXT="wann Grenzen anpassen"/>
|
|
</node>
|
|
<node CREATED="1487273234190" ID="ID_752073036" MODIFIED="1518487921088" TEXT="mehrere WorkSites">
|
|
<node CREATED="1487273239502" ID="ID_1735700195" MODIFIED="1518487921088" TEXT="können sich überlappen"/>
|
|
<node CREATED="1487273245421" ID="ID_1239635545" MODIFIED="1518487921088" TEXT="können naheliegen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487210642170" HGAP="28" ID="ID_337241818" MODIFIED="1518487921088" TEXT="Rahmen global" VSHIFT="-1">
|
|
<node CREATED="1487210648449" ID="ID_1430752735" MODIFIED="1535638478130" TEXT="konzeptionell">
|
|
<arrowlink COLOR="#34dbd3" DESTINATION="ID_1259700796" ENDARROW="Default" ENDINCLINATION="473;607;" ID="Arrow_ID_114106295" STARTARROW="None" STARTINCLINATION="-1346;-1090;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1487269963098" ID="ID_723170966" MODIFIED="1518487921088" TEXT="Raum als Metapher"/>
|
|
<node CREATED="1487269990582" ID="ID_164128588" MODIFIED="1518487921088">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Focus/Spot wird <i>mitbewegt</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487270008163" ID="ID_1916966167" MODIFIED="1518487921088" TEXT="operational">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1487270012283" ID="ID_212889115" MODIFIED="1518487921088" TEXT="noch unklar">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1487270108238" ID="ID_1957235452" MODIFIED="1518487921088" TEXT="Wechselwirkung: konventioneller Fokus"/>
|
|
<node CREATED="1487270131499" ID="ID_1523536395" MODIFIED="1518487921088" TEXT="Observer für Status-Änderungen"/>
|
|
<node CREATED="1487270141994" ID="ID_1312242119" MODIFIED="1518487921088" TEXT="Problem: wo andocken?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487272791578" ID="ID_1159463727" MODIFIED="1518487921088" TEXT="Strukturen">
|
|
<node CREATED="1487272794426" ID="ID_1016756623" MODIFIED="1518487921088" TEXT="transient"/>
|
|
<node CREATED="1487272797857" ID="ID_1810657142" MODIFIED="1518487921088" TEXT="persistent">
|
|
<node CREATED="1487273054439" ID="ID_185665950" MODIFIED="1518487921088" TEXT="Worksites bleiben dauerhaft erhalten"/>
|
|
<node CREATED="1487273061054" ID="ID_1347275006" MODIFIED="1518487921088" TEXT="werden im Modell gespeichert"/>
|
|
<node CREATED="1487273078564" ID="ID_1502695356" MODIFIED="1518487921088" TEXT="aber an den Benutzer gebunden"/>
|
|
</node>
|
|
<node CREATED="1487272800417" ID="ID_344309590" MODIFIED="1518487921088" TEXT="Wurzel">
|
|
<node CREATED="1487273308748" ID="ID_1980246174" MODIFIED="1518487921088" TEXT="Ankerpunkt: InteractionDirector">
|
|
<arrowlink COLOR="#586d86" DESTINATION="ID_735655054" ENDARROW="Default" ENDINCLINATION="549;166;" ID="Arrow_ID_1031406920" STARTARROW="None" STARTINCLINATION="1;-366;"/>
|
|
</node>
|
|
<node CREATED="1487273377603" ID="ID_1842094630" MODIFIED="1518487921088" TEXT="SpotLocator"/>
|
|
</node>
|
|
<node CREATED="1487272813119" ID="ID_1794274698" MODIFIED="1518487921088" TEXT="Bezug">
|
|
<node CREATED="1504460091831" ID="ID_150523428" MODIFIED="1575131533888" TEXT="Koordinatensystem">
|
|
<linktarget COLOR="#a9a5cd" DESTINATION="ID_150523428" ENDARROW="Default" ENDINCLINATION="1417;-3062;" ID="Arrow_ID_1485937133" SOURCE="ID_50865654" STARTARROW="None" STARTINCLINATION="1030;-46;"/>
|
|
<node CREATED="1504462869149" ID="ID_248419130" MODIFIED="1518487921088" TEXT="beschreibt Zugangsweg">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1504462874221" ID="ID_259258109" MODIFIED="1518487921088" TEXT="[optional] top-level Fenster"/>
|
|
<node CREATED="1504462888107" ID="ID_291187993" MODIFIED="1518487921088" TEXT="[optional] Perspektive"/>
|
|
<node CREATED="1504462891394" ID="ID_1569864275" MODIFIED="1518487921088" TEXT="Panel"/>
|
|
<node CREATED="1504463016698" ID="ID_337670154" MODIFIED="1518487921088" TEXT="lokal">
|
|
<node CREATED="1504463028384" ID="ID_604807253" MODIFIED="1518487921088" TEXT="View-ID"/>
|
|
<node CREATED="1504463020913" ID="ID_1114832380" MODIFIED="1518487921088" TEXT="[optional] Gruppe bzw. Tab"/>
|
|
<node CREATED="1504463067051" ID="ID_1393457815" MODIFIED="1518487921088" TEXT="Komponente/Komponente/Komponente..."/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1506956495003" ID="ID_364730867" MODIFIED="1518487921088" TEXT="konktete Topologie">
|
|
<node CREATED="1506956525336" ID="ID_344871464" MODIFIED="1518487921088" TEXT="stateful"/>
|
|
<node CREATED="1506956501474" ID="ID_905779000" MODIFIED="1518487921088" TEXT="zugänglich duch Navigator">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1515556878797" ID="ID_1322161446" MODIFIED="1518487921088" TEXT="Resolver mit path matching">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487273942038" HGAP="4" ID="ID_1254651309" MODIFIED="1561827465649" TEXT="Dynamik" VSHIFT="19">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<node CREATED="1487274013493" ID="ID_1949865241" MODIFIED="1518487921088" TEXT="mitbewegen">
|
|
<node CREATED="1487274017164" ID="ID_1079230717" MODIFIED="1518487921088" TEXT="Trigger">
|
|
<node CREATED="1487274021596" ID="ID_1455392363" MODIFIED="1518487921088" TEXT="Fenster wird aktiviert"/>
|
|
<node CREATED="1487274135596" ID="ID_1979220741" MODIFIED="1518487921088" TEXT="Keyboard-Focus shift"/>
|
|
<node CREATED="1487274145667" ID="ID_771196046" MODIFIED="1518487921088" TEXT="Selection gesetzt"/>
|
|
<node CREATED="1487274153058" ID="ID_624086875" MODIFIED="1518487921088" TEXT="Navigation expliizit"/>
|
|
</node>
|
|
<node CREATED="1487274921058" ID="ID_817413556" MODIFIED="1518487921088" TEXT="Ansatzpunkt">
|
|
<node CREATED="1487274932472" ID="ID_362677382" MODIFIED="1518487921088" TEXT="wie kann man Trigger installieren?"/>
|
|
<node CREATED="1487274942383" ID="ID_1727411524" MODIFIED="1518487921088" TEXT="model::Tangible">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1487274952662" ID="ID_137454278" MODIFIED="1518487921089" TEXT="immer?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1487274957301" ID="ID_1317780625" MODIFIED="1518487921089" TEXT="explizit?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487275149467" ID="ID_46033493" MODIFIED="1518487921089" TEXT="FocusListener"/>
|
|
</node>
|
|
<node CREATED="1487275167712" ID="ID_421642010" MODIFIED="1518487921089" TEXT="FocusTracker">
|
|
<node CREATED="1487275245822" ID="ID_1999993873" MODIFIED="1518487921089" TEXT="gehört zum InteractionDirector"/>
|
|
<node CREATED="1487275255092" ID="ID_528280403" MODIFIED="1518487921089" TEXT="muß von jedem Listener erreichbar sein"/>
|
|
<node CREATED="1487275265227" ID="ID_1738811487" MODIFIED="1518487921089" TEXT="wie setzt man einen neuen Listener auf?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1487275767543" ID="ID_1953432961" MODIFIED="1518487921089" TEXT="Idee: StateMark -> UI-Bus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1487275806658" ID="ID_46146913" MODIFIED="1518487921089" TEXT="CoreService <-> InteractionDirector">
|
|
<node CREATED="1487275821920" ID="ID_1911498338" MODIFIED="1518487921089" TEXT="Verbindung ohnehin notwendig"/>
|
|
<node CREATED="1487275829711" ID="ID_467014330" MODIFIED="1518487921089" TEXT="persistenter UI-State"/>
|
|
<node CREATED="1487275846133" ID="ID_1450222785" MODIFIED="1518487921089" TEXT="muß im Modell hängen"/>
|
|
<node CREATED="1487275854899" ID="ID_1437855457" MODIFIED="1518487921089" TEXT="und daher unter dem InteractionDirector"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487275415415" ID="ID_625776285" MODIFIED="1518487921089" TEXT="Bewegungs-Erkennung">
|
|
<node CREATED="1487275419726" ID="ID_379201934" MODIFIED="1518487921089" TEXT="ist ein Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1487275427165" ID="ID_196683293" MODIFIED="1518487921089" TEXT="was ist noch in einer WorkSite?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1487275438371" ID="ID_1849848193" MODIFIED="1518487921089" TEXT="wohin bewegen wir uns?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487275567114" ID="ID_1956672414" MODIFIED="1518487921089" TEXT="Zusammenarbeit">
|
|
<node CREATED="1487275572706" ID="ID_1943137650" MODIFIED="1518487921089" TEXT="WorkSite">
|
|
<node CREATED="1487275575665" ID="ID_406351009" MODIFIED="1518487921089" TEXT="weiß, was zu ihr gehört"/>
|
|
</node>
|
|
<node CREATED="1487275584048" ID="ID_1846202031" MODIFIED="1518487921089" TEXT="WorkSiteTrail">
|
|
<node CREATED="1487275591375" ID="ID_1854949126" MODIFIED="1518487921089" TEXT="verfolgt die WorkSites und ihre Dynamik"/>
|
|
</node>
|
|
<node CREATED="1487275601373" ID="ID_786512805" MODIFIED="1518487921089" TEXT="FocusTracker">
|
|
<node CREATED="1487275654958" ID="ID_874086704" MODIFIED="1518487921089" TEXT="verfolgt die Einzelelemente"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487277157451" ID="ID_434494653" MODIFIED="1518487921089" TEXT="Teil-Aufgaben">
|
|
<node CREATED="1487277161738" ID="ID_400737524" MODIFIED="1518487921089" TEXT="Verlassen einer WorkSite erkennen"/>
|
|
<node CREATED="1487277171617" ID="ID_566526238" MODIFIED="1518487921089" TEXT="Ankommen in einer bestehenden WorkSite erkennen"/>
|
|
<node CREATED="1487277190310" ID="ID_34185478" MODIFIED="1518487921089" TEXT="Notwendigkeit, eine neue WorkSite zu konstituieren erkennen"/>
|
|
</node>
|
|
<node CREATED="1487277244375" ID="ID_375270405" MODIFIED="1518487921089" TEXT="Ansatz">
|
|
<node CREATED="1487277246766" ID="ID_747328276" MODIFIED="1518487921089" TEXT="wer?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1487277261909" ID="ID_551475434" MODIFIED="1518487921089" TEXT="WorkSite">
|
|
<node CREATED="1487277266908" ID="ID_1718346792" MODIFIED="1518487921089" TEXT="könnte das Verlassen erkennen"/>
|
|
</node>
|
|
<node CREATED="1487277274251" ID="ID_1319104550" MODIFIED="1518487921089" TEXT="WorkSiteTrail"/>
|
|
<node CREATED="1487277281882" ID="ID_620509405" MODIFIED="1518487921089" TEXT="FocusTracker"/>
|
|
</node>
|
|
<node CREATED="1487277256149" ID="ID_339253853" MODIFIED="1518487921089" TEXT="wie?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1487277291305" ID="ID_1246038804" MODIFIED="1518487921089" TEXT="zentraler Tabellen-Lookup"/>
|
|
<node CREATED="1487277307374" ID="ID_335467287" MODIFIED="1518487921089" TEXT="lokalere Member-Tabelle"/>
|
|
<node CREATED="1487277317725" ID="ID_381402724" MODIFIED="1518487921089" TEXT="Reverse-Index"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1487277349233" ID="ID_1249868383" MODIFIED="1518487921089" TEXT="Resultat">
|
|
<node CREATED="1487277352856" ID="ID_587566118" MODIFIED="1518487921089" TEXT="alte WorkSite: verlassen"/>
|
|
<node CREATED="1487277375317" ID="ID_977859604" MODIFIED="1518487921089" TEXT="neue WorkSite: aktiviert"/>
|
|
<node CREATED="1487277384604" ID="ID_958245251" MODIFIED="1518487921089" TEXT="WorkSiteTrail: aktualisiert"/>
|
|
<node CREATED="1487277407425" ID="ID_1880710738" MODIFIED="1518487921089" TEXT="FocusPath: aktualisiert"/>
|
|
<node CREATED="1487277414744" ID="ID_1564254807" MODIFIED="1518487921089" TEXT="FocusLocator: hat sich bewegt"/>
|
|
<node CREATED="1487277448219" ID="ID_681470264" MODIFIED="1518487921089" TEXT="InteratcionStateManager: benachrichtigt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448070547667" FOLDED="true" HGAP="23" ID="ID_669457401" MODIFIED="1557498707235" TEXT="Bus-Terminal" VSHIFT="20">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1448070601165" ID="ID_1711137699" MODIFIED="1557498707235" TEXT="Methoden">
|
|
<node CREATED="1448407030239" ID="ID_619913132" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
act, note: Nachricht <i>upstream</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448407054900" ID="ID_1277028437" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mark: Nachricht <i>downstream</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448560729734" ID="ID_431928237" MODIFIED="1557498707235" TEXT="Nachricht mit Subjekt == indirekt, zur Weiterleitung"/>
|
|
<node CREATED="1448560744380" ID="ID_310914031" MODIFIED="1557498707235" TEXT="Nachricht ohne Subjekt == direkt, Subjekt implizit"/>
|
|
<node CREATED="1448560790558" ID="ID_1545911136" MODIFIED="1557498707235" TEXT="Bedeutung der Nachricht ergibt sich aus ihrem Namen"/>
|
|
</node>
|
|
<node CREATED="1448070605948" ID="ID_1779744719" MODIFIED="1557498707235" TEXT="Verhalten">
|
|
<node CREATED="1448407128826" ID="ID_1974801494" MODIFIED="1557498707235" TEXT="Bus-Master ist ein speziell implementiertes BusTerm"/>
|
|
<node CREATED="1448407139441" ID="ID_392543622" MODIFIED="1557498707235" TEXT="das gewöhnliche BusTerm ist einem Tangible zugeordnet"/>
|
|
<node CREATED="1448407187035" ID="ID_1622894914" MODIFIED="1557498707235" TEXT="sowie bus-seitig an ein "upstream" BusTerm"/>
|
|
</node>
|
|
<node CREATED="1448070618434" ID="ID_1925738380" MODIFIED="1557498707235" TEXT="Zuordnung">
|
|
<node CREATED="1448406963801" ID="ID_1506114314" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bus-Design is <b>selbstähnlich</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448406977350" ID="ID_1450959387" MODIFIED="1557498707235" TEXT="jedes BusTerm ist lediglich eine personalisierte Bus-Anbindung"/>
|
|
<node CREATED="1450390181806" ID="ID_61666430" MODIFIED="1557498707235" TEXT="es registriert beim Bus-Mater einen Link zum zugehörigen Tangible"/>
|
|
<node CREATED="1448406994860" ID="ID_846198635" MODIFIED="1557498707235">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Kennzeichen ist die <b>EntryID</b> des zugehörigen Elements
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128059966" ID="ID_823283341" MODIFIED="1557498707235" TEXT="Connect">
|
|
<node CREATED="1434128071126" FOLDED="true" HGAP="13" ID="ID_1618124128" MODIFIED="1561827465658" TEXT="UI-Bus" VSHIFT="11">
|
|
<linktarget COLOR="#3a8df0" DESTINATION="ID_1618124128" ENDARROW="Default" ENDINCLINATION="-25;-141;" ID="Arrow_ID_539627804" SOURCE="ID_257833497" STARTARROW="Default" STARTINCLINATION="-18;110;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1448548216556" ID="ID_1971609445" MODIFIED="1518487921089" TEXT="Topologie">
|
|
<node CREATED="1448548225659" ID="ID_807917172" MODIFIED="1518487921089" TEXT="upstream = zum Verteiler"/>
|
|
<node CREATED="1448548310247" ID="ID_993096699" MODIFIED="1518487921089" TEXT="downstream = zum Empfänger"/>
|
|
<node CREATED="1448560840239" ID="ID_1912018032" MODIFIED="1518487921089" TEXT="indirekt = zur Weiterleitung"/>
|
|
</node>
|
|
<node CREATED="1434128297445" ID="ID_1971555917" MODIFIED="1518487921089" TEXT="Nachrichtenformat">
|
|
<node CREATED="1448560865804" ID="ID_907456829" MODIFIED="1518487921089" TEXT="Klassifikation">
|
|
<node CREATED="1448548400308" ID="ID_1714197552" MODIFIED="1518487921089" TEXT="dedicated"/>
|
|
<node CREATED="1448548404475" ID="ID_1237647034" MODIFIED="1518487921089" TEXT="targetted"/>
|
|
<node CREATED="1448548407819" ID="ID_1923087300" MODIFIED="1518487921089" TEXT="flooding"/>
|
|
</node>
|
|
<node CREATED="1448560887081" ID="ID_1783786781" MODIFIED="1518487921089" TEXT="Addressierung">
|
|
<node CREATED="1448560891416" ID="ID_1603035591" MODIFIED="1518487921089" TEXT="per Subjekt"/>
|
|
<node CREATED="1448560896232" ID="ID_931223590" MODIFIED="1518487921089" TEXT="implizit"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128301525" ID="ID_187622243" MODIFIED="1518487921089" TEXT="Parallelität">
|
|
<node CREATED="1450390447884" ID="ID_1176145978" MODIFIED="1518487921090" TEXT="nicht Threadsafe"/>
|
|
<node CREATED="1450390454236" ID="ID_1617539841" MODIFIED="1518487921090" TEXT="läuft ausschließlich im Event-Thrad"/>
|
|
</node>
|
|
<node CREATED="1434128332277" ID="ID_33025591" MODIFIED="1561827465666" TEXT="Deregistrierung">
|
|
<node CREATED="1450390522393" ID="ID_1448879688" MODIFIED="1518487921090" TEXT="Uplink: implizit, hält Link zu einem Router"/>
|
|
<node CREATED="1450390559805" ID="ID_1657985065" MODIFIED="1518487921090" TEXT="Downlink:">
|
|
<node CREATED="1450390566252" ID="ID_591456555" MODIFIED="1518487921090" TEXT="registriert eine Route zu einem Tangible"/>
|
|
<node CREATED="1450390585329" ID="ID_1371255341" MODIFIED="1518487921090" TEXT="der dtor entfernt diese Route wieder"/>
|
|
</node>
|
|
<node COLOR="#7212f4" CREATED="1481413366826" FOLDED="true" HGAP="34" ID="ID_1180928280" MODIFIED="1518487921090" TEXT="problematisch im Shutdown" VSHIFT="5">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1481413410588" ID="ID_1106063275" MODIFIED="1518487921090" TEXT="Shutdown von Zombie-Nodes">
|
|
<node CREATED="1481413418027" ID="ID_998027739" MODIFIED="1518487921090" TEXT="reines Test-Problem"/>
|
|
<node CREATED="1481413421795" ID="ID_1335417806" MODIFIED="1518487921090" TEXT="gelöst durch self-link + tie break"/>
|
|
</node>
|
|
<node CREATED="1481413436529" ID="ID_195971284" MODIFIED="1518487921090" TEXT="Shutdown des CoreService">
|
|
<node CREATED="1481413462638" ID="ID_485427993" MODIFIED="1518487921090" TEXT="Problem: Backlink zum Nexus"/>
|
|
<node CREATED="1481413470268" ID="ID_688303898" MODIFIED="1576282358006" TEXT="Nexus ist zu dem Zeitpunkt schon destruiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Lösung für diese wecheslseitige Abhängigkeit
|
|
</p>
|
|
<p>
|
|
ist, den Nexus als Member im CoreService zu haben,
|
|
</p>
|
|
<p>
|
|
weil man dann seine Addresse schon weiß, bevor er erzeugt ist.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dummerweise rettet mich dieser Trick nicht im Shutdown,
|
|
</p>
|
|
<p>
|
|
denn hier nun läuft tatsächlicher Code aus dem Destruktor heraus!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481413489290" ID="ID_24882673" MODIFIED="1518487921090" TEXT="folglich läuft nur noch die Impl vom BusTerm"/>
|
|
<node CREATED="1481413520326" ID="ID_471345968" MODIFIED="1518487921090" TEXT="Endlosschleife (ping-pong)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1481414009877" ID="ID_269084554" MODIFIED="1518487921090" TEXT="...innerer Widerspruch">
|
|
<linktarget COLOR="#426895" DESTINATION="ID_269084554" ENDARROW="Default" ENDINCLINATION="36;87;" ID="Arrow_ID_708633830" SOURCE="ID_354799236" STARTARROW="None" STARTINCLINATION="369;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1481414032482" ID="ID_1121261163" MODIFIED="1518487921090" TEXT="upstream und nicht upstream"/>
|
|
<node CREATED="1481414149018" ID="ID_1708781872" MODIFIED="1576282358005" TEXT="kann Reihenfolge nicht etablieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bei einem <i>echten Downstream</i> könnte man dafür sorgen,
|
|
</p>
|
|
<p>
|
|
daß er grundsätzlich vor dem Nexus weggeht. Aber nun kommt, auf dem Umweg
|
|
</p>
|
|
<p>
|
|
über den Core-Service, der Nexus nach dem Nexus....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481414420406" ID="ID_559357688" MODIFIED="1518487921090" TEXT="erschwerend...">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1481414434148" ID="ID_333480677" MODIFIED="1518487921090" TEXT="BusTerm ist stateless"/>
|
|
<node CREATED="1481414477766" ID="ID_695637715" MODIFIED="1576282358005" TEXT="soll auch so bleiben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich will nicht damit anfangen, daß man einen Zeiger umsetzen kann....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481415983533" HGAP="37" ID="ID_1500277801" MODIFIED="1518487921090" TEXT="Trick löst beide" VSHIFT="6">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481415996732" ID="ID_98181285" MODIFIED="1518487921090" TEXT="ein "circuit breaker""/>
|
|
<node CREATED="1481416013842" ID="ID_1905276259" MODIFIED="1518487921090">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beendet Deregistrierung,
|
|
</p>
|
|
<p>
|
|
wenn ein BusTerm sich selbst deregistriert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1481416047509" ID="ID_1445652228" MODIFIED="1518487921090" TEXT="etwas halbseiden"/>
|
|
<node CREATED="1481416060843" ID="ID_354799236" MODIFIED="1518487921090" TEXT="aber... ein innerer Widerspruch liegt zugrunde">
|
|
<arrowlink COLOR="#426895" DESTINATION="ID_269084554" ENDARROW="Default" ENDINCLINATION="36;87;" ID="Arrow_ID_708633830" STARTARROW="None" STARTINCLINATION="369;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128310005" ID="ID_644247390" MODIFIED="1518487921090" TEXT="Knoten-ID">
|
|
<node CREATED="1450390501876" ID="ID_1750345192" MODIFIED="1518487921090" TEXT="ist die EntryID des Tangible"/>
|
|
<node CREATED="1450390512635" ID="ID_43739373" MODIFIED="1518487921090" TEXT="dient auch zum Routing"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1453546261390" FOLDED="true" HGAP="25" ID="ID_1996322416" MODIFIED="1679358500828" TEXT="Test" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1453546264638" ID="ID_975821244" MODIFIED="1518487921090" TEXT="Test-Nexus">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1453546268998" ID="ID_1692848170" MODIFIED="1576282358004" TEXT="Event-Log">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mechanismus, der es erlaubt
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
log-Nachrichten aus Mocks zu hinterlassen
|
|
</li>
|
|
<li>
|
|
in der Test-Fixture auf diese zu matchen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535815195338" ID="ID_1743938908" MODIFIED="1535815207849" TEXT="naive Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535815210288" ID="ID_1041148737" MODIFIED="1561827465667" TEXT="Problem: kein wirkliches Backtracking">
|
|
<linktarget COLOR="#80b3ba" DESTINATION="ID_1041148737" ENDARROW="Default" ENDINCLINATION="-1705;-7489;" ID="Arrow_ID_1257144480" SOURCE="ID_493114230" STARTARROW="None" STARTINCLINATION="838;114;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535835597691" ID="ID_218241863" MODIFIED="1576282358004" TEXT="wird relevant bei Richtungs-Wechsel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel:
|
|
</p>
|
|
<p>
|
|
a-b-c-a
|
|
</p>
|
|
<p>
|
|
match("a").after("b") scheitert, weil sich die Suche am ersten "a" festbeißt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1535835709996" ID="ID_239175550" MODIFIED="1535835723893" TEXT="wir brauchen zwingend eine Art Stack">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1535835843019" ID="ID_772926928" MODIFIED="1535836462411" TEXT="die Sequenz der Filter muß verfügbar bleiben"/>
|
|
<node CREATED="1535836509369" ID="ID_391734023" MODIFIED="1535836566669" TEXT="wenn eine Konfiguration erschöpft (leer) ist müssen wir..."/>
|
|
<node CREATED="1535836534934" ID="ID_371785386" MODIFIED="1535836558822" TEXT="auf dem nächsten Element der vorherigen Stufe neu aufsetezn"/>
|
|
</node>
|
|
<node CREATED="1535836610803" ID="ID_1351097381" MODIFIED="1535893429218" TEXT="das kommt mir bekannt vor...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1535836620898" ID="ID_1732889993" MODIFIED="1535836645399" TEXT="kann mein neuer Pipeline-Iter das?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1535893406156" ID="ID_451238053" MODIFIED="1535893422972" TEXT="Ja: er wurde exakt für solche Auswertungen konstruiert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535893431656" ID="ID_1626597975" MODIFIED="1537409091617" TEXT="Beschluß: umstellen auf TreeExplorer">
|
|
<arrowlink COLOR="#3eccac" DESTINATION="ID_1665477644" ENDARROW="Default" ENDINCLINATION="-4110;-2852;" ID="Arrow_ID_1163013232" STARTARROW="None" STARTINCLINATION="1631;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536441983485" ID="ID_330124350" MODIFIED="1576282358003" TEXT="Warnung: anonymous namespace">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist mir nicht völlig klar, warum das bei einigen Includes auftritt,
|
|
</p>
|
|
<p>
|
|
und bei anderen nicht. Beispiel
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
In file included from src/lib/diff/test-mutation-target.hpp:55:0,
|
|
</p>
|
|
<p>
|
|
                 from tests/library/diff/diff-complex-application-test.cpp:35:
|
|
</p>
|
|
<p>
|
|
src/lib/test/event-log.hpp:96:9: warning: 'lib::test::EventMatch' has a field 'lib::test::EventMatch::solution_' whose type uses the anonymous namespace [-Wsubobject-linkage]
|
|
</p>
|
|
<p>
|
|
   class EventMatch
|
|
</p>
|
|
<p>
|
|
         ^~~~~~~~~~
|
|
</p>
|
|
<p>
|
|
In file included from src/lib/diff/test-mutation-target.hpp:55:0,
|
|
</p>
|
|
<p>
|
|
                 from tests/library/diff/tree-mutator-binding-test.cpp:32:
|
|
</p>
|
|
<p>
|
|
src/lib/test/event-log.hpp:96:9: warning: 'lib::test::EventMatch' has a field 'lib::test::EventMatch::solution_' whose type uses the anonymous namespace [-Wsubobject-linkage]
|
|
</p>
|
|
<p>
|
|
   class EventMatch
|
|
</p>
|
|
<p>
|
|
         ^~~~~~~~~~
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485548830035" FOLDED="true" HGAP="5" ID="ID_1295711115" MODIFIED="1518487921090" TEXT="Nutzen" VSHIFT="17">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1485548856639" ID="ID_1677281474" MODIFIED="1518487921090" TEXT="spezifische Aktionen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1485548894522" ID="ID_826011549" MODIFIED="1576282358002" TEXT="Problem: globale Aktionen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel: Aktionen, die im globalen Menü stehen.
|
|
</p>
|
|
<p>
|
|
"Add Sequence"
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wer bildet daraus ein Command?
|
|
</li>
|
|
<li>
|
|
auf welchen Kontext bezieht sich das
|
|
</li>
|
|
<li>
|
|
wen kann die Menü-Registrierung konkret ansprechen (Verdrahtung ist statisch)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#824f68" DESTINATION="ID_826011549" ENDARROW="Default" ENDINCLINATION="-872;-1178;" ID="Arrow_ID_1373278707" SOURCE="ID_1122969153" STARTARROW="Default" STARTINCLINATION="911;271;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1485555902731" ID="ID_1913236669" MODIFIED="1518487921090" TEXT="#1070 how to bind session commands into UI actions">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1486767998242" ID="ID_1898269374" MODIFIED="1518487921090" TEXT="InteractionDirector verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492444328031" ID="ID_1628732201" MODIFIED="1518487921090" TEXT="muß im Lauf der Zeit wachsen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502452724107" ID="ID_689474303" MODIFIED="1518487921090" TEXT="Mutationen">
|
|
<node CREATED="1502452771285" ID="ID_1091994004" MODIFIED="1518487921090" TEXT="Diff-Format">
|
|
<arrowlink COLOR="#a9acc1" DESTINATION="ID_143203937" ENDARROW="Default" ENDINCLINATION="115;-2033;" ID="Arrow_ID_136706418" STARTARROW="None" STARTINCLINATION="1656;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1502452875447" ID="ID_1363153586" MODIFIED="1576203487696" TEXT="MutationMessage">
|
|
<linktarget COLOR="#a7afc1" DESTINATION="ID_1363153586" ENDARROW="Default" ENDINCLINATION="931;-187;" ID="Arrow_ID_324877454" SOURCE="ID_336806935" STARTARROW="Default" STARTINCLINATION="835;592;"/>
|
|
<node CREATED="1502452903075" ID="ID_726723452" MODIFIED="1518487921090" TEXT="abstrahierter Iterator">
|
|
<node CREATED="1502453110640" ID="ID_1024081141" MODIFIED="1518487921090" TEXT="IterSource-Interface"/>
|
|
<node CREATED="1502453116327" ID="ID_1762714186" MODIFIED="1518487921090" TEXT="opaque generaction context"/>
|
|
<node CREATED="1502453128198" ID="ID_1311188906" MODIFIED="1518487921090" TEXT="per smart-ptr gehalten"/>
|
|
</node>
|
|
<node CREATED="1502452909091" ID="ID_638887155" MODIFIED="1518487921090" TEXT="nur einmal konsumierbar"/>
|
|
<node CREATED="1502452913906" ID="ID_1500100371" MODIFIED="1518487921090" TEXT="Framework zur Hanhabung">
|
|
<arrowlink COLOR="#afb1bd" DESTINATION="ID_1651893758" ENDARROW="Default" ENDINCLINATION="-1257;0;" ID="Arrow_ID_1786455458" STARTARROW="None" STARTINCLINATION="1858;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1485548866990" ID="ID_664933854" MODIFIED="1518487921090" TEXT="Commands"/>
|
|
<node CREATED="1485548878292" ID="ID_49934573" MODIFIED="1518487921090" TEXT="Broadcast"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1453545812389" FOLDED="true" HGAP="43" ID="ID_202253849" MODIFIED="1576282358002" TEXT="Core-Services" VSHIFT="2">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
konzeptionell: fertig
|
|
</p>
|
|
<p>
|
|
Implementierung der real-world-Variante fehlt!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_1343270939" ENDARROW="Default" ENDINCLINATION="-197;638;" ID="Arrow_ID_1686519160" STARTARROW="Default" STARTINCLINATION="-83;-1020;"/>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1453545875627" ID="ID_1411740156" MODIFIED="1576282358001" TEXT="Definition »Zentral-Dienste«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dienste im UI, erreichbar über den Bus.
|
|
</p>
|
|
<p>
|
|
Sie stellen die Verbindung zu zentralen Belangen her
|
|
</p>
|
|
<p>
|
|
wie Session- und State-Managment, Commands etc.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1453545968166" ID="ID_399884859" MODIFIED="1561827465670" TEXT="Command-Handler">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1453546129537" FOLDED="true" ID="ID_1926242869" MODIFIED="1518487921090" TEXT="empfängt "act"-Nachrichten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1453546381255" ID="ID_1252400934" MODIFIED="1518487921090" TEXT=""bind" -> Bindung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1453546393573" ID="ID_857178151" MODIFIED="1518487921090" TEXT="Paradigmen-Mismatch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1453546417098" ID="ID_676713402" MODIFIED="1518487921090" TEXT="DOM vs. compiletime typing">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1453546436455" ID="ID_129001401" MODIFIED="1561827465674" TEXT="double-dispatch">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1453546450317" ID="ID_1899026394" MODIFIED="1512926192213" TEXT="Variant-Visitor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1453546485737" ID="ID_491338311" MODIFIED="1453546493300" TEXT="Gen-Node-Typen"/>
|
|
<node CREATED="1453546493719" ID="ID_834270776" MODIFIED="1453546496947" TEXT="fest vorgegeben"/>
|
|
</node>
|
|
<node CREATED="1453546454484" ID="ID_1643300093" MODIFIED="1453590507167" TEXT="Trampolin">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1453546512277" ID="ID_968193365" MODIFIED="1453590559627" TEXT="Aufruf: generische Iteration">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1453590522161" ID="ID_1369411965" MODIFIED="1512926192215" TEXT="Problem: narrowing conversions">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1453590585865" ID="ID_350595711" MODIFIED="1453590606670" TEXT="explizit gefährliche ausschließen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1453638973049" ID="ID_1350801390" LINK="https://gcc.gnu.org/bugzilla/show_bug.cgi?id=63723" MODIFIED="1453639023645">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Compiler-Bug <font color="#c80219">Gcc-#63723</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1453639033250" ID="ID_1669831951" LINK="http://stackoverflow.com/questions/26705199/how-can-i-write-a-type-trait-to-check-if-a-type-is-convertible-to-another-by-a-n" MODIFIED="1453639049952" TEXT="s.a. Stackoverflow"/>
|
|
<node CREATED="1453639055478" ID="ID_1560466275" MODIFIED="1453639078468">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gelöst in GCC-5 -- <i>backport unwahrscheinlich</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1453639119142" ID="ID_1472487058" MODIFIED="1453639126177" TEXT="inzwischen hartgecodet">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453546467707" ID="ID_1543497504" MODIFIED="1512926192216" TEXT="Problem: template bloat">
|
|
<node CREATED="1453590622236" ID="ID_1084684065" MODIFIED="1512926192217" TEXT="hält sich in Grenzen">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1453590828976" ID="ID_659078492" MODIFIED="1453590855465" TEXT="eine VTable pro Zieltyp"/>
|
|
<node CREATED="1453590856220" ID="ID_376478329" MODIFIED="1453590879683">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eine virtuelle Funktion
|
|
</p>
|
|
<p>
|
|
pro möglichem Umwandlungs-Pfad
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453590628419" ID="ID_1314031268" MODIFIED="1453590885601">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir verwenden die Basis-VTable
|
|
</p>
|
|
<p>
|
|
und layern nur die tatsächlich möglichen Umwandlungen drüber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1453590667630" ID="ID_792450888" MODIFIED="1453590699782" TEXT="überprüft: mit -O3 und strip bleibt erstaunlich wenig übrig"/>
|
|
<node CREATED="1453590741428" ID="ID_1733557933" MODIFIED="1453590749327" TEXT="1.6MiB -> 100k"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453546367201" ID="ID_1473684366" MODIFIED="1518487921090" TEXT=""bang" -> HandlingPattern">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492205728949" ID="ID_730154835" MODIFIED="1518487921090" TEXT="abgeschafft"/>
|
|
<node CREATED="1492205732389" ID="ID_1080697951" MODIFIED="1518487921090" TEXT="wir können stets gleich triggern"/>
|
|
</node>
|
|
<node CREATED="1492205741483" ID="ID_1132272888" MODIFIED="1518487921090" TEXT="Command wird sofort nach dem Binden getriggert"/>
|
|
<node COLOR="#338800" CREATED="1483925280108" HGAP="30" ID="ID_1479669922" MODIFIED="1582487520669" TEXT="Protokoll-Erweiterung" VSHIFT="8">
|
|
<arrowlink COLOR="#8ba05e" DESTINATION="ID_242219866" ENDARROW="Default" ENDINCLINATION="1170;1204;" ID="Arrow_ID_1617518648" STARTARROW="None" STARTINCLINATION="3617;-1097;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483925298713" ID="ID_347702585" MODIFIED="1518487921090" TEXT="Command-Prototyp forken"/>
|
|
<node CREATED="1483925307385" ID="ID_509982277" MODIFIED="1518487921090" TEXT="ID durch Kontext-ID dekorieren"/>
|
|
<node CREATED="1483925311624" ID="ID_1592410347" MODIFIED="1518487921090" TEXT="Anforderung vom InvocationStateManager"/>
|
|
<node CREATED="1483925338796" ID="ID_348930186" MODIFIED="1518487921090" TEXT="implementiert in SessionCommandService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453546138215" ID="ID_621186206" MODIFIED="1518487921090" TEXT="Verbindung zum ProcDispatcher">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483927603312" ID="ID_1803909975" MODIFIED="1518487921090" TEXT="Aufruf der SessionCommand facade">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483927624157" ID="ID_86978128" MODIFIED="1518487921090" TEXT="in CommandHandler gepackt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1483927637022" ID="ID_455471953" MODIFIED="1518487921090" TEXT="total einfach hier">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453546183561" ID="ID_1080090125" MODIFIED="1518487921090" TEXT="Mock-Variante">
|
|
<node CREATED="1453546195240" ID="ID_1905175534" MODIFIED="1518487921090" TEXT="loggen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1453546197727" ID="ID_606855270" MODIFIED="1518487921090" TEXT="verifizierbar machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1453546215117" ID="ID_31965862" MODIFIED="1518487921090" TEXT="pseudo-Command">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483927678318" HGAP="25" ID="ID_1324099152" MODIFIED="1561827465674" TEXT="Notification-Facade öffnen" VSHIFT="4">
|
|
<arrowlink COLOR="#51517b" DESTINATION="ID_379585622" ENDARROW="Default" ENDINCLINATION="-476;439;" ID="Arrow_ID_1616528570" STARTARROW="Default" STARTINCLINATION="-541;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1483927692988" ID="ID_354422174" MODIFIED="1538263617013" TEXT="Lebenszyklus-Fragen verifizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483927735679" ID="ID_783490676" MODIFIED="1538263622227" TEXT="Integration in UI-Main verifizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1483927710450" ID="ID_1085939201" MODIFIED="1522935005617" TEXT="Hochfahren des UI / Schließen des UI">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1515977616903" ID="ID_1098045534" MODIFIED="1538263666187" TEXT="(vorläufig) einfaches Fehler-Display">
|
|
<arrowlink COLOR="#ebf0a5" DESTINATION="ID_1007296291" ENDARROW="Default" ENDINCLINATION="-3154;1704;" ID="Arrow_ID_1091720734" STARTARROW="None" STARTINCLINATION="1220;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1501778430101" ID="ID_489078622" MODIFIED="1561827465675" TEXT="#1098 hand-over to UI thread">
|
|
<arrowlink COLOR="#7caaa8" DESTINATION="ID_1023343635" ENDARROW="Default" ENDINCLINATION="2513;3565;" ID="Arrow_ID_1832047032" STARTARROW="Default" STARTINCLINATION="2914;51;"/>
|
|
<linktarget COLOR="#6c5f80" DESTINATION="ID_489078622" ENDARROW="Default" ENDINCLINATION="712;-47;" ID="Arrow_ID_485145709" SOURCE="ID_31825421" STARTARROW="None" STARTINCLINATION="1538;-37;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1531583488816" ID="ID_626261980" MODIFIED="1531583585348" TEXT="Dispatcher">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1531583492656" ID="ID_1958336253" MODIFIED="1531583586580" TEXT="Queue mit explizitem Mutex-Locking">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1531583503318" ID="ID_1398440490" MODIFIED="1531583587884" TEXT="UI-Thread signalisieren per Gtk::Dispatcher">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1453546083296" ID="ID_1154674875" MODIFIED="1561827465677" TEXT="Presentation-State-Manager">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1455290707481" ID="ID_551153117" MODIFIED="1518487921091">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
empfängt alle <b>state mark notificatons</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455290726358" ID="ID_386120755" MODIFIED="1518487921091" TEXT="muß gruppieren">
|
|
<node CREATED="1455290732805" ID="ID_1731455164" MODIFIED="1518487921091" TEXT="nach Ui-Element"/>
|
|
<node CREATED="1455290738044" ID="ID_1309710182" MODIFIED="1518487921091" TEXT="nach property innerhalb"/>
|
|
</node>
|
|
<node CREATED="1455290748539" ID="ID_504317246" MODIFIED="1518487921091" TEXT="zeichnet jeweils den letzten aktuellen Zustand auf">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1455290768888" ID="ID_1779151953" MODIFIED="1518487921091" TEXT="Wechselwirkungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1455290773936" ID="ID_533210684" MODIFIED="1518487921091" TEXT="geplant, absehbar">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1455290807459" ID="ID_1222290895" MODIFIED="1518487921091" TEXT="muß Auszüge aus dieser Info schaffen"/>
|
|
<node CREATED="1455290827193" ID="ID_1429808095" MODIFIED="1518487921091">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nach <b>Perspektive</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455290833048" ID="ID_1650274766" MODIFIED="1518487921091">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nach <b>work site</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1455290849374" ID="ID_906623432" MODIFIED="1518487921091" TEXT="future work">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672534372" FOLDED="true" HGAP="78" ID="ID_1920838120" MODIFIED="1561827465685" TEXT="core commands" VSHIFT="21">
|
|
<icon BUILTIN="prepare"/>
|
|
<node CREATED="1488672580926" ID="ID_1920974710" MODIFIED="1518487921091" TEXT="konzeptionell">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1488672621585" ID="ID_1461875887" MODIFIED="1679362063079" TEXT="Command-cycle">
|
|
<linktarget COLOR="#706a9a" DESTINATION="ID_1461875887" ENDARROW="Default" ENDINCLINATION="-923;-789;" ID="Arrow_ID_457540370" SOURCE="ID_969011841" STARTARROW="None" STARTINCLINATION="867;304;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1488672838499" ID="ID_1617972329" MODIFIED="1518487921091" TEXT="Interaktionen">
|
|
<node CREATED="1492442637686" ID="ID_1148014554" MODIFIED="1518487921091" TEXT="brauche Command-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492442643942" ID="ID_184523090" MODIFIED="1518487921091" TEXT="muß grundsätzlich bekannt sein"/>
|
|
<node CREATED="1492442652612" ID="ID_1774585291" MODIFIED="1518487921091" TEXT="ggfs fest definierte Konstante"/>
|
|
<node CREATED="1492442665858" ID="ID_48986283" MODIFIED="1518487921091" TEXT="definiert in proc/cmd.hpp">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492442694199" ID="ID_502474813" MODIFIED="1518487921091" TEXT="CommandSetup">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1492442659060" ID="ID_707740928" MODIFIED="1518487921091" TEXT="lib::Symbol">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672957922" ID="ID_329010871" MODIFIED="1518487921091" TEXT="brauche InteractionStateManager">
|
|
<arrowlink COLOR="#5a80c1" DESTINATION="ID_121485208" ENDARROW="Default" ENDINCLINATION="9;-164;" ID="Arrow_ID_17404383" STARTARROW="None" STARTINCLINATION="1;52;"/>
|
|
<node CREATED="1488676089349" ID="ID_1584585045" MODIFIED="1518487921091" TEXT="Anfrage ...für ein bestimmes Command"/>
|
|
<node CREATED="1488676629451" ID="ID_989334768" MODIFIED="1518487921091" TEXT="Problem: wie findet man den Zuständigen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1488676134951" ID="ID_1426727929" MODIFIED="1518487921091" TEXT="N : M">
|
|
<node CREATED="1488676119929" ID="ID_70646733" MODIFIED="1518487921091">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
einer könnte für
|
|
</p>
|
|
<p>
|
|
mehrere Commands zuständig sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1488676210948" ID="ID_1003704499" MODIFIED="1518487921091" TEXT="verschiedene Ausprägungen"/>
|
|
<node CREATED="1488676230802" ID="ID_1711345566" MODIFIED="1518487921091" TEXT="generische Situation"/>
|
|
</node>
|
|
<node CREATED="1488676179840" ID="ID_1207866065" MODIFIED="1518487921091">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mehrere könnten für
|
|
</p>
|
|
<p>
|
|
ein Command zuständig sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1488676238120" ID="ID_62079120" MODIFIED="1518487921091" TEXT="da an ein Control/Interface-System gebunden"/>
|
|
<node CREATED="1488676280459" ID="ID_800780235" MODIFIED="1576282358001" TEXT="ist vermutlich keine gute Idee">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....denn wir wollen ja grade
|
|
</p>
|
|
<p>
|
|
den Widget-Code vom Control-System abstrahieren
|
|
</p>
|
|
<p>
|
|
und ebenso die Gesten abstrahieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1488676343170" ID="ID_1624806724" MODIFIED="1518487921091" TEXT="besser? InteractionStateManager == Geste">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488674244218" ID="ID_121485208" MODIFIED="1518487921091" TEXT="Aktivitäten">
|
|
<linktarget COLOR="#5a80c1" DESTINATION="ID_121485208" ENDARROW="Default" ENDINCLINATION="9;-164;" ID="Arrow_ID_17404383" SOURCE="ID_329010871" STARTARROW="None" STARTINCLINATION="1;52;"/>
|
|
<node COLOR="#338800" CREATED="1488674249665" ID="ID_1028887910" MODIFIED="1518487921091" TEXT="Command-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488674520524" ID="ID_895059689" MODIFIED="1518487921091" TEXT="Prototyp-Pattern">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1488674528035" ID="ID_1084922722" MODIFIED="1576282358000">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>muß</i> Instanzen einsetzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar zwingend, sobald
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
das command Argumente hat, die gebunden sein wollen
|
|
</li>
|
|
<li>
|
|
mehrere Invocations des gleichen Grund-Commands "gleichzeitig" unterwegs sein könnten
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1488674659521" FOLDED="true" ID="ID_1283697108" MODIFIED="1561827465687" TEXT="Problem: Instanz-Management">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1488674675895" ID="ID_1414738474" MODIFIED="1518487921091" TEXT="benannt oder anonyom">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1488674682869" ID="ID_1865712804" MODIFIED="1518487921091" TEXT="anonym == ref counted">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1488674692293" ID="ID_1154381764" MODIFIED="1518487921091" TEXT="bindet uns an Proc">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1488674807716" ID="ID_1220416942" MODIFIED="1518487921091" TEXT="ist das ein Problem?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1488674815867" ID="ID_417989611" MODIFIED="1576282357999" TEXT="eigentlich nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...vom Linken her nicht, da wir Gui gegen Proc linken
|
|
</p>
|
|
<p>
|
|
vom Bauen auch nicht, und außerdem...
|
|
</p>
|
|
<p>
|
|
...coden wir ja nicht gegen die Implementierung,
|
|
</p>
|
|
<p>
|
|
sondern gegen eine Abstraction (Command), die eigens dafür geschaffen wurde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1488674905160" ID="ID_1688143285" MODIFIED="1518487921091" TEXT="ungutes Gefühl">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1488674941243" ID="ID_1628081916" MODIFIED="1518487921091" TEXT="unterläuft das Interface-System"/>
|
|
<node CREATED="1488675139160" ID="ID_1466153465" MODIFIED="1518487921091" TEXT="unterläuft das Messaging / UI-Bus"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488674721265" ID="ID_1409487095" MODIFIED="1518487921091" TEXT="aber: benannte Instanzen leben einfach weiter">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1488677059648" ID="ID_1869818470" MODIFIED="1518487921091" TEXT="war eigentlich nur für "Spezialisierungen" gedacht"/>
|
|
<node CREATED="1488936223175" ID="ID_1105962999" MODIFIED="1518487921091" TEXT="zu prüfen: overhead">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1488936242413" ID="ID_1255236132" MODIFIED="1518487921091" TEXT="könnte eigener, dritter Typus werden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488936634128" ID="ID_857930488" MODIFIED="1518487921091" TEXT="Konsequenz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488936638247" ID="ID_699367403" MODIFIED="1518487921091" TEXT="man sollte auf das Bauchgefühl hören"/>
|
|
<node CREATED="1488936653341" ID="ID_629143054" MODIFIED="1518487921091" TEXT="Design leitet in richtige Bahnen"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1488936670970" ID="ID_697148715" MODIFIED="1613941754293" TEXT="die Trennung respektieren">
|
|
<arrowlink COLOR="#79d2c4" DESTINATION="ID_1131387570" ENDARROW="Default" ENDINCLINATION="-70;-129;" ID="Arrow_ID_1598234794" STARTARROW="None" STARTINCLINATION="-500;47;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488675785223" FOLDED="true" ID="ID_134788782" MODIFIED="1561827465692" TEXT="Lösung schaffen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1488675788278" ID="ID_241828684" MODIFIED="1518487921091" TEXT="wer erzeugt die Instanz?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488676735628" ID="ID_845338567" MODIFIED="1518487921091" TEXT="der InteractionStateManager">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1488676746667" ID="ID_1675443482" MODIFIED="1518487921091" TEXT="jemand in Proc">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488936425628" ID="ID_273815265" MODIFIED="1518487921092" TEXT="neue Entität"/>
|
|
<node CREATED="1488936429139" ID="ID_858892843" MODIFIED="1518487921092" TEXT="gehört zum Command-System"/>
|
|
<node COLOR="#435e98" CREATED="1512926192223" ID="ID_283015913" MODIFIED="1613941797180" TEXT="CommandInstanceManager">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488675795485" ID="ID_560742641" MODIFIED="1518487921092" TEXT="wer benennt die Instanz?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1488676790165" ID="ID_450420022" MODIFIED="1518487921092" TEXT="der der sie erzeugt">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1488676796892" ID="ID_399980219" MODIFIED="1518487921092" TEXT="ein Benennungs-Service in Proc">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1488676805491" ID="ID_1995019439" MODIFIED="1518487921092" TEXT="ein Instanz-Pool">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488675800668" ID="ID_260870361" MODIFIED="1561827465694" TEXT="wer hält die Instanz (am Leben)?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488676827432" ID="ID_1354771185" MODIFIED="1576282357999" TEXT="Problem: air-Gap">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wegen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Command-Message via UI-Bus
|
|
</li>
|
|
<li>
|
|
Durchreichen durch das Interface-System
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1488677586744" ID="ID_1077384395" MODIFIED="1488677612409" TEXT="AUA: Zwang zum Benennen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488676941240" ID="ID_403164604" MODIFIED="1576282357998" TEXT="im Proc-Dispatcher kein Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da die DispatcherQueue direkt Command-Objekte (=frontend handle) speichert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1488677212907" ID="ID_1525612446" MODIFIED="1488936784410" TEXT="Idee: im InteractionStateManager">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1488677232640" ID="ID_1033002023" MODIFIED="1488677274454" TEXT="null oder maximal eine pro Command"/>
|
|
<node CREATED="1488677258932" ID="ID_1695115228" MODIFIED="1488677268487" TEXT="andere Geste -> andere Command-Instanz"/>
|
|
<node COLOR="#c15a5d" CREATED="1488677333066" ID="ID_182292267" MODIFIED="1488677344667" TEXT="Aber">
|
|
<node CREATED="1488677346473" ID="ID_712110821" MODIFIED="1488677350100" TEXT="air-Gap"/>
|
|
<node CREATED="1488677350640" ID="ID_901346570" MODIFIED="1488677370377" TEXT="Ausführung im Dispatcher erst später"/>
|
|
<node COLOR="#338800" CREATED="1488677418087" ID="ID_644949863" MODIFIED="1576282357998" TEXT="ist doch kein Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn das GUI läuft ja synchron.
|
|
</p>
|
|
<p>
|
|
D.h. wir wissen, wenn wir das Air-Gap überstanden haben.
|
|
</p>
|
|
<p>
|
|
Ab diesem Punkt hält der Eintrag in der DispatcherQueue das Command am Leben,
|
|
</p>
|
|
<p>
|
|
und wenn es stirbt, dann stirbt es halt...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488936070394" ID="ID_1131387570" MODIFIED="1488936736607" TEXT="Schlußfolgerung">
|
|
<linktarget COLOR="#79d2c4" DESTINATION="ID_1131387570" ENDARROW="Default" ENDINCLINATION="-70;-129;" ID="Arrow_ID_1598234794" SOURCE="ID_697148715" STARTARROW="None" STARTINCLINATION="-500;47;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1488936102272" ID="ID_414025307" MODIFIED="1488936125740" TEXT="eigenes Instantiierungs-Protokoll">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1488936115534" ID="ID_1508575123" MODIFIED="1488936128074" TEXT="explizit in Proc zu unterstützen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492443899058" ID="ID_1465290437" MODIFIED="1512926192223" TEXT="CommandInstanceManager">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492443908344" ID="ID_499675523" MODIFIED="1492443916643" TEXT="lebt in SessionCommandService"/>
|
|
<node CREATED="1492443917423" ID="ID_1829369544" MODIFIED="1492443926330" TEXT="an ProcDispatcher-Loop gebunden"/>
|
|
<node CREATED="1492443926806" ID="ID_1117512587" MODIFIED="1492443933129" TEXT="lebt und stirbt mit der Session"/>
|
|
<node CREATED="1492443933813" ID="ID_1185852649" MODIFIED="1492443940760" TEXT="hat eigene lokale Hashtable"/>
|
|
<node CREATED="1492443941260" ID="ID_870719620" MODIFIED="1576282357997" TEXT="unterstützt einfachen Fallback">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aufruf direkt mit Command-ID -> erzeugt automatisch eine Klon-Kopie
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488936129180" ID="ID_62638556" MODIFIED="1488936137127" TEXT="hand-over">
|
|
<node CREATED="1488936140275" ID="ID_61978297" MODIFIED="1488936152237" TEXT="entfernt Registrierung"/>
|
|
<node CREATED="1488936152849" ID="ID_525023498" MODIFIED="1488936164963" TEXT="erzeugt anonyme Instanz"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1488936910756" HGAP="200" ID="ID_208733336" MODIFIED="1538871084006" TEXT="neues Design" VSHIFT="14">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1488937072267" ID="ID_1765750778" MODIFIED="1488937082039" TEXT="separation of concerns">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1488936925448" ID="ID_1949523361" MODIFIED="1488937085712" TEXT="zwei neue Entitäten">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1488936938742" ID="ID_1388901840" MODIFIED="1488939645006">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GUI: <b>CmdAccessor</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1488936962690" ID="ID_399848637" MODIFIED="1488936995228" TEXT="vermittelt InvocationStateManager"/>
|
|
<node CREATED="1488937001406" ID="ID_1747520920" MODIFIED="1488937012304" TEXT="letzterer ist Interface für UI-Entitäten"/>
|
|
</node>
|
|
<node CREATED="1488936942317" ID="ID_222608258" MODIFIED="1488939548823">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Proc: <b>CmdInstanceManager</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1488937028202" ID="ID_1121930542" MODIFIED="1488937033253" TEXT="erzeugt die Instanzen"/>
|
|
<node CREATED="1488937033769" ID="ID_1795817178" MODIFIED="1488937045947" TEXT="verwaltet deren Lebenszyklus"/>
|
|
<node CREATED="1488937046591" ID="ID_1911259949" MODIFIED="1488937055426" TEXT="vom UI allein per ID ansprechbar"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488938186100" ID="ID_98580620" MODIFIED="1489191362863" TEXT="Command-Definition erweitern">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1488938195387" ID="ID_1831459518" MODIFIED="1488938202950" TEXT="Möglichkeit, Regeln vorzugeben"/>
|
|
<node CREATED="1488938222135" ID="ID_1365861102" MODIFIED="1488938232250" TEXT="werden fest mit dem Command zusammen konfiguriert"/>
|
|
<node CREATED="1488938205266" ID="ID_1560120611" MODIFIED="1488938215411" TEXT="diese können aus der Command-Def bezogen werden"/>
|
|
</node>
|
|
<node CREATED="1488939658004" ID="ID_726054321" MODIFIED="1488939668212" TEXT="Interaktionen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1488939675705" ID="ID_1515081819" MODIFIED="1488939724134" TEXT="UI-Element fragt CmdAccessor nach InteractionStateManager"/>
|
|
<node CREATED="1488939946828" ID="ID_1817986480" MODIFIED="1488940966027" TEXT="CmdAccessor speichert InteractionStateManager"/>
|
|
<node CREATED="1492442881509" ID="ID_79816412" MODIFIED="1492442905342" TEXT="irgendjemand bindet ein Command an den Kontext und markiert die zu bindenden Argumente"/>
|
|
<node CREATED="1492442906642" ID="ID_1806470431" MODIFIED="1492442926595" TEXT="dabei werden Argumente mit bestimmten Rollen markiert (Subjekt, Scope, Wert)"/>
|
|
<node CREATED="1488939748247" ID="ID_589914539" MODIFIED="1489079785598" TEXT="InteractionStateManager belegt beim CmdInstanceManager neue ID..."/>
|
|
<node CREATED="1488940222591" ID="ID_1071611814" MODIFIED="1488940241768" TEXT="UI-Element fragt InteractionStateManager: "kann dieses Command ausgeführt werden"?"/>
|
|
<node CREATED="1488940300116" ID="ID_172216455" MODIFIED="1488940331244" TEXT="UI-Element registriert sich beim InteractionStateManager (als Observer)"/>
|
|
<node CREATED="1488940435601" ID="ID_1906295137" MODIFIED="1492442861300" TEXT="InteractionState befriedigt die Parameter aus dem aktuellen Interaktions-Kontext"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1488940469365" ID="ID_130562988" MODIFIED="1576282357997" TEXT="TODO: wie werden die Parameter konkret übergeben?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es könnte z.B. sein, daß man vom InteractionState
|
|
</p>
|
|
<p>
|
|
direkt einen Record<GenNode> bezieht, und bei diesem Zugriff
|
|
</p>
|
|
<p>
|
|
automatisch die Kontext-Accessor-Ausdrücke ausgewertet werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#6b709e" DESTINATION="ID_131071232" ENDARROW="Default" ENDINCLINATION="275;0;" ID="Arrow_ID_1369499964" STARTARROW="Default" STARTINCLINATION="275;0;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1488940519518" ID="ID_1875791797" MODIFIED="1488940533992" TEXT="bei nächster Anfrage wird CmdInstanceManager daher neue Instanz anlegen"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1488677859619" HGAP="-15" ID="ID_827179653" MODIFIED="1576282357996" TEXT="Problem: Service-Zugang" VSHIFT="24">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da dies ein pervasiv genutzter Service ist,
|
|
</p>
|
|
<p>
|
|
und wir nicht wollen, daß jedes Widget
|
|
</p>
|
|
<p>
|
|
mit dem InteractionDirector verdrahtet sein muß!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#9f5680" DESTINATION="ID_850989325" ENDARROW="Default" ENDINCLINATION="211;189;" ID="Arrow_ID_1007188680" STARTARROW="None" STARTINCLINATION="963;-965;"/>
|
|
<linktarget COLOR="#758ba4" DESTINATION="ID_827179653" ENDARROW="Default" ENDINCLINATION="173;83;" ID="Arrow_ID_57938013" SOURCE="ID_1621107057" STARTARROW="None" STARTINCLINATION="384;-135;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1488936835940" ID="ID_1322149090" MODIFIED="1576282357996" TEXT="separates Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hat überhaupt nichts mit dem Zugang zu Commands zu tun,
|
|
</p>
|
|
<p>
|
|
und auch nichts mit der Trennung zwischen Layern und Subsystemen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1488936840059" ID="ID_1305671938" MODIFIED="1576282357995" TEXT="generisches Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es geht um Service-Dependencies
|
|
</p>
|
|
<p>
|
|
aka DependencyInjection + Lifecycle Management
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b6829b" DESTINATION="ID_1359158691" ENDARROW="Default" ENDINCLINATION="1134;-1646;" ID="Arrow_ID_927211935" STARTARROW="None" STARTINCLINATION="1359;916;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1488937419308" ID="ID_994813744" MODIFIED="1518487921092" TEXT="lib::Depend ausbauen"/>
|
|
<node CREATED="1488937436890" ID="ID_1184288068" MODIFIED="1518487921092" TEXT="kann auf später vertagt werden"/>
|
|
<node CREATED="1488937424996" ID="ID_1712367280" MODIFIED="1518487921092" TEXT="vorerst eigenes Front-End verwenden"/>
|
|
<node CREATED="1488937449896" ID="ID_1352702920" MODIFIED="1576282357995" TEXT="Idee klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
man hat ein statisches Front-End, d.h. by-name access
|
|
</li>
|
|
<li>
|
|
hinter dem liegt eine Factory
|
|
</li>
|
|
<li>
|
|
die Instanz kann von innen her wieder geschlossen werden
|
|
</li>
|
|
<li>
|
|
wenn geschlossen, dann Fehler werfen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1538868884651" ID="ID_92705586" MODIFIED="1538868888699" TEXT="gelöst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614379178320" ID="ID_1221036425" MODIFIED="1614380579512" TEXT="komplexe Aktionen mit Satzcharakter und Kontext">
|
|
<linktarget COLOR="#5b4964" DESTINATION="ID_1221036425" ENDARROW="Default" ENDINCLINATION="717;-46;" ID="Arrow_ID_1875882072" SOURCE="ID_1624270915" STARTARROW="None" STARTINCLINATION="586;34;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1614379221818" ID="ID_970302446" MODIFIED="1614379248300" TEXT="zunächst wurde nur eine »point and shot«-Lösung realisiert">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1614379249966" ID="ID_1395628620" MODIFIED="1614379269183" TEXT="feste verdrahtete Command-ID"/>
|
|
<node CREATED="1614379269938" ID="ID_487933301" MODIFIED="1614379285059">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur eine Art <i>remote procedure call</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614379298743" ID="ID_1608963281" MODIFIED="1614379434193" TEXT="Frage: muß das UI-Bus-Protokoll erweitert werden?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das heißt auch, wo werden die Aussage-Sätze gebildet?<br />wird das Formen von kontextbezogenen Anweisungen im UI-Bus-Protokoll eigens verankert, oder erfolgt dies komplett intern im Stage-Layer?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614379467852" ID="ID_327990233" MODIFIED="1614379593877" TEXT="das heißt auch: Aufsammeln der Kontext-Information ― wer und wie?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614379530868" ID="ID_131071232" MODIFIED="1614379614382" TEXT="werden Parameter sofort übersetzt, oder schrittweise aufgesammelt?">
|
|
<linktarget COLOR="#6b709e" DESTINATION="ID_131071232" ENDARROW="Default" ENDINCLINATION="275;0;" ID="Arrow_ID_1369499964" SOURCE="ID_130562988" STARTARROW="Default" STARTINCLINATION="275;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#3301ae" CREATED="1616854028288" ID="ID_1575859119" MODIFIED="1616854070566" TEXT="neige mehr und mehr dazu, dies rein intern in gewissen »Gesten-Controllern« zu regeln...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618493782498" ID="ID_1188739544" MODIFIED="1618495853582" TEXT="im Allgemeinen....">
|
|
<arrowlink COLOR="#436b85" DESTINATION="ID_1168598401" ENDARROW="Default" ENDINCLINATION="-1067;53;" ID="Arrow_ID_811903885" STARTARROW="None" STARTINCLINATION="325;54;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488674268407" ID="ID_284516869" MODIFIED="1518487921092" TEXT="Parameter">
|
|
<node CREATED="1488937542963" ID="ID_853531623" MODIFIED="1518487921092" TEXT="passiert im InvocationStateManager"/>
|
|
<node CREATED="1488937551514" ID="ID_1024843173" MODIFIED="1518487921092" TEXT="es könnte Binde-Regeln geben"/>
|
|
<node CREATED="1488937996901" ID="ID_1000532365" MODIFIED="1576282357994" TEXT="Lösungsweg vom Command vorkonfiguriert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nicht klar, ob das notwendig (und gut) ist
|
|
</p>
|
|
<p>
|
|
es könnte auch ausreichen, einfach die passende InteractionStateManager-Impl zu verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1488937565632" ID="ID_1990212985" MODIFIED="1576282357994" TEXT="dem User (UI-Element) ist das egal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn InteractionStateManager ist ein <b>Interface</b>!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1488937651021" ID="ID_1956085726" MODIFIED="1518487921092" TEXT="Binde-Muster">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1488937670778" ID="ID_696645875" MODIFIED="1576282357993" TEXT="fest hinterlegte Eintität einsetzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das UI weiß,
|
|
</p>
|
|
<p>
|
|
wer das konkret immer sein wird.
|
|
</p>
|
|
<p>
|
|
D.h. beim Start des UI wird eine Verbindung irgendwo hinterlegt
|
|
</p>
|
|
<p>
|
|
Das könnte ein <i>Advice</i> sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1488937682649" ID="ID_1090053275" MODIFIED="1576282357993" TEXT="aktuelles Element (mit Typ-Check)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vom Command her ist der Typ festgelegt
|
|
</p>
|
|
<p>
|
|
auf das "aktuelle Element" wir eine Art Typ-Match gemacht.
|
|
</p>
|
|
<p>
|
|
Wenn der paßt, kann das aktuelle Element verwendet werden.
|
|
</p>
|
|
<p>
|
|
In diesem Fall wird das Command <i>enabled</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1488937711053" ID="ID_586793367" MODIFIED="1576282357992" TEXT="partial application">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eine Argumentliste mit mehreren Parametern wir Schritt für Schritt geschlossen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1488937724867" ID="ID_231519502" MODIFIED="1576282357991" TEXT="Ordnung nach Scope">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn mehrere Objekte als Argumente in Frage kommen,
|
|
</p>
|
|
<p>
|
|
wird das gemäß Scope "nächstgelegne" genommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488937933566" ID="ID_170827087" MODIFIED="1518487921092" TEXT="das sind komplexe Pläne">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1488937947004" ID="ID_1297081811" MODIFIED="1518487921092" TEXT="Schlußfolgerung: nur die Strategie vorsehen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618498875079" ID="ID_1822212049" MODIFIED="1618499095806" TEXT="Framework-Anforderungen beachten">
|
|
<linktarget COLOR="#5c4052" DESTINATION="ID_1822212049" ENDARROW="Default" ENDINCLINATION="-834;0;" ID="Arrow_ID_1506237506" SOURCE="ID_420683622" STARTARROW="None" STARTINCLINATION="112;439;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672976664" ID="ID_476262016" MODIFIED="1518487921092" TEXT="Rollen">
|
|
<node CREATED="1488673008668" ID="ID_1231961413" MODIFIED="1518487921092" TEXT="InvocationTrail">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1488673045793" ID="ID_969627518" MODIFIED="1518487921092" TEXT="passiver Marker für eine Instanz"/>
|
|
<node CREATED="1492443050502" ID="ID_333085641" MODIFIED="1518487921092" TEXT="Konzept aufgegeben">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488673032384" ID="ID_1621941781" MODIFIED="1518487921092" TEXT="InteractionStateManager">
|
|
<node CREATED="1488673053917" ID="ID_312201027" MODIFIED="1518487921092" TEXT="Vermittler"/>
|
|
<node CREATED="1488673066524" ID="ID_1129594057" MODIFIED="1518487921092" TEXT="Bildung von Sätzen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#53102b" CREATED="1613947659276" ID="ID_1657972773" MODIFIED="1613947682366" TEXT="Stand">
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1613947688776" ID="ID_1133022481" MODIFIED="1613947709441" TEXT="2017 - 2/2021">
|
|
<node CREATED="1613947717729" ID="ID_1840082890" MODIFIED="1613948142348" TEXT="es gibt eine Vision">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Interaktion mit einem UI formuliert Befehls-Aussagen indem sie die »<b>Gesten</b>« des Benutzers beobachtet; dieser bewegt sich dabei in konzeptionell in einem »Interface-<b>Raum</b>«
|
|
</li>
|
|
<li>
|
|
das konkrete Interaktions-System (Keyboard, Mouse, Pen, Hardware-Controller, VR...) ist konsequent zu <b>abstrahieren</b>
|
|
</li>
|
|
<li>
|
|
eine Zwischenschicht trennt die Widgets, die das UI realisieren, und die vom UI abgesetzten Handlungs-Anweisungen (»Commands«)
|
|
</li>
|
|
<li>
|
|
diese Zwischenschicht ― oder Interaktions-Schicht ― zu entwickeln ist ein Kern-Belang; dieser Belang kann niemals von irgend einem Framework abgedeckt werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1613947727636" ID="ID_729788594" MODIFIED="1613948283484" TEXT="ein elaboriertes Framework wurde geplant und wieder verworfen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
2017 habe ich zunächst versucht, die Analyse soweit zu treiben, daß sich daraus Strukturen ablesen lassen; die Intention war, darin die einfache Struktur eines direkt "point and shot" gegebenen Commands eingebettet zu finden. Dieses Bestreben mußte abgebrochen werden, da ich noch nicht genug über das konrete Interface weiß, um sachadäquat beurteilen zu können, was <i>notwendig ist.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1613947757959" ID="ID_1626123352" MODIFIED="1613948424917" TEXT="darauf aufbauend wurde der einfachste Fall bereits fertig implementiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...stattdessen habe ich dann die schon bestehenden und definierten Teile zusammengebunden, um das direkte Absetzen von fest im Code vorgegebenen Commands zu ermöglichen. Diese gehen seither als einfache symbolische Nachrichten über den UI-Bus. Das gesamte Thema "Argument Binding" ist bereits abschließend behandelt (Marshalling via GenNode). Ebenso der asynchrone Dispatch, und die ebenso asynchron entkoppelte Rückmeldung ("push up") in das UI.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1613947778476" ID="ID_1664459728" MODIFIED="1613948672376" TEXT="an der Grundidee wird festgehalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
2018-2019 habe ich eine dieser Vision entsprechende, offene und generische Grundstruktur des UI angelegt, und begonnen, konkret für die Timeline-Repräsentation auszuimplementieren. Auch dies ist grundsätzlich alles geregelt, wir können ein Custom-Stylesheet aufgreifen, wir können eigene Widgets mit custom-drawing realisieren, und trotzdem weitgehend auf das UI-Toolkitset mit allen seinen Zusatzfunktionen zurückgreifen. Nun (2/2021) bin ich wieder an dem Punkt, an dem die erste, einfachste »Geste« zu realisieren wäre: nämlich das Verschieben eines Clip in der Timeline. Und ich halte genau an der Einsicht fest, daß diese Interaktions-Logik nicht fest in ein Widget eingebaut werden darf.<br /><i><font color="#a33449">Da stehe ich, und mehr weiß ich noch nicht...</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672585310" ID="ID_50525010" MODIFIED="1518487921092" TEXT="framework">
|
|
<node CREATED="1489191062441" ID="ID_772085108" MODIFIED="1518487921092" TEXT="Aktoren">
|
|
<node CREATED="1489191072415" ID="ID_546981226" MODIFIED="1518487921092" TEXT="Command Definition"/>
|
|
<node CREATED="1489191088613" ID="ID_1858363588" MODIFIED="1518487921092" TEXT="CmdAccessor"/>
|
|
<node CREATED="1489191103187" ID="ID_1016072906" MODIFIED="1518487921092" TEXT="InteractionStateManager"/>
|
|
<node CREATED="1489191095700" ID="ID_1053653890" MODIFIED="1518487921092" TEXT="InteractionDirector"/>
|
|
</node>
|
|
<node CREATED="1489191112026" FOLDED="true" ID="ID_1805268724" MODIFIED="1561827465703" TEXT="Implementierung">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1489191118705" ID="ID_1501573546" MODIFIED="1518487921092" TEXT="Aufbau">
|
|
<node CREATED="1489191126256" HGAP="24" ID="ID_127004361" MODIFIED="1518487921092" TEXT="Tickets" VSHIFT="26">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1489191161395" ID="ID_346158251" MODIFIED="1518487921092" TEXT="#1087 GUI/Session command handling">
|
|
<linktarget COLOR="#606d94" DESTINATION="ID_346158251" ENDARROW="Default" ENDINCLINATION="671;0;" ID="Arrow_ID_726918944" SOURCE="ID_898481930" STARTARROW="None" STARTINCLINATION="1012;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1489191208557" FOLDED="true" ID="ID_632390561" MODIFIED="1561827465704" TEXT="#1088 Command definition registration">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1490986190364" ID="ID_266121409" MODIFIED="1518487921092" TEXT="CommandSetup helper">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1490986198683" ID="ID_658767230" MODIFIED="1518487921092" TEXT="Build-Skript vertagt">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1518487921092" ID="ID_1694595239" MODIFIED="1613943616179" TEXT="vorläufig werden Commands von Hand definiert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Plan ist, einmal Command-Skripts (C++ basierte DSL-Notation) direkt vom Build-System verarbeiten zu lassen; der Build wird daraus passende C++-Translation-Units generieren und übersetzen. Tatsächlich ist all dies nicht besonders anspruchsvoll, denn die eigentliche Arbeit, die DSL-Notation ist bereits geschaffen. Trotzdem ist das Thema vorerst vertagt, weil zur praktischen Ausführung eine Menge zusätzlichem Wissen aus der Praxis notwendig ist, wie z.B. wie teilt man die Commands ein, wer definiert überhaupt Commands, und zu welchem Zweck. Beispielsweise ist es durchaus später einmal denkbar, daß auch eine Lumiera-Extension (Plug-in) zusätzliche Command-Scripts bereitstellt. Dann stellt sich natürlich auf das (ziemlich anspruchsvolle) Problem der Belegung von Command-IDs erneut.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Vorerst und auf längere Sicht genügt es völlig, die Command-Scripts von Hand zu schreiben und in einigen Cpp-Files im Steam-Layer abzulegen. Als allgemein sichtbare Schnittstelle dient der Header cmd.hpp, in dem die Command-IDs fest als globale Konstanten definiert sind. Diesen Ansatz behalten wir solange bei, bis die Pflege dieser fest verdrahteten Definitionen und Command-Skripte tatsächlich zum Problem wird.
|
|
</p>
|
|
<p>
|
|
<b>YAGNI</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1613942454968" ID="ID_1870290710" MODIFIED="1613942458935" TEXT="proc/cmd.hpp">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1489191229098" FOLDED="true" ID="ID_341428100" MODIFIED="1582989005605" TEXT="#1089 Command instance management">
|
|
<linktarget COLOR="#584d79" DESTINATION="ID_341428100" ENDARROW="Default" ENDINCLINATION="1864;-1272;" ID="Arrow_ID_879741123" SOURCE="ID_1331796226" STARTARROW="None" STARTINCLINATION="769;78;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1489196572055" ID="ID_339289633" MODIFIED="1489196577154" TEXT="Command-ID">
|
|
<node CREATED="1489196578470" ID="ID_1460242316" MODIFIED="1490976980566" TEXT="extensible ID anschauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1490976981548" ID="ID_319912426" MODIFIED="1492169049860" TEXT="nein: es genügen rein textuelle IDs">
|
|
<arrowlink DESTINATION="ID_119293304" ENDARROW="Default" ENDINCLINATION="153;-248;" ID="Arrow_ID_1691148413" STARTARROW="None" STARTINCLINATION="312;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1490985775995" ID="ID_1920622498" MODIFIED="1561827465707" TEXT="Instance-Manager">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1490985786138" ID="ID_664659428" MODIFIED="1490985793244" TEXT="einfache Komponente"/>
|
|
<node CREATED="1490985793793" ID="ID_511499018" MODIFIED="1490985798436" TEXT="wo">
|
|
<node CREATED="1490985799639" ID="ID_1798979341" MODIFIED="1490985804979" TEXT="SessionCommandService"/>
|
|
<node CREATED="1490985805518" ID="ID_937609414" MODIFIED="1490985814593" TEXT="damit vom SessionLoopThread gemanaged"/>
|
|
</node>
|
|
<node CREATED="1490985820613" ID="ID_1526182884" MODIFIED="1490985823408" TEXT="API">
|
|
<node CREATED="1490985825844" ID="ID_1072463021" MODIFIED="1490985853020" TEXT="neue Instanz">
|
|
<node CREATED="1490986239341" ID="ID_1121928421" MODIFIED="1490986243065" TEXT="ID dekorieren"/>
|
|
<node CREATED="1490986243557" ID="ID_1457927529" MODIFIED="1490986249952" TEXT="slot / smart-ptr erzeugen"/>
|
|
</node>
|
|
<node CREATED="1490985938597" ID="ID_90790203" MODIFIED="1490985955039" TEXT="Dispatch">
|
|
<node CREATED="1490986252963" ID="ID_1745967844" MODIFIED="1490986257991" TEXT="smart-ptr move"/>
|
|
<node CREATED="1490986258483" ID="ID_462607969" MODIFIED="1490986261422" TEXT="slot leeren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491005426763" ID="ID_1575553505" MODIFIED="1538870990460" TEXT="zu klären: duplikate Instanz">
|
|
<arrowlink COLOR="#ca978d" DESTINATION="ID_1805144008" ENDARROW="Default" ENDINCLINATION="594;0;" ID="Arrow_ID_191915626" STARTARROW="None" STARTINCLINATION="594;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491005509448" ID="ID_709599195" MODIFIED="1491005512147" TEXT="Fehler?"/>
|
|
<node CREATED="1491005514015" ID="ID_66770459" MODIFIED="1491495268579" TEXT="bestehende Instanz überbügeln"/>
|
|
<node CREATED="1491495244653" ID="ID_1710448495" MODIFIED="1491495254015" TEXT="stillschweigend die bestehende Instanz verwenden"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1491495254699" ID="ID_1848409976" MODIFIED="1613943705388" TEXT="per Fehler abweisen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008040105" FOLDED="true" HGAP="50" ID="ID_662216926" MODIFIED="1561827465708" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1491008045936" ID="ID_1071153669" MODIFIED="1491008146180" TEXT="CommandInstanceManager_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008059366" ID="ID_1809405076" MODIFIED="1491008147195" TEXT="CommandInstanceManager">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008067046" ID="ID_1905446877" MODIFIED="1491008148076" TEXT="einfache Map-Impl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008073989" ID="ID_1954195404" MODIFIED="1491008148995" TEXT="Symbol-Tabelle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008079676" ID="ID_1262786130" MODIFIED="1491618841600" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1491008088699" ID="ID_1501876595" MODIFIED="1576282357991" TEXT="Basisfall läuft noch nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Instanz kommt nicht in der Fixture-Queue an
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008118695" ID="ID_1595821007" MODIFIED="1491618830886" TEXT="Invocation abdecken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491498978878" ID="ID_1001760576" MODIFIED="1576282357991" TEXT="nicht direkt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Umstand, daß Commands auch ausgeführt werdern können,
|
|
</p>
|
|
<p>
|
|
gehört nicht zum Thema "Instanz-Management"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491499005954" ID="ID_1944400975" MODIFIED="1576282357990" TEXT="aber im Hinblick auf den Lebenszyklus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn ein Command geht dann in die Queue
|
|
</p>
|
|
<p>
|
|
und kann noch ausgeführt werden, während ein weiteres
|
|
</p>
|
|
<p>
|
|
schon "in der Mache ist"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008124550" ID="ID_249252999" MODIFIED="1491618833169" TEXT="Duplikate abdecken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1491008129165" ID="ID_118623494" MODIFIED="1491618835441" TEXT="Lebenszyklus-Fehler">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491753027936" HGAP="53" ID="ID_118278209" MODIFIED="1561827465709" TEXT="Refactoring" VSHIFT="4">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491753036895" ID="ID_1029946389" MODIFIED="1491753047201" TEXT="fall-back auf Command integrieren"/>
|
|
<node CREATED="1491753645531" ID="ID_597184850" MODIFIED="1491753650607" TEXT="maybeGet entfernen"/>
|
|
<node CREATED="1491753047981" FOLDED="true" ID="ID_1220888974" MODIFIED="1491753330643" TEXT="Referenz rausgeben">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1491753058620" ID="ID_1772710050" MODIFIED="1491753078866" TEXT="nicht thradsafe">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1491753170924" ID="ID_1947747818" MODIFIED="1576282357989" TEXT="Command-Zugriff ist by value">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aus gutem Grund
|
|
</p>
|
|
<p>
|
|
(kann mich erinnern, daß ich mir das überlegt hatte).
|
|
</p>
|
|
<p>
|
|
Sofern Definitionen wirklich concurrent geändert oder gelöscht werden,
|
|
</p>
|
|
<p>
|
|
könnte es sein, daß jemand auf einer stale reference arbeitet,
|
|
</p>
|
|
<p>
|
|
denn das Lock schützt nur den Aufruf innerhalb der CommandRegistry.
|
|
</p>
|
|
<p>
|
|
Sicher ist der Zugriff nur, wenn im Schutzbereich dieses Locks ein
|
|
</p>
|
|
<p>
|
|
neues Command-Objekt kopiert wird. Was allerdings den RefCount erhöht.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491753132377" ID="ID_1441469124" MODIFIED="1491753156451" TEXT="müßte dafür direkt auf die CommandRegistry zugreifen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491753332318" ID="ID_889636506" MODIFIED="1491757384745" TEXT="nein: Wert rausgeben">
|
|
<linktarget COLOR="#3e657d" DESTINATION="ID_889636506" ENDARROW="Default" ENDINCLINATION="21;223;" ID="Arrow_ID_1428975472" SOURCE="ID_1707474386" STARTARROW="None" STARTINCLINATION="-541;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491753337438" ID="ID_1228083262" MODIFIED="1491753342636" TEXT="KISS">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1491753354116" ID="ID_1070880433" MODIFIED="1576282357989" TEXT="Bus + CommandHandler + GenNode">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber sich mit einem Refcount verrückt machen.....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491656361886" HGAP="62" ID="ID_1269299900" MODIFIED="1561827465713" TEXT="Einbindung" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1491659172438" HGAP="34" ID="ID_1103739498" MODIFIED="1491757376165" TEXT="in SessionCommandService" VSHIFT="-3">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491659191155" ID="ID_586991718" MODIFIED="1491659216131" TEXT="Nutzung des Instance-Managers ist optional"/>
|
|
<node CREATED="1491659194283" ID="ID_1169808852" MODIFIED="1491659203949" TEXT="direkter Zugriff auf Commands bleibt offen"/>
|
|
<node CREATED="1491659224630" ID="ID_837055372" MODIFIED="1491659238608" TEXT="Entscheidung anhand der Command-ID"/>
|
|
<node CREATED="1491694300867" ID="ID_1838809343" MODIFIED="1576282357988" TEXT="Festlegung: CommandID wird als Symbol entgegengenommen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....künftige Weiterung:
|
|
</p>
|
|
<p>
|
|
auch in EntryID könnte ein Symbol stecken,
|
|
</p>
|
|
<p>
|
|
mithin in der GenNode::ID
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491659382161" ID="ID_948768193" MODIFIED="1576282357988" TEXT="Performance: maybeGet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da dieser Zugriff wirklich für jedes Command passiert,
|
|
</p>
|
|
<p>
|
|
möchte ich mit dem Minimum an Hashtable-Zugriffen auskommen.
|
|
</p>
|
|
<p>
|
|
Daher prüfen wir als erstes den CommandInstanceManager,
|
|
</p>
|
|
<p>
|
|
da dies der Regelfall ist. Wenn dies scheitert, suchen wir noch
|
|
</p>
|
|
<p>
|
|
in der globalen Registry
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1491702872058" ID="ID_487194706" MODIFIED="1491702875613" TEXT="keine gute Idee"/>
|
|
<node CREATED="1491702876137" ID="ID_141674543" MODIFIED="1491702880476" TEXT="doppelt das Interface"/>
|
|
<node CREATED="1491702881160" ID="ID_1657270200" MODIFIED="1491753472968" TEXT="Taschenspielerei">
|
|
<arrowlink COLOR="#a71f6e" DESTINATION="ID_1776414678" ENDARROW="Default" ENDINCLINATION="-8;-62;" ID="Arrow_ID_559634306" STARTARROW="None" STARTINCLINATION="-86;2;"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491702805203" HGAP="26" ID="ID_1776414678" MODIFIED="1491757370278" TEXT="Performance / Standard-Fall" VSHIFT="22">
|
|
<linktarget COLOR="#a71f6e" DESTINATION="ID_1776414678" ENDARROW="Default" ENDINCLINATION="-8;-62;" ID="Arrow_ID_559634306" SOURCE="ID_1657270200" STARTARROW="None" STARTINCLINATION="-86;2;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491702822568" ID="ID_1028353876" MODIFIED="1491702830531" TEXT="wir suchen stets zuerst eine Instanz"/>
|
|
<node CREATED="1491702831023" ID="ID_184396015" MODIFIED="1491702840810" TEXT="wir fallen auf die globale Registry zurück"/>
|
|
<node CREATED="1491702841453" ID="ID_1707474386" MODIFIED="1491757384744" TEXT="das kann der InstanceManager am Besten selber!">
|
|
<arrowlink COLOR="#3e657d" DESTINATION="ID_889636506" ENDARROW="Default" ENDINCLINATION="21;223;" ID="Arrow_ID_1428975472" STARTARROW="None" STARTINCLINATION="-541;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491692398913" FOLDED="true" HGAP="27" ID="ID_1349137025" MODIFIED="1561827465708" TEXT="in UI-Bus" VSHIFT="6">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="closed"/>
|
|
<node COLOR="#990000" CREATED="1491692419958" ID="ID_411638678" MODIFIED="1582487370244" TEXT="#1058 consider expanding UI-Bus protocol for command cloning">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1491692431021" ID="ID_1526880552" MODIFIED="1491692436375" TEXT="wollen wir das?"/>
|
|
<node CREATED="1491692438907" ID="ID_1137204114" MODIFIED="1491692452509" TEXT="oder nur für explizite Spezialisierungen?"/>
|
|
<node CREATED="1491692779933" ID="ID_184706664" MODIFIED="1491692783680" TEXT="Abwägung">
|
|
<node CREATED="1491692784692" ID="ID_875264954" MODIFIED="1533608414018" TEXT="pro">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1491692786876" ID="ID_1725123375" MODIFIED="1491692800733" TEXT="Einheitliches Interface"/>
|
|
<node CREATED="1491692887517" ID="ID_832151078" MODIFIED="1491692894912" TEXT="Bus könnte weitere Trennschicht werden"/>
|
|
<node CREATED="1491692922625" ID="ID_1378937117" MODIFIED="1491692927444" TEXT="Bus ist gut unit-testbar"/>
|
|
</node>
|
|
<node CREATED="1491692931040" ID="ID_1678638713" MODIFIED="1533608414020" TEXT="con">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491692990840" ID="ID_1200979620" MODIFIED="1491692995939" TEXT="ziemlich indirekt"/>
|
|
<node CREATED="1491692996639" ID="ID_1249742943" MODIFIED="1491693005081" TEXT="double-dispatch"/>
|
|
<node CREATED="1491693382706" ID="ID_1886288474" MODIFIED="1576282357987" TEXT="CommandHandler hat keinen Rückgabewert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wir müßten dann auch noch das Interface brechen
|
|
</p>
|
|
<p>
|
|
und die Form der ID-Dokoration zur Konvention machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491693197435" ID="ID_1151359036" MODIFIED="1576282357987" TEXT="InteractionState ist kein Tangible">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, für das ganze Thema InteractionControl
|
|
</p>
|
|
<p>
|
|
schwebt mir eine Zwischenschicht unabhängig von den Widgets vor
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wenn nun aber das Anfordern einer neuen Instanz über den Bus laufen soll,
|
|
</p>
|
|
<p>
|
|
dann würde es wohl ehr direkt von den Tangibles (Widget / Controller) ausgehen.
|
|
</p>
|
|
<p>
|
|
Das wollte ich <i>genau nicht</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491693246284" ID="ID_553376017" MODIFIED="1576282357986">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Tangible sollte InteractionState <i>verwenden</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und demnach sollte InteractionState eben grade nicht von Tangible wissen
|
|
</p>
|
|
<p>
|
|
Demnach müßte sich InteractionState irgendwo "hinten rum" an den Bus ranmachen,
|
|
</p>
|
|
<p>
|
|
z.B. über den InteractionDirector. Das ist aber nun wirklich absurrd,
|
|
</p>
|
|
<p>
|
|
da es letztlich nur darum geht ein <i>ohnehin öffentliches</i>  Interface aufzurufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491659180516" ID="ID_655217923" MODIFIED="1492391121444" TEXT="in CmdAccess">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492391124070" ID="ID_1515597578" MODIFIED="1492391129921" TEXT="nicht mehr notwendig"/>
|
|
<node CREATED="1492391131173" ID="ID_1089257513" MODIFIED="1492391139944" TEXT="CmdAccess wird komplett on top arbeiten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492293088861" HGAP="28" ID="ID_1660020661" MODIFIED="1561827465721" TEXT="Überarbeitung" VSHIFT="14">
|
|
<linktarget COLOR="#626a9e" DESTINATION="ID_1660020661" ENDARROW="Default" ENDINCLINATION="-324;0;" ID="Arrow_ID_876356993" SOURCE="ID_220910293" STARTARROW="None" STARTINCLINATION="-687;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492293139398" ID="ID_1274577545" MODIFIED="1492293146721" TEXT="als Folge der Design-Kritik"/>
|
|
<node CREATED="1492293282803" ID="ID_1858980532" MODIFIED="1492293285150" TEXT="Ziel">
|
|
<node CREATED="1492293286802" ID="ID_980352671" MODIFIED="1492293292141" TEXT="weitgehend automatisch"/>
|
|
<node CREATED="1492293292801" ID="ID_556604895" MODIFIED="1492293305099" TEXT="Zyklus muß nicht explizit eröffnet werden"/>
|
|
<node CREATED="1492293307511" ID="ID_582978700" MODIFIED="1492293317442" TEXT="Instanzen selbst für globale Commands"/>
|
|
<node CREATED="1561827465708" ID="ID_1337375396" MODIFIED="1613945493715" TEXT="zunächst einfach ― aber komplexere Lösung kann später noch realiseiert werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492293359944" ID="ID_1367582526" MODIFIED="1492293429410" TEXT="Konsequenzen">
|
|
<node CREATED="1492293430689" ID="ID_1472205001" MODIFIED="1492293430689" TEXT="weitgehender Verzicht auf Konsistenzprüfungen"/>
|
|
<node CREATED="1492293588400" ID="ID_1878334690" MODIFIED="1576282357985" TEXT="Binden und Dispatch müssen kombiniert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sonst wird die ganze Sache absurd
|
|
</p>
|
|
<p>
|
|
und unsinnigerweise aufwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492293433222" ID="ID_1665333497" MODIFIED="1492293442272" TEXT="Registry könnte längerfristig wegfallen"/>
|
|
</node>
|
|
<node CREATED="1492293450067" ID="ID_1626482891" MODIFIED="1492293452767" TEXT="Fälle">
|
|
<node CREATED="1492293499701" ID="ID_1165417078" MODIFIED="1492293504344" TEXT="voller Zyklus">
|
|
<node CREATED="1492293540943" ID="ID_432796112" MODIFIED="1492293561513">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Instanz <i>öffnen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492293553405" ID="ID_1787045274" MODIFIED="1492293557912" TEXT="Instanz herausgeben"/>
|
|
<node CREATED="1492293563028" ID="ID_713648189" MODIFIED="1492293583853" TEXT="Binden und Feuern"/>
|
|
</node>
|
|
<node CREATED="1492293984170" ID="ID_1495091918" MODIFIED="1492293990949" TEXT="fire-and-forget">
|
|
<node CREATED="1492294004119" ID="ID_1322819026" MODIFIED="1492294029307">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
CommandID <i>und</i> Argumente gegeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492294031035" ID="ID_521535374" MODIFIED="1492294048357" TEXT="anonyme Instanz erzeugen, aber nicht speichern"/>
|
|
<node CREATED="1492294049089" ID="ID_631979849" MODIFIED="1492294052148" TEXT="Argumente binden"/>
|
|
<node CREATED="1492294052616" ID="ID_1477708688" MODIFIED="1492294062235" TEXT="direkt an Dispatcher übergeben"/>
|
|
<node CREATED="1492294063183" ID="ID_1341000232" MODIFIED="1492294094983" TEXT="hinterläßt sonst keine Spur">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492294104665" ID="ID_433710721" MODIFIED="1492294116796" TEXT="globales Command">
|
|
<node CREATED="1492294207251" ID="ID_1653497945" MODIFIED="1492294212303" TEXT="wenn ID nicht lokal bekannt"/>
|
|
<node CREATED="1492294212795" ID="ID_82885635" MODIFIED="1492294242178" TEXT="aber globales Command bereits ausführbar"/>
|
|
<node CREATED="1492294242862" ID="ID_1583400472" MODIFIED="1492294253689" TEXT="anonyme Instanz klonen"/>
|
|
<node CREATED="1492294254277" ID="ID_57256331" MODIFIED="1492294260560" TEXT="und an Dispatcher übergeben"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492294356319" ID="ID_1877638479" MODIFIED="1492294363265" TEXT="Semantik-Änderung">
|
|
<node CREATED="1492294454001" ID="ID_356186975" MODIFIED="1492359481843">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
SessionCommandService::<b>trigger</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492295091826" ID="ID_96156600" MODIFIED="1533608414021" TEXT="bisher">
|
|
<node CREATED="1492295094337" ID="ID_420834348" MODIFIED="1492295103364" TEXT="Instanz nur wenn vorher angelegt"/>
|
|
<node CREATED="1492295104096" ID="ID_104008616" MODIFIED="1492295116282" TEXT="Sonst wird einfach globales Command genomen"/>
|
|
<node CREATED="1492295116894" ID="ID_930409268" MODIFIED="1492295120945" TEXT="gebunden und gefeuert"/>
|
|
</node>
|
|
<node CREATED="1492295122765" ID="ID_1120774629" MODIFIED="1533608414022" TEXT="jetzt">
|
|
<node CREATED="1492295137387" ID="ID_1142805823" MODIFIED="1492295146318" TEXT="offene Instanz wird genommen"/>
|
|
<node CREATED="1492295146794" ID="ID_715268835" MODIFIED="1492295159372" TEXT="Sonst wird anonyme Instanz gebildet"/>
|
|
<node CREATED="1492295160320" ID="ID_289465814" MODIFIED="1492295164348" TEXT="gebunden und gefeuert"/>
|
|
<node CREATED="1492350125119" ID="ID_1349289727" MODIFIED="1613945576576" TEXT="Suche zuerst in der globalen Command-Registry"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492294454001" ID="ID_1498558942" MODIFIED="1492359486258">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
SessionCommandService::<b>bindArg</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1492295834844" ID="ID_1373400691" MODIFIED="1492295839063" TEXT="Semantik nicht geändert"/>
|
|
</node>
|
|
<node CREATED="1492294454001" ID="ID_48228210" MODIFIED="1492359489563">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
SessionCommandService::<b>invoke</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492295834844" ID="ID_1465048391" MODIFIED="1533608414023" TEXT="bisher">
|
|
<node CREATED="1492295891844" ID="ID_219295848" MODIFIED="1492295983675" TEXT="offene Instanz wird zum Dispatcher verschoben"/>
|
|
<node CREATED="1492295914304" ID="ID_196991118" MODIFIED="1492295939921" TEXT="globales Command wird direkt an den Dispatcher übergeben"/>
|
|
</node>
|
|
<node CREATED="1492295855881" ID="ID_1570343929" MODIFIED="1533608414023" TEXT="jetzt">
|
|
<node CREATED="1492295965170" ID="ID_647547612" MODIFIED="1492350377230" TEXT="globales Command wird geklont"/>
|
|
<node CREATED="1492295941981" ID="ID_265372200" MODIFIED="1492295962382" TEXT="offene Instanz wird verschoben (unverändert)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492359501220" ID="ID_1889001956" MODIFIED="1492391055336" TEXT="Test anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1489191252503" FOLDED="true" ID="ID_1621107057" MODIFIED="1561827465730" TEXT="#1090 Command access for UI-Elements">
|
|
<arrowlink COLOR="#758ba4" DESTINATION="ID_827179653" ENDARROW="Default" ENDINCLINATION="173;83;" ID="Arrow_ID_57938013" STARTARROW="None" STARTINCLINATION="384;-135;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1489196597635" ID="ID_850892898" MODIFIED="1518487921092" TEXT="Access-Front-End">
|
|
<node CREATED="1492095519827" HGAP="16" ID="ID_983435641" MODIFIED="1518487921092" TEXT="Grundprinzip" VSHIFT="-5">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1492095551151" ID="ID_1172833434" MODIFIED="1518487921092" TEXT="verweist auf andere Komponente"/>
|
|
<node CREATED="1492095590481" ID="ID_842137243" MODIFIED="1518487921092">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
managed diese Komponente <i>nicht</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492095612678" ID="ID_836842226" MODIFIED="1518487921092" TEXT="open/closed state"/>
|
|
<node CREATED="1492095627868" ID="ID_463853539" MODIFIED="1518487921092" TEXT="Exception when closed"/>
|
|
</node>
|
|
<node CREATED="1489196605530" HGAP="104" ID="ID_1235925214" MODIFIED="1518487921092" TEXT="anschauen" VSHIFT="1">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1489196613065" ID="ID_1738286518" MODIFIED="1518487921092" TEXT="Proxy-Instanz"/>
|
|
<node CREATED="1489196617873" ID="ID_1676140831" MODIFIED="1518487921092" TEXT="Session Services"/>
|
|
</node>
|
|
<node CREATED="1492094142303" ID="ID_12953370" MODIFIED="1518487921092" TEXT="Zukunft / Plan">
|
|
<node CREATED="1492094148054" ID="ID_988050021" MODIFIED="1518487921092" TEXT="lib::Depend"/>
|
|
<node CREATED="1492094154237" ID="ID_1058052889" MODIFIED="1518487921092" TEXT="müßte generalisiert werden"/>
|
|
<node CREATED="1492094161724" ID="ID_657768231" MODIFIED="1518487921092" TEXT="Refactoring notwendig">
|
|
<node CREATED="1492094294218" ID="ID_531986736" MODIFIED="1518487921092" TEXT="Komplexität wirklich notwendig?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1492094305497" ID="ID_1689865131" MODIFIED="1518487921092" TEXT="Zweifel wegen double checked locking"/>
|
|
<node CREATED="1492094321039" ID="ID_1545149473" MODIFIED="1518487921092">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aufwendiges <i>Nebenthema</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492094512876" HGAP="32" ID="ID_953384901" MODIFIED="1518487921092" TEXT="vorläufig eigenständig" VSHIFT="4">
|
|
<node COLOR="#338800" CREATED="1492094528370" ID="ID_1032947061" MODIFIED="1518487921092" TEXT="später mal integrieren">
|
|
<arrowlink COLOR="#8697be" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="200;-562;" ID="Arrow_ID_1211717131" STARTARROW="None" STARTINCLINATION="1387;-152;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1613916810040" HGAP="23" ID="ID_69431933" MODIFIED="1613916831791" TEXT="(DependencyInjection Schema)" VSHIFT="3"/>
|
|
</node>
|
|
<node CREATED="1492095379262" ID="ID_16023242" MODIFIED="1518487921092" TEXT="einfache Implementierung"/>
|
|
<node CREATED="1492096252231" ID="ID_1892095908" MODIFIED="1518487921092" TEXT="Problem">
|
|
<node CREATED="1492096257182" ID="ID_682054688" MODIFIED="1518487921092" TEXT="externe Komponente muß kooperieren"/>
|
|
<node CREATED="1492096285706" ID="ID_1257721538" MODIFIED="1518487921092" TEXT="oder externe Kompnente muß einen Adapter installieren"/>
|
|
<node CREATED="1492096269716" ID="ID_527173807" MODIFIED="1518487921092" TEXT="oder externe Komponente muß das Front-end betreiben"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492095433567" FOLDED="true" HGAP="69" ID="ID_1208499974" MODIFIED="1576282357985" TEXT="DSL schaffen" VSHIFT="1">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das war der erste Entwurf
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
overengineered
|
|
</li>
|
|
<li>
|
|
am Bedarf vorbei
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b82856" DESTINATION="ID_73450627" ENDARROW="Default" ENDINCLINATION="-641;29;" ID="Arrow_ID_1593125080" STARTARROW="None" STARTINCLINATION="122;76;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492095437190" ID="ID_491978759" MODIFIED="1492095481564" TEXT="Wunsch: access(ID).<operation>(args)"/>
|
|
<node CREATED="1492096317382" ID="ID_554292510" MODIFIED="1492096319497" TEXT="möglich">
|
|
<node CREATED="1492096321341" ID="ID_543087109" MODIFIED="1492096656547" TEXT="CmdAccess::for(id).<operation>(args)"/>
|
|
<node CREATED="1492096678244" ID="ID_1032312440" MODIFIED="1492096690927" TEXT="cmdAccess(id).<operation>(args)"/>
|
|
</node>
|
|
<node CREATED="1492096751315" ID="ID_537448890" MODIFIED="1492096762621" TEXT="Frage: was ist ID ?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1492096881433" ID="ID_446570438" MODIFIED="1492098926420" TEXT="frei wählbare Kontext-ID">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492096925259" ID="ID_1180559929" MODIFIED="1492096943012" TEXT="müßte ID-Konvention verwenden"/>
|
|
<node CREATED="1492096965205" ID="ID_1565773206" MODIFIED="1492096975304" TEXT="manuelle Administration"/>
|
|
<node CREATED="1492096958310" ID="ID_55881971" MODIFIED="1492096962961" TEXT="fehleranfällig"/>
|
|
</node>
|
|
<node CREATED="1492096850229" ID="ID_1267775472" MODIFIED="1492096880653" TEXT="instanceID">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492098995736" ID="ID_70721654" MODIFIED="1492099021254" TEXT="per Builder erzeugt"/>
|
|
<node CREATED="1492098935224" ID="ID_1545341249" MODIFIED="1492098943667" TEXT="erfordert DSL-Kontext"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492098973515" HGAP="42" ID="ID_449212028" MODIFIED="1492281728466" TEXT="Syntax-Entwurf" VSHIFT="18">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492096992098" ID="ID_495973760" MODIFIED="1492132247519">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Symbol ADD_CLIP = CmdAccess::to (cmd::scope_addClip, INTO_FORK);
|
|
</p>
|
|
<p>
|
|
prepareCommand (cmdAccess(ADD_CLIP).bind (scope(HERE), element(RECENT)))
|
|
</p>
|
|
<p>
|
|
issueCommand (cmdAccess(ADD_CLIP).execute());
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492098948782" ID="ID_176273356" MODIFIED="1492098957764" TEXT="einigermaßen komplex">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1492099069702" ID="ID_1623888568" MODIFIED="1492099073097" TEXT="Bestandteile">
|
|
<node CREATED="1492099077900" ID="ID_489218136" MODIFIED="1533608414024" TEXT="Standard-Kontexte">
|
|
<node CREATED="1492099101785" ID="ID_1493219189" MODIFIED="1492099107713" TEXT="INTO_PROJECT"/>
|
|
<node CREATED="1492099089419" ID="ID_1867923525" MODIFIED="1492099092055" TEXT="INTO_FORK"/>
|
|
<node CREATED="1492099093187" ID="ID_999642842" MODIFIED="1492099097382" TEXT="INTO_BIN"/>
|
|
</node>
|
|
<node CREATED="1492099122230" ID="ID_1025497514" MODIFIED="1492099129057" TEXT="Benennungs-Schema für Command-Defs"/>
|
|
<node CREATED="1492099134053" ID="ID_358523293" MODIFIED="1492099143703" TEXT="lokal definierte Instanz-Symbole"/>
|
|
<node CREATED="1492099185350" ID="ID_209679519" MODIFIED="1492099189905" TEXT="Standard-Argument-Rollen"/>
|
|
<node CREATED="1492099167960" ID="ID_52357728" MODIFIED="1533608414024" TEXT="Argument-Resolver">
|
|
<node CREATED="1492099172695" ID="ID_1174757682" MODIFIED="1492099177035" TEXT="scope(HERE)"/>
|
|
<node CREATED="1492099177863" ID="ID_1060789301" MODIFIED="1492099182250" TEXT="element(RECENT)"/>
|
|
</node>
|
|
<node CREATED="1492099211058" ID="ID_518845722" MODIFIED="1492099413746" TEXT="(automatische) Nachrichten-Erzeugung"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492099456649" HGAP="39" ID="ID_1984335926" MODIFIED="1492099477994" TEXT="Konsequenzen" VSHIFT="10">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1492099466079" ID="ID_1013112793" MODIFIED="1576282357984" TEXT="gentle degradation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die DSL muß so konstruiert werden,
|
|
</p>
|
|
<p>
|
|
daß die Syntax-Elemente nahtlos simplifiziert werden können,
|
|
</p>
|
|
<p>
|
|
in eine Form, die sich unmittelbar jetzt implementieren läßt
|
|
</p>
|
|
<p>
|
|
und mit einfachen, direkt gegebenen Objekten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492099579824" ID="ID_727878406" MODIFIED="1492099585163" TEXT="CommandDef-DSL erweitern">
|
|
<node CREATED="1492099587359" ID="ID_453414313" MODIFIED="1492099599513" TEXT="muß Argument-Rollen auszeichnen können"/>
|
|
<node CREATED="1492099622066" ID="ID_1927536817" MODIFIED="1492099630669" TEXT="erweiterbar auf binding rules"/>
|
|
<node CREATED="1576282357985" ID="ID_318475227" MODIFIED="1613917141790" TEXT="erster Entwurf: → CmdContext">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1518487921093" HGAP="57" ID="ID_1013004860" MODIFIED="1613917115257" TEXT="umgewidmet in einen komplexeren Spezialfall" VSHIFT="17">
|
|
<arrowlink COLOR="#6c9dbe" DESTINATION="ID_143339688" ENDARROW="Default" ENDINCLINATION="2023;-1563;" ID="Arrow_ID_1767017735" STARTARROW="None" STARTINCLINATION="303;19;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576282357985" HGAP="43" ID="ID_73450627" MODIFIED="1613917052881" TEXT="Thema vorerst vertagt und einfache Lösung implementiert" VSHIFT="3">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u><font size="2">(Anmerkung 2/2021)</font></u>
|
|
</p>
|
|
<p>
|
|
Über dieses Thema, und »InteractionControl« im Allgemeinen habe ich intensiv nachgedacht über den Sommer 2017. Die damals aufgestellten Grundzüge erscheinen mir auch heute noch sinnvoll. Allerdings kann dieser Entwurf nicht nur allein aus first principles abgeleitet werden. Daher habe ich im Winter 2017/18 dann entschieden, eine Verkopplung mit dem direkten Aufruf von Commands aufzulösen, wodurch Letztere einfach implementiert werden konnte. Überhaupt muß das UI ein gutes Stück weiter erst konkret gebaut werden, damit überhaupt ein Sachbezug für die Überlegungen gewonnen werden kann....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#b82856" DESTINATION="ID_73450627" ENDARROW="Default" ENDINCLINATION="-641;29;" ID="Arrow_ID_1593125080" SOURCE="ID_1208499974" STARTARROW="None" STARTINCLINATION="122;76;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492281599624" HGAP="22" ID="ID_1089419591" MODIFIED="1518487921092" TEXT="einfache Lösung" VSHIFT="10">
|
|
<linktarget COLOR="#5f758e" DESTINATION="ID_1089419591" ENDARROW="Default" ENDINCLINATION="40;300;" ID="Arrow_ID_1986823533" SOURCE="ID_813754826" STARTARROW="None" STARTINCLINATION="1031;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1492281610286" ID="ID_1217333147" MODIFIED="1518487921093" TEXT="automatische Instanz-Erzeugung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492281619901" ID="ID_887103826" MODIFIED="1518487921093" TEXT="direkter Aufruf mit CommandDef-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492281659520" ID="ID_488879231" MODIFIED="1518487921093" TEXT="Argument-Resolver für Kontext-Zugriff">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492281675557" ID="ID_1256848300" MODIFIED="1518487921093" TEXT="InvocationState mit Callbacks">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1614378714385" ID="ID_1301868924" MODIFIED="1614378743497" TEXT="Adapter für Event-Quellen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492463479663" ID="ID_1449859033" MODIFIED="1518487921093" TEXT="#1096 passing object IDs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489777406155" HGAP="74" ID="ID_1319269544" MODIFIED="1518487921093" TEXT="Grundstrukturen" VSHIFT="25">
|
|
<node CREATED="1489777414729" ID="ID_464574092" MODIFIED="1518487921093" TEXT="CommandID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489777420817" ID="ID_1146990209" MODIFIED="1518487921093" TEXT="Command access"/>
|
|
<node CREATED="1489777429111" ID="ID_148471534" MODIFIED="1518487921093" TEXT="InvocationTrail">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489777438663" ID="ID_729917092" MODIFIED="1518487921093" TEXT="InteractionState">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1613945185345" ID="ID_357126744" MODIFIED="1613945202633" TEXT="für komplexe kontext-abhängige »Gesten«">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489777502366" ID="ID_1798143241" MODIFIED="1518487921093" TEXT="Command-Definitionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489777517315" ID="ID_922436346" MODIFIED="1518487921093" TEXT="instance management">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489777523266" ID="ID_136474944" MODIFIED="1518487921093" TEXT="trigger Invocation">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1616946525068" FOLDED="true" ID="ID_1115109193" MODIFIED="1616946583608" TEXT="Service für InteractionState">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1616946542052" ID="ID_475841090" MODIFIED="1616946549992" TEXT="GestureState (Service)"/>
|
|
<node CREATED="1616946552171" ID="ID_441985158" MODIFIED="1616946565598" TEXT="vom InteractionDirector konfiguriert"/>
|
|
<node CREATED="1616946568902" ID="ID_290290362" MODIFIED="1616946580856" TEXT="verwaltet Art der Gesten und Scopes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489778159357" HGAP="105" ID="ID_1046149430" MODIFIED="1518487921093" TEXT="Command-Zyklus" VSHIFT="36">
|
|
<node CREATED="1489544225984" ID="ID_695057205" MODIFIED="1518487921093" TEXT="Triggern">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1489544261547" ID="ID_782648362" MODIFIED="1518487921093" TEXT="wer">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544403984" ID="ID_382753424" MODIFIED="1518487921093" TEXT=""ein UI-Element"">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1489544439187" ID="ID_278628492" MODIFIED="1518487921093" TEXT="Beispiel: Toolbar-Button"/>
|
|
<node CREATED="1489544452034" ID="ID_1252070479" MODIFIED="1518487921093" TEXT="Beispiel: Kontextmenü-Eintrag"/>
|
|
<node CREATED="1489544513577" ID="ID_1918576059" MODIFIED="1518487921093" TEXT="Beispiel: Aktion per Keybinding"/>
|
|
<node CREATED="1489544524128" ID="ID_620530211" MODIFIED="1518487921093" TEXT="Beispiel: Signal drag-n-drop"/>
|
|
</node>
|
|
<node CREATED="1489544268018" ID="ID_317151852" MODIFIED="1518487921093" TEXT="was">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544652414" ID="ID_61156502" MODIFIED="1518487921093" TEXT="lokal bekannt"/>
|
|
<node CREATED="1489544640288" ID="ID_1660798945" MODIFIED="1518487921093" TEXT="fest verdrahtet"/>
|
|
<node CREATED="1489544659597" ID="ID_519858607" MODIFIED="1518487921093" TEXT="ggfs. Auswahl aus kleiner Menge"/>
|
|
</node>
|
|
<node CREATED="1489544717333" ID="ID_154924026" MODIFIED="1518487921093" TEXT="falls">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489544722261" ID="ID_1252784107" MODIFIED="1518487921093" TEXT="ausführbar"/>
|
|
<node CREATED="1489544725860" ID="ID_1860103561" MODIFIED="1518487921093" TEXT="d.h. aktiviert"/>
|
|
<node CREATED="1489544826383" ID="ID_1190793385" MODIFIED="1518487921093" TEXT="zwei verschiedene Effekte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489544836757" ID="ID_1364306635" MODIFIED="1576282357984" TEXT="Ausführung abweisen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...stattdessen einen Fehler-Indikator auslösen
|
|
</p>
|
|
<p>
|
|
(Beispiel "in-point fehlt")
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1489544910395" ID="ID_909938815" MODIFIED="1576282357983" TEXT="enable Action">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist eine Reaktion,
|
|
</p>
|
|
<p>
|
|
die von einem managing Ui-Element ausgeführt wird,
|
|
</p>
|
|
<p>
|
|
aber von einem externen State-Change getriggert wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491005020528" ID="ID_1665806173" MODIFIED="1561827465733" TEXT="zu klären">
|
|
<node CREATED="1491005025928" FOLDED="true" ID="ID_1805144008" MODIFIED="1561827465738" TEXT="duplikate Instanzen">
|
|
<linktarget COLOR="#ca978d" DESTINATION="ID_1805144008" ENDARROW="Default" ENDINCLINATION="594;0;" ID="Arrow_ID_191915626" SOURCE="ID_1575553505" STARTARROW="None" STARTINCLINATION="594;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491005039414" ID="ID_378645276" MODIFIED="1492391288793" TEXT="mehrfach newInstance() mit gleicher ID"/>
|
|
<node CREATED="1491005054595" ID="ID_1987692266" MODIFIED="1492391288793" TEXT="drei Möglichkeiten">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1491005058931" ID="ID_1108733153" MODIFIED="1492391288793" TEXT="mit neuem Klon überschreiben"/>
|
|
<node CREATED="1491495291966" ID="ID_703254591" MODIFIED="1492391288793" TEXT="stillschweigend bestehende Instanz ausgeben"/>
|
|
<node CREATED="1491005066706" ID="ID_1990482123" MODIFIED="1492391288793" TEXT="Fehler auslösen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1491495356533" ID="ID_1948190107" MODIFIED="1492391288793" TEXT="einzig sichere Variante">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1491495398895" ID="ID_1958544932" MODIFIED="1492391288793" TEXT="es gibt jetzt auch getInstance"/>
|
|
<node CREATED="1491495405151" ID="ID_988620199" MODIFIED="1492391288793" TEXT="der Client muß geht von Exclusivität aus"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491005071634" ID="ID_178338289" MODIFIED="1492443389733" TEXT="zur Klärung">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1491005078409" ID="ID_1515823316" MODIFIED="1492391288793" TEXT="...muß ich wissen, wie newInstance verwendet wird"/>
|
|
<node CREATED="1491005491226" ID="ID_1986906306" MODIFIED="1576282357983" TEXT="und das hängt von InvocationTrail ab">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
invocationTral wurde aufgegeben.
|
|
</p>
|
|
<p>
|
|
Insofern löst sich dieser Knoten langsam
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1492391213458" ID="ID_1535150206" MODIFIED="1492391288793" TEXT="Differenzierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1492391217961" ID="ID_1152426430" MODIFIED="1492391288793" TEXT="wir erzeugen nun Instanzen transparent">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1492391227720" ID="ID_475537616" MODIFIED="1492391288793" TEXT="d.h. eine reine Command-ID wird stillschweigend geklont"/>
|
|
<node CREATED="1492391240086" ID="ID_687060412" MODIFIED="1492391288793">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
allerdings, wenn man eine <b>explizite</b> Instanz-ID angibt,
|
|
</p>
|
|
<p>
|
|
bleibt es bei der stringenten Fehlerbehandlung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491494748185" FOLDED="true" ID="ID_1589354901" MODIFIED="1518487921093" TEXT="Instanzen registrieren">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1491494779796" ID="ID_1437580350" MODIFIED="1576282357982" TEXT="oder nur Prototypen?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, es geht um die Haupt-Registry für Commands.
|
|
</p>
|
|
<p>
|
|
Wenn wir eine Instanz machen, um Parameter zu binden und sie dann schließlich auszuführen,
|
|
</p>
|
|
<p>
|
|
könnte man dieser Instanz einen Namen geben, und sie in die Haupt-Registry eintragen..
|
|
</p>
|
|
<p>
|
|
Oder man könnte sie anonym verarbeiten, weil Command selber ein smart-Handle ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491494889781" ID="ID_737410509" MODIFIED="1518487921093" TEXT="Analyse">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1491494903779" ID="ID_1388732102" MODIFIED="1518487921093" TEXT="ja">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1491494912266" ID="ID_32553701" MODIFIED="1518487921093" TEXT="Vorteil: Zugriff per-Name"/>
|
|
<node CREATED="1491494928040" ID="ID_76613856" MODIFIED="1518487921093" TEXT="Nachteil: Druck auf die Registry"/>
|
|
<node CREATED="1491494938614" ID="ID_189174601" MODIFIED="1518487921093" TEXT="Nachteil: IDs müssen verwaltet werden"/>
|
|
</node>
|
|
<node CREATED="1491494957020" ID="ID_266987025" MODIFIED="1518487921093" TEXT="nein">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1491494972658" ID="ID_1987998531" MODIFIED="1518487921093" TEXT="Vorteil: spart jede Menge Infrastruktur"/>
|
|
<node CREATED="1491494989215" ID="ID_1302849116" MODIFIED="1518487921093" TEXT="Nachteil: Aufruf-Protokol sehr festgelegt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491495071460" ID="ID_597368143" MODIFIED="1518487921093" TEXT="wir registrieren nicht">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492167970338" FOLDED="true" ID="ID_1983035921" MODIFIED="1613945160418" TEXT="InteractionState ⟺ Invocation-Instance">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist jetzt geklärt.
|
|
</p>
|
|
<p>
|
|
InteractionState == Kontext
|
|
</p>
|
|
<p>
|
|
CommandID.KontextID == Instanz
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492168186700" ID="ID_501823967" MODIFIED="1518487921093" TEXT="InvocationTrail">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492168200986" ID="ID_579400142" MODIFIED="1518487921093" TEXT="ist fest"/>
|
|
<node CREATED="1492168716660" ID="ID_644301358" MODIFIED="1518487921093" TEXT="ist ein front-End"/>
|
|
<node CREATED="1492168226078" ID="ID_1848898275" MODIFIED="1518487921093" TEXT="ist pro Command Instanz"/>
|
|
<node CREATED="1492443100375" ID="ID_1946114739" MODIFIED="1518487921093" TEXT="Konzept aufgegeben">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492168193355" ID="ID_841284230" MODIFIED="1518487921093" TEXT="InteractionState">
|
|
<node CREATED="1492168702845" ID="ID_1065430835" MODIFIED="1518487921093" TEXT="ermöglicht Registrierung"/>
|
|
<node CREATED="1492168535004" ID="ID_93617758" MODIFIED="1518487921093" TEXT="sammelt dynamischen state"/>
|
|
<node CREATED="1492168515983" ID="ID_607058891" MODIFIED="1518487921093" TEXT="bedient einen ganzen Kontext"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492168662947" ID="ID_1857185767" MODIFIED="1518487921093" TEXT="automatisiert die Argument-Versorgung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492169260089" HGAP="30" ID="ID_172791747" MODIFIED="1518487921093" TEXT="usage patterns" VSHIFT="18">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1492169311714" ID="ID_1022909876" MODIFIED="1525124215278" TEXT="fire-and-forget">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492170822396" ID="ID_1848739236" MODIFIED="1492170827759" TEXT="es ist alles klar"/>
|
|
<node CREATED="1492170841401" ID="ID_533459846" MODIFIED="1492170851803" TEXT="kein relevanter Kontext-Bezug"/>
|
|
<node CREATED="1492170863838" ID="ID_1183166030" MODIFIED="1533608414025" TEXT="Beispiel">
|
|
<node CREATED="1492170878863" ID="ID_90242022" MODIFIED="1492170878863" TEXT="globale Menü-Aktion"/>
|
|
<node CREATED="1492170880371" ID="ID_594766034" MODIFIED="1492170903172" TEXT="schließe Session!"/>
|
|
</node>
|
|
<node CREATED="1492170941739" ID="ID_1680428229" MODIFIED="1533608414025" TEXT="Lösung">
|
|
<node CREATED="1492170947610" ID="ID_1247697440" MODIFIED="1492170955606" TEXT="Funktor bereitstellen"/>
|
|
<node CREATED="1492170966264" ID="ID_1737975858" MODIFIED="1492170972019" TEXT="kein Bus-Term notwendig"/>
|
|
<node CREATED="1492170957161" ID="ID_1082986883" MODIFIED="1492170963732" TEXT="Argumente und Trigger in einem"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492169345030" ID="ID_84243440" MODIFIED="1525124215279" TEXT="widget-local">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492171212350" ID="ID_1877488908" MODIFIED="1492171403696" TEXT="fest in einem Widget angesiedelt"/>
|
|
<node CREATED="1492171419802" ID="ID_393104252" MODIFIED="1492171434347" TEXT="lokale Verdrahtung mit etwas Logik"/>
|
|
<node CREATED="1492171517084" ID="ID_45739538" MODIFIED="1492171533742" TEXT="Widget verwendet eigene Command-Instanz"/>
|
|
<node CREATED="1492171540017" ID="ID_110960992" MODIFIED="1492171546252" TEXT="führt aber dann das Binden direkt aus"/>
|
|
<node CREATED="1492171547624" ID="ID_1140206188" MODIFIED="1533608414025" TEXT="Lösung">
|
|
<node CREATED="1492171736734" ID="ID_685211506" MODIFIED="1492443151644" TEXT="lokal bekannte Command-ID"/>
|
|
<node CREATED="1492171753436" ID="ID_1576877235" MODIFIED="1492171764262" TEXT="Widget verwendet sein BusTerm"/>
|
|
</node>
|
|
<node CREATED="1492171774185" HGAP="23" ID="ID_11015489" MODIFIED="1533608414026" TEXT="Unterschied zu fire-and-forget?" VSHIFT="11">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1492171947257" ID="ID_1137709019" MODIFIED="1492171949469" TEXT="kaum einer"/>
|
|
<node CREATED="1492172515236" ID="ID_180853795" MODIFIED="1492172525262" TEXT="Binden ist ein separater Aufruf"/>
|
|
<node CREATED="1492172525946" ID="ID_1399943374" MODIFIED="1492172531749" TEXT="lokales BusTerm verwendet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492169360148" ID="ID_1657289637" MODIFIED="1525124215281" TEXT="context-bound">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1492172593201" ID="ID_1984505306" MODIFIED="1492172600644" TEXT="Command liegt in einem Kontext bereit"/>
|
|
<node CREATED="1492172621613" ID="ID_1344424432" MODIFIED="1492172637206" TEXT="Argument-Bindings werden per Accessor / Rules vorkonfiguriert"/>
|
|
<node CREATED="1492172984411" ID="ID_14678074" MODIFIED="1492173001613" TEXT="InteractionState weiß, ob Command ausführbar ist"/>
|
|
<node CREATED="1492173003905" ID="ID_173633221" MODIFIED="1492173080128" TEXT="von beliebigem Tangible triggerbar"/>
|
|
<node CREATED="1492172679797" ID="ID_1836674310" MODIFIED="1492172684920" TEXT="Aktivierungs-Callbacks"/>
|
|
<node CREATED="1492173454299" HGAP="22" ID="ID_1346472068" MODIFIED="1533608414026" TEXT="Lösung" VSHIFT="10">
|
|
<node CREATED="1492173481023" ID="ID_285008060" MODIFIED="1492173494690" TEXT="InteractionState pro Kontext(ID)"/>
|
|
<node CREATED="1492173497269" ID="ID_365694462" MODIFIED="1492173519950" TEXT="speichert binding patterns pro Command"/>
|
|
<node CREATED="1492173637978" ID="ID_1696162932" MODIFIED="1492173647765" TEXT="BindingPattern erkennt Ausführbarkeit"/>
|
|
<node CREATED="1492173787950" ID="ID_318157835" MODIFIED="1492173802664" TEXT="Command-Instanz wird erst spät (bei Bedarf) gebildet"/>
|
|
<node CREATED="1492173813466" ID="ID_1383483945" MODIFIED="1492173828300" TEXT="sie wird sofort vom InteractionState fertig parametrisiert"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492206477974" HGAP="28" ID="ID_1639842825" MODIFIED="1533608414027" TEXT="Zukunft" VSHIFT="14">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1492206491525" ID="ID_1000204628" MODIFIED="1492206500103" TEXT="das wird einmal essentiell"/>
|
|
<node CREATED="1492206500643" ID="ID_1716565687" MODIFIED="1492206505343" TEXT="aber noch nicht gleich benötigt"/>
|
|
<node CREATED="1492206505907" ID="ID_427665863" MODIFIED="1492206512494" TEXT="und im Moment auch nicht abschätzbar"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492173833368" HGAP="42" ID="ID_769512112" MODIFIED="1525124215283" TEXT="widersprüchlich" VSHIFT="12">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1492173862203" ID="ID_1492707816" MODIFIED="1492173876661" TEXT="wozu die ganzen UI-Bus-Nachrichten">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1492173887792" ID="ID_552249287" MODIFIED="1576282357981" TEXT="wozu Auslösung über BusTerm eines Widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn es doch offenbar für den "fire-and-forget"-Fall
|
|
</p>
|
|
<p>
|
|
genauso gut möglich ist, über eine zentrale Stelle zu triggern.
|
|
</p>
|
|
<p>
|
|
Nebenläufigkeit ist kein Argument (da das UI single-threaded läuft)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1492174006016" ID="ID_1942935948" MODIFIED="1492174016504" TEXT="wozu getrennter Parametrisierungs-Call">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1492174212708" ID="ID_716714989" MODIFIED="1492174238508" TEXT="man könnte auf die bang!-Nachricht verzichten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492205847909" ID="ID_20433747" MODIFIED="1492205860240" TEXT="entfernt eine Menge Komplexität">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1492205861275" ID="ID_1520439061" MODIFIED="1492205867150" TEXT="der dämliche Visitor ist weg!"/>
|
|
<node COLOR="#338800" CREATED="1492205867738" ID="ID_1598058671" MODIFIED="1492206444561" TEXT="sofort ausgeführt">
|
|
<linktarget COLOR="#78d7bb" DESTINATION="ID_1598058671" ENDARROW="Default" ENDINCLINATION="406;0;" ID="Arrow_ID_1788740270" SOURCE="ID_1018158934" STARTARROW="None" STARTINCLINATION="383;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492174243863" ID="ID_900555701" MODIFIED="1492174267140">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber: Parametrisierung <i>könnte</i> partiell sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492174268716" ID="ID_995073060" MODIFIED="1492174273527" TEXT="not yet implemented"/>
|
|
<node CREATED="1492174274067" ID="ID_1334398441" MODIFIED="1492174279407" TEXT="YAGNI"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492205884680" HGAP="22" ID="ID_1123687976" MODIFIED="1492205904295" TEXT="Schlußfolgerung" VSHIFT="15">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1492205906237" ID="ID_900884756" MODIFIED="1533608414027" TEXT="der UI-Bus ist eine Architektur-Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1492205915980" ID="ID_1147449569" MODIFIED="1492205922022" TEXT="es geht hier nicht um Performance"/>
|
|
<node CREATED="1492205922851" ID="ID_64631579" MODIFIED="1492205930525" TEXT="der direkte Auführungs-Pfad ist egal"/>
|
|
<node CREATED="1492206055640" ID="ID_1375005290" MODIFIED="1492206059883" TEXT="es geht um die Struktur"/>
|
|
</node>
|
|
<node CREATED="1492205953694" ID="ID_801761661" MODIFIED="1533608414028" TEXT="deshalb werden Command nicht "hintenrum" getriggert">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1492206398465" ID="ID_255699527" MODIFIED="1492206403349" TEXT="kein fire-and-forget"/>
|
|
<node CREATED="1492206423622" ID="ID_1494333022" MODIFIED="1492206428977" TEXT="widget-local ist immer gut genug"/>
|
|
<node CREATED="1492206404649" ID="ID_62238358" MODIFIED="1492206413723" TEXT="man kann den UI-Bus direkt nutzen"/>
|
|
</node>
|
|
<node CREATED="1492205969332" ID="ID_1018158934" MODIFIED="1492206444561" TEXT="aber auf die Trennung in bind / bang kann man verzichten">
|
|
<arrowlink COLOR="#78d7bb" DESTINATION="ID_1598058671" ENDARROW="Default" ENDINCLINATION="406;0;" ID="Arrow_ID_1788740270" STARTARROW="None" STARTINCLINATION="383;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1492268950187" HGAP="22" ID="ID_768535627" MODIFIED="1492269713606" TEXT="Rolle des InvocationTrail nicht klar" VSHIFT="6">
|
|
<arrowlink COLOR="#a24839" DESTINATION="ID_407290509" ENDARROW="Default" ENDINCLINATION="-90;-238;" ID="Arrow_ID_924621068" STARTARROW="None" STARTINCLINATION="-201;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492268981885" FOLDED="true" HGAP="105" ID="ID_1743832326" MODIFIED="1561827465755" TEXT="Design-Kritik" VSHIFT="-46">
|
|
<arrowlink COLOR="#f7335a" DESTINATION="ID_43582318" ENDARROW="Default" ENDINCLINATION="-123;-43;" ID="Arrow_ID_601519634" STARTARROW="Default" STARTINCLINATION="-63;109;"/>
|
|
<linktarget COLOR="#7b7696" DESTINATION="ID_1743832326" ENDARROW="Default" ENDINCLINATION="321;-3493;" ID="Arrow_ID_741454137" SOURCE="ID_1824168791" STARTARROW="None" STARTINCLINATION="-1170;44;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492269138424" ID="ID_1682612433" MODIFIED="1492269153284" TEXT="gefährlich stark vom komplexen Fall getrieben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1492269185449" ID="ID_695030032" MODIFIED="1492269196091" TEXT="die Bedeutung der Command-Instanz ist übertrieben">
|
|
<node CREATED="1492269414362" ID="ID_1011798630" MODIFIED="1492269421708" TEXT="sie ist notwendig wegen Multithreading"/>
|
|
<node CREATED="1492269422257" ID="ID_921483875" MODIFIED="1492269432251" TEXT="aber nur im ProcDispatcher"/>
|
|
<node CREATED="1492269451181" ID="ID_800020285" MODIFIED="1492269548819">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sie wird nicht zum <i>Parameter-Sammeln</i> verwendet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492269433415" ID="ID_55077056" MODIFIED="1492269446161" TEXT="es würde genügen, sie beim Einfügen transparent zu erzeugen"/>
|
|
<node CREATED="1492269567485" ID="ID_661748666" MODIFIED="1492269585470" TEXT="Ausnahme: context-bound">
|
|
<node CREATED="1492269751716" ID="ID_868922268" MODIFIED="1492269757167" TEXT="hier ist es eine Trenn-ID"/>
|
|
<node CREATED="1492269757659" ID="ID_1570623233" MODIFIED="1492269772333" TEXT="mehrere Control-Systeme können koexistieren"/>
|
|
</node>
|
|
<node CREATED="1492269922724" ID="ID_806519829" MODIFIED="1576282357981" TEXT="Idee: on demand">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...eine Instanz wird dann erzeugt, wenn sie notwendig wird.
|
|
</p>
|
|
<p>
|
|
Sie kann vom UI-Command-Framework erzeugt werden,
|
|
</p>
|
|
<p>
|
|
sie wird automatisch erzeugt, sofern Parameter gebunden werden,
|
|
</p>
|
|
<p>
|
|
oder ein Command an den Dispatcher übergeben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1492270021119" ID="ID_1461150467" MODIFIED="1492270028429" TEXT="praktikabel?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1492270033509" ID="ID_1721416097" MODIFIED="1492270045552" TEXT="würde fall-Back auf globale Commands beseitigen"/>
|
|
<node CREATED="1492270075064" ID="ID_814785630" MODIFIED="1492270086423" TEXT="wäre eigentlich sauberer als dieser Fall-back">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1492270046164" ID="ID_191900745" MODIFIED="1492270058746" TEXT="das könnte viele Unit-Tests betreffen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492269260487" ID="ID_1242844034" MODIFIED="1492270114043" TEXT="es gibt kein wirkliches "Protokoll"">
|
|
<node CREATED="1492270115626" ID="ID_1073186006" MODIFIED="1492270139603" TEXT="...jenseits von »Binden und Ausführen«"/>
|
|
<node CREATED="1492270174242" ID="ID_884795984" MODIFIED="1492270187724" TEXT="die Varianten sind bis zur Beliebigkeit "offen""/>
|
|
<node CREATED="1492270193216" ID="ID_667627556" MODIFIED="1492270205594" TEXT="erst der reale Gebrauch wird hier Klarheit schaffen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492269210918" ID="ID_420603812" MODIFIED="1492269221064" TEXT="CmdAccess wirkt wie eine unnötige Last">
|
|
<node CREATED="1492270239793" ID="ID_1729040008" MODIFIED="1492270283358" TEXT="ist notwendig als factory für InteractionState">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1492270258487" ID="ID_108374652" MODIFIED="1492270262186" TEXT="war als Facade gedacht"/>
|
|
<node CREATED="1492270262710" ID="ID_1958798996" MODIFIED="1492270276548" TEXT="macht aber den einfachen Fall verwirrend">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492269372144" ID="ID_1386411981" MODIFIED="1492269383826" TEXT="Konkurrenz zwischen CmdAccess und UI-Bus">
|
|
<node CREATED="1492270323718" ID="ID_1980829815" MODIFIED="1492270337152" TEXT="suggeriert »Zugriff auf Command«">
|
|
<node CREATED="1492270363992" ID="ID_386306013" MODIFIED="1492270382113" TEXT="man kommt aber nicht an Commands ran"/>
|
|
<node CREATED="1492270382565" ID="ID_1485765410" MODIFIED="1492270398351" TEXT="diese sollen unter dem Bus bleiben, in Proc"/>
|
|
<node CREATED="1492270411354" ID="ID_947388027" MODIFIED="1492270415125" TEXT="man bekommt nur eine ID"/>
|
|
<node CREATED="1492270415593" ID="ID_1624406053" MODIFIED="1492270424495" TEXT="die man schon kennen muß, um sie zu bekommen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492270339851" ID="ID_238907164" MODIFIED="1492270358381" TEXT="suggeriert »Ausführen von Commands«">
|
|
<node CREATED="1492271004097" ID="ID_511583689" MODIFIED="1492271014907" TEXT="muß man aber selber machen, via BusTerm"/>
|
|
<node CREATED="1492271017087" ID="ID_321529761" MODIFIED="1492271024673" TEXT="dafür braucht man nur die ID">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1492271198846" ID="ID_199345824" MODIFIED="1492271206009" TEXT="die Nachricht wird in Tangible generiert"/>
|
|
<node CREATED="1492271027654" ID="ID_42222873" MODIFIED="1492271052893" TEXT="im komplexen Fall könte CmdAccess Parameter beisteuern"/>
|
|
</node>
|
|
<node CREATED="1492281019743" ID="ID_948470933" MODIFIED="1492281049526">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
grundlegender Widerspruch
|
|
</p>
|
|
<p>
|
|
zwischen Command-Control-Interface
|
|
</p>
|
|
<p>
|
|
und Messaging
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492269623805" ID="ID_407290509" MODIFIED="1492444081051" TEXT="InvocationTrail ist fragwürdig">
|
|
<linktarget COLOR="#a24839" DESTINATION="ID_407290509" ENDARROW="Default" ENDINCLINATION="-90;-238;" ID="Arrow_ID_924621068" SOURCE="ID_768535627" STARTARROW="None" STARTINCLINATION="-201;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1492281083479" ID="ID_970079498" MODIFIED="1492281138259" TEXT="fire-and-forget: superfluous"/>
|
|
<node CREATED="1492281103684" ID="ID_135245437" MODIFIED="1576282357980" TEXT="widget-bound: overengineered">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und kaum erkennbarer Nutzen.
|
|
</p>
|
|
<p>
|
|
Der einzige Nutzfall wäre ein "this"-Parameter.
|
|
</p>
|
|
<p>
|
|
Den kann man aber mit geeigneter Syntax auch direkt angeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1492281124705" ID="ID_256590492" MODIFIED="1576282357980" TEXT="context-bound: different structure needed">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier müßte der InvocationTrail die aufgesammelten Argumente transportieren.
|
|
</p>
|
|
<p>
|
|
allein <i>dafür</i> genügt eine GenNode
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492281297561" ID="ID_627059506" MODIFIED="1518487921093" TEXT="Schlußfolgerung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1492281320758" ID="ID_1465764553" MODIFIED="1518487921093" TEXT="InvocationTrail fällt weg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492281327277" ID="ID_1090150746" MODIFIED="1518487921093" TEXT="Aufruf erfolgt mit reiner Command-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492281338555" ID="ID_220910293" MODIFIED="1518487921093" TEXT="Instanzen werden automatisch generiert">
|
|
<arrowlink COLOR="#626a9e" DESTINATION="ID_1660020661" ENDARROW="Default" ENDINCLINATION="-324;0;" ID="Arrow_ID_876356993" STARTARROW="None" STARTINCLINATION="-687;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1492281383613" ID="ID_143339688" MODIFIED="1518487921093" TEXT="CmdAccess wird für den komplexen Fall umgewidmet">
|
|
<linktarget COLOR="#6c9dbe" DESTINATION="ID_143339688" ENDARROW="Default" ENDINCLINATION="2023;-1563;" ID="Arrow_ID_1767017735" SOURCE="ID_1013004860" STARTARROW="None" STARTINCLINATION="303;19;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1492281402666" ID="ID_1263822028" MODIFIED="1518487921093" TEXT="es bleibt ein Access-front-End"/>
|
|
<node COLOR="#435e98" CREATED="1492281417025" ID="ID_1229681605" MODIFIED="1518487921093" TEXT="der Name wird angepaßt → CmdContext">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1492281425672" ID="ID_1330862297" MODIFIED="1518487921093" TEXT="es dient zum Konfigurieren eines Kontextes"/>
|
|
<node CREATED="1492281434678" ID="ID_1036338249" MODIFIED="1518487921093" TEXT="für Zugriff auf den InteractionState"/>
|
|
<node CREATED="1492281448845" ID="ID_1396633899" MODIFIED="1518487921093" TEXT="für Callback-Registrierung"/>
|
|
<node CREATED="1492281466282" ID="ID_1012579063" MODIFIED="1518487921093" TEXT="Callbacks schicken direkt eine GenNode"/>
|
|
</node>
|
|
<node CREATED="1616946594556" ID="ID_54239665" MODIFIED="1616946613439" TEXT="das System der komplexeren Interaktionen wird ein reiner UI-Belang">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1616946615845" ID="ID_554876862" MODIFIED="1616946628768" TEXT="GestureState (Service im InteractionDirector)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616946630071" ID="ID_303553781" MODIFIED="1616946650346" TEXT="dort: Klassifkation und Zuordnung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616946652692" ID="ID_1401408143" MODIFIED="1616946776521" TEXT="erster Entwurf">
|
|
<arrowlink COLOR="#2381d3" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="-533;1807;" ID="Arrow_ID_1818387200" STARTARROW="None" STARTINCLINATION="1260;198;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#252298" CREATED="1489546623162" HGAP="-24" ID="ID_1622574347" MODIFIED="1575131582794" TEXT="was wird gebraucht" VSHIFT="21">
|
|
<linktarget COLOR="#352c7d" DESTINATION="ID_1622574347" ENDARROW="Default" ENDINCLINATION="-461;-3358;" ID="Arrow_ID_1512127407" SOURCE="ID_1401258681" STARTARROW="None" STARTINCLINATION="1819;0;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="help"/>
|
|
<node COLOR="#f10a1a" CREATED="1489546678250" ID="ID_228157787" MODIFIED="1518487921093" TEXT="Vorsicht UI-Programmierung">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1489546705798" ID="ID_43582318" MODIFIED="1518487921093" TEXT="keine neue Programmiersprache entwerfen">
|
|
<linktarget COLOR="#f7335a" DESTINATION="ID_43582318" ENDARROW="Default" ENDINCLINATION="-123;-43;" ID="Arrow_ID_601519634" SOURCE="ID_1743832326" STARTARROW="Default" STARTINCLINATION="-63;109;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1489546724892" ID="ID_1763781107" MODIFIED="1518487921093" TEXT="muß letztlich explizit sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489546837172" ID="ID_665817500" MODIFIED="1518487921093" TEXT="aber">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1489546843356" ID="ID_1556795494" MODIFIED="1518487921093" TEXT="ich will Gestaltbarkeit"/>
|
|
<node CREATED="1489546855202" ID="ID_1824748232" MODIFIED="1518487921093" TEXT="ich will Konfigurierbarkeit"/>
|
|
</node>
|
|
<node CREATED="1489546994743" FOLDED="true" ID="ID_1851585461" MODIFIED="1561827465765" TEXT="im Einzelnen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1489777326111" ID="ID_497480483" MODIFIED="1525124215293" TEXT="CommandID">
|
|
<node CREATED="1489715248861" ID="ID_999876408" MODIFIED="1492167362880" TEXT="brauche">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1489715276057" ID="ID_878658276" MODIFIED="1492167327317" TEXT="Basis-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489715297406" ID="ID_601143379" MODIFIED="1492167324342" TEXT="dekoriert durch Invocation-Trail">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489715320435" ID="ID_1521007439" MODIFIED="1491003112168" TEXT="dekoriert durch laufende Nr">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489715326210" ID="ID_1820734132" MODIFIED="1492167321470" TEXT="guten Hash von diesen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492167331337" ID="ID_1262753230" MODIFIED="1492167341460" TEXT="lib::Symbol">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489715461992" ID="ID_115322523" MODIFIED="1491003142993" TEXT=""leere" Basis-ID ohne lfdNr">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489715591582" ID="ID_256884690" MODIFIED="1491003145193" TEXT="inkrement der lfdNr">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489716825126" HGAP="38" ID="ID_969368347" MODIFIED="1492205500240" TEXT="Ansätze" VSHIFT="-1">
|
|
<node CREATED="1489716845980" ID="ID_816994670" MODIFIED="1489718875217" TEXT="Command-ID-Token">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1489716859034" ID="ID_1342799459" MODIFIED="1489716867940" TEXT="SubID o.ä."/>
|
|
<node CREATED="1489716870000" ID="ID_907818022" MODIFIED="1489716875547" TEXT="Wert-Semantik"/>
|
|
<node CREATED="1489716876183" ID="ID_880911498" MODIFIED="1489716883650" TEXT="enthält die lfdNr"/>
|
|
</node>
|
|
<node CREATED="1489717087626" ID="ID_1304379039" MODIFIED="1489718872841" TEXT="Registrierungs-Instanz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1489717094881" ID="ID_890501908" MODIFIED="1489717104332" TEXT="Referenz-Semantik"/>
|
|
<node CREATED="1489717108735" ID="ID_142693821" MODIFIED="1489717115730" TEXT="enthält direkt den Zähler"/>
|
|
<node CREATED="1489717116246" ID="ID_1967376157" MODIFIED="1489717129232" TEXT="brauche front-End-Token"/>
|
|
</node>
|
|
<node CREATED="1489717203882" ID="ID_199366549" MODIFIED="1489718870140" TEXT="eingebettete Information">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1489717237622" ID="ID_1384169115" MODIFIED="1492167147558" TEXT="Command + KontextID in Hashtable"/>
|
|
<node CREATED="1489717304621" ID="ID_1984888825" MODIFIED="1489717311967" TEXT="CmdInstanceManager hat Hashtable"/>
|
|
<node CREATED="1489717425684" ID="ID_205251145" MODIFIED="1489717436846" TEXT="Instance-Management komplett eingekapselt"/>
|
|
<node CREATED="1489717312532" ID="ID_1911293548" MODIFIED="1492443198294" TEXT="key ist Basis-Cmd-ID + Kontext-ID"/>
|
|
<node CREATED="1489717395312" ID="ID_1098297494" MODIFIED="1533608414028" TEXT="InvocationTrail speichert nur diese ID">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492443231533" ID="ID_648420580" MODIFIED="1492443237416" TEXT="Konzept aufgegeben"/>
|
|
<node CREATED="1492443238668" ID="ID_516547594" MODIFIED="1492443243711" TEXT="unnötige Indirektion"/>
|
|
</node>
|
|
<node CREATED="1489717406447" ID="ID_1938762085" MODIFIED="1533608414028" TEXT="Bang sendet nur diese ID">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1492205513779" ID="ID_36883868" MODIFIED="1492205520773" TEXT="Bang gibts nicht mehr"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489717768805" HGAP="79" ID="ID_119293304" MODIFIED="1492169049860" TEXT="Entscheidung" VSHIFT="4">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_119293304" ENDARROW="Default" ENDINCLINATION="153;-248;" ID="Arrow_ID_1691148413" SOURCE="ID_319912426" STARTARROW="None" STARTINCLINATION="312;0;"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1489717797353" ID="ID_899130819" MODIFIED="1489717807068" TEXT="die ersten beiden sind unötig generisch"/>
|
|
<node CREATED="1489717807872" ID="ID_1209104496" MODIFIED="1489717818826" TEXT="wir bauen ohnehin den Command-Cycle fest ein"/>
|
|
<node CREATED="1489717844003" ID="ID_97055123" MODIFIED="1489717853605" TEXT="letztgenannte Lösung ist auf den Punkt"/>
|
|
<node CREATED="1489717927279" ID="ID_845301501" MODIFIED="1489717959263" TEXT="Command-ID erfüllt keine regulierende Funktion"/>
|
|
<node CREATED="1491003369611" ID="ID_854080320" MODIFIED="1576282357979" TEXT="Instanz-Management funktioniert anonym">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil es zu jedem InvocationPath
|
|
</p>
|
|
<p>
|
|
zu jeder Zeit nur eine "offene" Instanz gibt.
|
|
</p>
|
|
<p>
|
|
Also genügt es, einen anonymen Klon dieser Instanz zu halten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1489717960331" ID="ID_1849715968" MODIFIED="1489717991603" TEXT="viel wichtiger sind die Aktivierungs-Regeln"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489546998918" HGAP="43" ID="ID_668687712" MODIFIED="1576282357978" TEXT="Aktivierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist:
|
|
</p>
|
|
<p>
|
|
Ein UI-Control wird <i>aktivierbar,</i> weil das zugrundeliegende Command
|
|
</p>
|
|
<p>
|
|
alle seine Argumente aus dem aktuellen Kontext befriedigen kann
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Beispiel: Menü-Eintrag "create duplicate"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1489547002918" ID="ID_728456926" MODIFIED="1518487921094" TEXT="Callback installieren"/>
|
|
<node CREATED="1489547016564" ID="ID_41325273" MODIFIED="1518487921094" TEXT="Anfrage: ist dies aktivierbar?"/>
|
|
</node>
|
|
<node CREATED="1489547086458" HGAP="48" ID="ID_1858100202" MODIFIED="1525124215294" TEXT="Argumente" VSHIFT="-1">
|
|
<node CREATED="1489547096857" ID="ID_184341736" MODIFIED="1492167490875" TEXT=""gib mir die Argumente!"">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1489547170463" ID="ID_1981926549" MODIFIED="1489547178266" TEXT="wirklich?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1489547179254" ID="ID_192306839" MODIFIED="1489547197378" TEXT="ist das der richtige Ansatz?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1489547208282" ID="ID_99440101" MODIFIED="1489690731089" TEXT="läßt sich das überhaupt je realisieren?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489547112255" ID="ID_270498008" MODIFIED="1576282357978" TEXT="generische Rollen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Idee ist hier,
|
|
</p>
|
|
<p>
|
|
daß diese generischen Rollen bereits in der Einrichtung der Command-Definition verwendet werden.
|
|
</p>
|
|
<p>
|
|
Das heißt, für einen bestimmten Invocation-Trail legt man fest,
|
|
</p>
|
|
<p>
|
|
daß ein bestimmtes Argument an eine gewisse Rolle gebunden wird,
|
|
</p>
|
|
<p>
|
|
oder andernfalls einen bestimmten Namen bekommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489547124597" ID="ID_408090908" MODIFIED="1489547128224" TEXT="das Subjekt"/>
|
|
<node CREATED="1489547128837" ID="ID_865724442" MODIFIED="1489547131120" TEXT="der Container"/>
|
|
<node CREATED="1489547498122" ID="ID_1669169317" MODIFIED="1489547504003" TEXT="die Dauer"/>
|
|
<node CREATED="1489547283807" ID="ID_559442696" MODIFIED="1489547286467" TEXT="der Wert"/>
|
|
</node>
|
|
<node CREATED="1489547506625" ID="ID_1063184971" MODIFIED="1489719071018" TEXT="konkret....">
|
|
<arrowlink COLOR="#4d2a67" DESTINATION="ID_1622068086" ENDARROW="Default" ENDINCLINATION="-9;-36;" ID="Arrow_ID_717312728" STARTARROW="None" STARTINCLINATION="15;49;"/>
|
|
<node CREATED="1489547511224" ID="ID_954080965" MODIFIED="1489547530586" TEXT="das UI-Element weiß explizit was gebraucht wird"/>
|
|
<node CREATED="1489547542852" ID="ID_271774122" MODIFIED="1489547548943" TEXT="und stellt selber das Tupel zusammen"/>
|
|
<node CREATED="1489547574504" ID="ID_49978062" MODIFIED="1489547582019" TEXT="oder ruft einen Funktor auf"/>
|
|
<node CREATED="1489547588102" ID="ID_985840704" MODIFIED="1489547597465" TEXT="wodurch die Argument-Typen dokumentiert sind"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489548252324" HGAP="47" ID="ID_1622068086" MODIFIED="1525124215295" TEXT="das könnte der InvocationTrail sein" VSHIFT="27">
|
|
<linktarget COLOR="#4d2a67" DESTINATION="ID_1622068086" ENDARROW="Default" ENDINCLINATION="-9;-36;" ID="Arrow_ID_717312728" SOURCE="ID_1063184971" STARTARROW="None" STARTINCLINATION="15;49;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489719178053" ID="ID_1509284806" MODIFIED="1489719184696" TEXT="hat Cmd-ID + eigene ID"/>
|
|
<node CREATED="1489719186276" ID="ID_929080602" MODIFIED="1489719196230" TEXT="kann entscheiden ob ausführbar"/>
|
|
<node CREATED="1489719200330" ID="ID_840062807" MODIFIED="1489719208197" TEXT="hat Argument-Accessor"/>
|
|
<node COLOR="#5e427f" CREATED="1489719212976" HGAP="-52" ID="ID_949699860" MODIFIED="1614373195459" TEXT="noch offen" VSHIFT="45">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="closed"/>
|
|
<node CREATED="1489719257426" ID="ID_1618753270" MODIFIED="1576282357977" TEXT="wer erzeugt den InvocationTrail">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...eben!
|
|
</p>
|
|
<p>
|
|
Diese Frage hat dann dazu geführt,
|
|
</p>
|
|
<p>
|
|
daß ich das ganze Konzept "InvocationTrail"
|
|
</p>
|
|
<p>
|
|
wieder komplett zurückgebaut habe
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489719267537" ID="ID_963145148" MODIFIED="1489719291065" TEXT="was ist bereits vom Command her definiert"/>
|
|
<node CREATED="1489719292181" ID="ID_804928267" MODIFIED="1489719304359" TEXT="kann es mehrere konkurrierende Auslegungen geben?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492281599624" ID="ID_813754826" MODIFIED="1518487921094" TEXT="einfache Lösung">
|
|
<arrowlink COLOR="#5f758e" DESTINATION="ID_1089419591" ENDARROW="Default" ENDINCLINATION="40;300;" ID="Arrow_ID_1986823533" STARTARROW="None" STARTINCLINATION="1031;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1492281610286" ID="ID_1542647024" MODIFIED="1518487921094" TEXT="automatische Instanz-Erzeugung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1492281619901" ID="ID_423372741" MODIFIED="1518487921094" TEXT="direkter Aufruf mit CommandDef-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1492281659520" ID="ID_1742758477" MODIFIED="1518487921094" TEXT="Argument-Resolver für Kontext-Zugriff"/>
|
|
<node CREATED="1492281675557" ID="ID_1809773326" MODIFIED="1518487921094" TEXT="InvocationState mit Callbacks"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616946803314" HGAP="-20" ID="ID_1642737972" MODIFIED="1616946817268" TEXT="System für UI-Gesten" VSHIFT="13">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#2b95af" CREATED="1616946819438" ID="ID_752209156" MODIFIED="1617979552380" TEXT="Kontext-Zuordnung ist reiner UI-Belang">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1617979322413" FOLDED="true" ID="ID_512298093" MODIFIED="1617979760982" TEXT="Gesten sollen im Lumiera-UI eine zentrale Rolle spielen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1617979344655" FOLDED="true" ID="ID_1851586839" MODIFIED="1617979758591" TEXT="deshalb wird die Grundstruktur im Projekt selber entwickelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wir versuchen gar nicht erst, »etwas Bestehendes zu nutzen« ― sondern wir machen <i>unser eigenes Ding.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1617979579143" ID="ID_748564389" MODIFIED="1617979590729" TEXT="später sollen Gesten-Frameworks mit integriert werden"/>
|
|
<node CREATED="1617979591490" ID="ID_1553590368" MODIFIED="1617979602103" TEXT="aber nur insofern das einen Mehrwert bringt"/>
|
|
<node CREATED="1617979616050" ID="ID_1797789056" LINK="https://developer.gnome.org/gtk3/stable/chap-input-handling.html#event-controllers-and-gestures" MODIFIED="1617979753210" TEXT="Beispiel: GTK Gesten-Controller">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617979423537" ID="ID_1042187795" MODIFIED="1617979467715" TEXT="Gesten sollen eine Zwischenschicht bilden ― oberhalb des konkreten Interaktions-Systems"/>
|
|
<node CREATED="1617979477669" ID="ID_1946864730" MODIFIED="1617979494327" TEXT="die Koordination von Gesten darf nicht über die Einzel-Widgets verstreut sein"/>
|
|
<node CREATED="1617979495483" ID="ID_118392564" MODIFIED="1617979506317" TEXT="Gesten werden nach dem Muster eines Aussage-Satzes modelliert"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1616946831044" ID="ID_160240965" MODIFIED="1616946847970" TEXT="angelegt im GestureState (Service im InteractionDirector)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1616946854861" ID="ID_273700034" MODIFIED="1616947006922" TEXT="Thema wartet auf eine viel weiter gediehene konkrete Implementierung">
|
|
<arrowlink COLOR="#565ec8" DESTINATION="ID_1000039605" ENDARROW="Default" ENDINCLINATION="-1327;-47;" ID="Arrow_ID_33928560" STARTARROW="None" STARTINCLINATION="-397;16;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616946652692" ID="ID_1570729566" MODIFIED="1616947147359" TEXT="Entwurf "drag clip": Gesten-Controller vorläufig fest gedrahtet">
|
|
<arrowlink COLOR="#5f7a9f" DESTINATION="ID_1714668959" ENDARROW="Default" ENDINCLINATION="-533;1807;" ID="Arrow_ID_1378120058" STARTARROW="None" STARTINCLINATION="1673;76;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489781392694" ID="ID_1312397991" MODIFIED="1518487921094" TEXT="Festlegungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1489781404925" ID="ID_1918933171" MODIFIED="1518487921094" TEXT="Command-ID">
|
|
<node CREATED="1489781409876" ID="ID_1973020417" MODIFIED="1518487921094" TEXT="Basis-ID ist ein Symbol"/>
|
|
<node CREATED="1491003215783" ID="ID_1537560721" MODIFIED="1518487921094" TEXT="es wird mit einer Invocation-ID dekoriert"/>
|
|
<node CREATED="1491003228101" ID="ID_661472357" MODIFIED="1518487921094" TEXT="wir brauchen keine laufende Nummer">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1491003237108" ID="ID_1167308664" MODIFIED="1518487921094" TEXT="Instance-Management funktioniert anonym"/>
|
|
</node>
|
|
<node CREATED="1489781426978" ID="ID_1543445405" MODIFIED="1518487921094" TEXT="konkrete Definition">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1489781443184" ID="ID_966382785" MODIFIED="1518487921094" TEXT="Ort">
|
|
<node CREATED="1489781447639" ID="ID_588776773" MODIFIED="1518487921094" TEXT="proc/cmd/*-cmd.cpp"/>
|
|
<node CREATED="1489781476355" ID="ID_1953562265" MODIFIED="1518487921094" TEXT="Namespace proc::cmd"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1489781611257" FOLDED="true" ID="ID_179887792" MODIFIED="1561827465774" TEXT="brauche">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1489781616257" ID="ID_1645536558" MODIFIED="1518487921094" TEXT="Schema für ID-Konstanten"/>
|
|
<node CREATED="1489781628743" ID="ID_1733247268" MODIFIED="1518487921094" TEXT="Mechanismus, der die Definition treibt"/>
|
|
<node CREATED="1489781758389" ID="ID_1124650374" MODIFIED="1533608414029" TEXT="gewünscht">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1489781775443" ID="ID_379002135" MODIFIED="1518487921094" TEXT="Name und Definition nahe zusammen"/>
|
|
<node CREATED="1489781769500" ID="ID_998243238" MODIFIED="1518487921094" TEXT="keine Redundanz"/>
|
|
<node CREATED="1489781902770" ID="ID_1568226956" MODIFIED="1518487921094" TEXT="gut lesbar"/>
|
|
<node CREATED="1489781907906" ID="ID_1206063892" MODIFIED="1518487921094" TEXT="debuggbar"/>
|
|
<node CREATED="1489781923640" ID="ID_241861600" MODIFIED="1518487921094" TEXT="kommentierbar (Doxygen)"/>
|
|
<node CREATED="1489785114574" ID="ID_241665479" MODIFIED="1518487921094" TEXT="nur unsichtbare Magie"/>
|
|
</node>
|
|
<node CREATED="1489785137083" ID="ID_1466955376" MODIFIED="1533608414033" TEXT="Möglichkeiten">
|
|
<node CREATED="1489785163216" ID="ID_1992894903" MODIFIED="1489785168547" TEXT="zu Fuß...">
|
|
<node CREATED="1489785199131" ID="ID_111396262" MODIFIED="1489785207662" TEXT="ID-Konstanten im Header deklarieren"/>
|
|
<node CREATED="1489785208298" ID="ID_315886293" MODIFIED="1489785222188" TEXT="ID-Konstanten in der jeweiligen translation-Unit definieren"/>
|
|
<node CREATED="1489785250500" ID="ID_464247309" MODIFIED="1489785259671" TEXT="Lifecycle-Hook installieren..."/>
|
|
<node CREATED="1489785260523" ID="ID_1306260885" MODIFIED="1489785270590" TEXT="..der eine Registrierungs-Funktion aufruft"/>
|
|
<node CREATED="1489785276137" ID="ID_1526475921" MODIFIED="1489785285307" TEXT="in dieser die CommandDef absetzen"/>
|
|
<node CREATED="1489785285872" ID="ID_1304462599" MODIFIED="1489785296938" TEXT="und als Command-ID die definierte Konstante verwenden"/>
|
|
</node>
|
|
<node CREATED="1489786040203" ID="ID_1417335273" MODIFIED="1489786045870" TEXT="Vereinfachungen">
|
|
<node CREATED="1489786055057" ID="ID_565306146" MODIFIED="1489786059852" TEXT="decl/def">
|
|
<node CREATED="1489786238273" ID="ID_1957761383" MODIFIED="1489786331600" TEXT="marker-Makro"/>
|
|
<node CREATED="1489786245024" ID="ID_430222749" MODIFIED="1489786255810" TEXT="alle Definitionen in Makros einwickeln"/>
|
|
<node CREATED="1489786393908" ID="ID_1345826013" MODIFIED="1576282357977" TEXT="spezielle Inclusion-Rituale">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vermutlich läuft es immer darauf hinaus
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
daß cmd.hpp die Implementierungs-Einheiten includiert
|
|
</li>
|
|
<li>
|
|
oder daß in einer ausgezeichneten Impl-Einheit das marker-Makro gesetzt wird und dann cmd.hpp includiert wird
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489789880260" ID="ID_768121026" MODIFIED="1489789887822" TEXT="Template-Spezialisierung?">
|
|
<node CREATED="1489790030727" ID="ID_1780788892" MODIFIED="1489790046961" TEXT="könnte const char* nehmen"/>
|
|
<node CREATED="1489790053044" ID="ID_1594786428" MODIFIED="1489790070534" TEXT="könnte dann nach Literal konvertibel sein"/>
|
|
<node CREATED="1489790158335" ID="ID_1828195626" MODIFIED="1489790166017" TEXT="Template könnte in Header definiert sein"/>
|
|
<node CREATED="1489790167669" ID="ID_156312862" MODIFIED="1489790182247" TEXT="und nur die explizite Spezialisierung generiert Code"/>
|
|
</node>
|
|
<node CREATED="1489790425251" ID="ID_1099709668" MODIFIED="1489790430606" TEXT="auto-Registrierung">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1489790431810" ID="ID_1253214974" MODIFIED="1489790442380" TEXT="variable statisch initialisieren"/>
|
|
<node CREATED="1489790522958" ID="ID_1454213723" MODIFIED="1489790532345" TEXT="Lambda an Basis-Ctor geben"/>
|
|
</node>
|
|
<node CREATED="1489790555393" ID="ID_1281815871" MODIFIED="1489790574611" TEXT="DSL wie boost-test">
|
|
<node CREATED="1489790576831" ID="ID_84712572" MODIFIED="1489790584658" TEXT="definiert Klasse o.ä"/>
|
|
<node CREATED="1489790588749" ID="ID_1302974476" MODIFIED="1489790599656" TEXT="User schreibt direkt dahinter einen Codeblock"/>
|
|
<node CREATED="1489790689536" ID="ID_605065689" MODIFIED="1489790702050" TEXT="tatsächlich wird das eine out-of-class definierte Methode"/>
|
|
<node CREATED="1489791695217" ID="ID_1529943414" MODIFIED="1489791705036" TEXT="...und kann sogar per Doxygen kommentiert werden"/>
|
|
</node>
|
|
<node CREATED="1489791741539" ID="ID_175521756" MODIFIED="1489791746686" TEXT="im Build-Prozeß parsen">
|
|
<node CREATED="1489791753074" ID="ID_1141751955" MODIFIED="1489791761893" TEXT="und z.B. den Header daraus generieren"/>
|
|
<node CREATED="1489791763313" ID="ID_1622970394" MODIFIED="1489791766588" TEXT="warum nicht...?"/>
|
|
<node CREATED="1489791777102" ID="ID_102161218" MODIFIED="1489791786937" TEXT="empfinde ich besser als komplex verschachtelte Makros"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489791729957" ID="ID_1986771449" MODIFIED="1525124215299" TEXT="kombinierte Magie">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1489791798116" ID="ID_197500257" MODIFIED="1533608414034" TEXT="Definitions-Klasse">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1489791805675" ID="ID_1517636242" MODIFIED="1489811237752" TEXT="ist konvertierbar nach Literal">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489791817873" ID="ID_361574240" MODIFIED="1489811240833" TEXT="nimmt Lambda als Konstruktor-Argument">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489791849245" ID="ID_262482724" MODIFIED="1489791860879" TEXT="bietet interne DSL"/>
|
|
<node CREATED="1489795277835" ID="ID_663997649" MODIFIED="1533608414035" TEXT="Name gesucht...?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1489795288354" ID="ID_960791386" MODIFIED="1489795346577" TEXT="CommandInstance">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489795292689" ID="ID_1059834523" MODIFIED="1489795346578" TEXT="CommandDefinition">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489795318614" ID="ID_437740295" MODIFIED="1489795346578" TEXT="CommandName">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489795321669" ID="ID_115829263" MODIFIED="1489795346579" TEXT="CommandItem">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1489795298832" ID="ID_1272194079" MODIFIED="1489795342763" TEXT="CommandSetup">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489791864787" ID="ID_891631217" MODIFIED="1489791877373" TEXT="in den Impl-Einheiten eine Folge von Definitionen"/>
|
|
<node CREATED="1489791877913" ID="ID_387208356" MODIFIED="1489793604385" TEXT="zughörigen Header proc/cmd.hpp im Build-Prozeß regenerieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1613944850941" ID="ID_716808675" MODIFIED="1613944856389" TEXT="vorerst nicht">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1489811274588" ID="ID_1635051629" MODIFIED="1518487921094" TEXT="Mechanismus">
|
|
<node COLOR="#338800" CREATED="1489811285746" ID="ID_1726037509" MODIFIED="1518487921094" TEXT="CommandSetup">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1489811291313" ID="ID_1780064476" MODIFIED="1518487921094" TEXT="Makro COMMAND_DEFINITION">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1489811304111" ID="ID_1976451454" MODIFIED="1518487921094" TEXT="Build-Generierung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1490927680004" ID="ID_1456638216" MODIFIED="1518487921094" TEXT="auf "später" vertagt"/>
|
|
<node CREATED="1490927702128" ID="ID_1355040899" MODIFIED="1518487921094" TEXT="wenn die händische Pflege zum Problem wird"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1490985673313" ID="ID_1705714293" MODIFIED="1561827465776" TEXT="Instanzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1490985683359" FOLDED="true" ID="ID_476048128" MODIFIED="1525124215302" TEXT="Instanz-Manager">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1490985692550" ID="ID_300485716" MODIFIED="1490985696321" TEXT="einfache Komponente"/>
|
|
<node CREATED="1490985710963" ID="ID_447657694" MODIFIED="1490985717974" TEXT="keinerlei Lifecycle-Magie"/>
|
|
<node CREATED="1490985720722" ID="ID_1386937508" MODIFIED="1561827465778" TEXT="ist nur eine Registry mit etwas Funktionalität">
|
|
<node CREATED="1490986294710" ID="ID_558020871" MODIFIED="1533400457991" TEXT="Command-IDs dekorieren"/>
|
|
<node CREATED="1490986302197" ID="ID_1305641719" MODIFIED="1491004967731" TEXT="fortlaufenden Zähler verwalten">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1490986345879" ID="ID_1736956933" MODIFIED="1576282357976" TEXT="denn: Dispatch bedeutet Verzögerung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...also ist eine Instanz durchaus noch am Leben,
|
|
</p>
|
|
<p>
|
|
während bereits die nächste Instanz für das GUI ausgegeben wurde.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1490986395088" ID="ID_52247198" MODIFIED="1490986412151" TEXT="Stets nur eine Instanz im Instance-manager">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1490986336425" ID="ID_1955343463" MODIFIED="1576282357976" TEXT="Konsequenz: leerer Eintrag">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit die Nummer erhalten bleibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491004971039" ID="ID_329531567" MODIFIED="1491004978482" TEXT="anonyme Instanz verwalten">
|
|
<node CREATED="1491004982341" ID="ID_1956457610" MODIFIED="1491495639478" TEXT="Frage: Duplikat überschreiben?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1491495641174" ID="ID_1196432780" MODIFIED="1491495651041" TEXT="antwort (vorerst): nein"/>
|
|
<node CREATED="1491495651932" ID="ID_1393507104" MODIFIED="1491495656080" TEXT="wäre gefährlich"/>
|
|
<node CREATED="1491495656604" ID="ID_1592570029" MODIFIED="1491495669470" TEXT="weist auf Logik-Fehler hin"/>
|
|
</node>
|
|
<node CREATED="1491005133794" ID="ID_1003096513" MODIFIED="1491005393601" TEXT="vorläufig überschreibe ich stillschweigend">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1490986309084" ID="ID_1432845924" MODIFIED="1490986319583" TEXT="sicher Übergabe an Dispatch">
|
|
<node CREATED="1490986320434" ID="ID_1807848022" MODIFIED="1490986324558" TEXT="Dispatch als Closure"/>
|
|
<node CREATED="1490986325626" ID="ID_167499115" MODIFIED="1490986333421" TEXT="Exception-Safety!"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491003278638" ID="ID_516679033" MODIFIED="1491003300696" TEXT="Instanz-Management">
|
|
<node CREATED="1491003301379" ID="ID_997022970" MODIFIED="1491003305671" TEXT="funktioniert fast von selbst"/>
|
|
<node CREATED="1491003306451" ID="ID_1812101347" MODIFIED="1491003314278" TEXT="Command == smart-Handle"/>
|
|
<node CREATED="1491003314746" ID="ID_850841535" MODIFIED="1491003350337" TEXT="instanz kann anonym bleiben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1491003323585" ID="ID_719524765" MODIFIED="1491003347758" TEXT="die lokale Registry hällt sie am Leben">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1490985696821" ID="ID_564026288" MODIFIED="1490985706464" TEXT="wird vom SessionCommandService betrieben"/>
|
|
</node>
|
|
<node CREATED="1490985748207" ID="ID_1314513556" MODIFIED="1518487921094" TEXT="Instanzbildung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1490985756381" ID="ID_1346029720" MODIFIED="1518487921094" TEXT="wird durch ID-Dekoration getrieben"/>
|
|
<node CREATED="1491656301121" ID="ID_566719122" MODIFIED="1518487921094" TEXT="es ist stets nur eine Instanz offen"/>
|
|
<node CREATED="1492359658654" ID="ID_712987844" MODIFIED="1518487921094" TEXT="erfolgt weitgehend automatisch/transparent">
|
|
<node CREATED="1492359686938" ID="ID_1447317770" MODIFIED="1518487921094" TEXT="anonyme Klon-Kopie von CommandDef">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1492359678835" ID="ID_608610767" MODIFIED="1576282357975" TEXT="explizite Instanzbildung ist optional">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...implementiert "für die Zukunft",
|
|
</p>
|
|
<p>
|
|
wenn wir context-bound -Commands verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491694174845" ID="ID_344801148" MODIFIED="1576282357975" TEXT="Instanzbildung gehört nicht in das Tangible">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist ein grundlegender Beschluß.
|
|
</p>
|
|
<p>
|
|
InteractionControl ist eine eigene Schicht;
|
|
</p>
|
|
<p>
|
|
deshalb ist auch der UI-Bus nicht <i>das </i>Universal-Interface schlechthin
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1492444212103" ID="ID_205822286" MODIFIED="1518487921094" TEXT="Regelfall">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1492444215374" ID="ID_1593808752" MODIFIED="1518487921094" TEXT="einfacher direkter Aufruf"/>
|
|
<node CREATED="1492444220086" ID="ID_1379993947" MODIFIED="1518487921094" TEXT="rein die Command-ID genügt"/>
|
|
<node CREATED="1492444235604" ID="ID_821909125" MODIFIED="1518487921094" TEXT="diese ist per proc/cmd.hpp festgelegt"/>
|
|
<node CREATED="1492444226909" ID="ID_1827091909" MODIFIED="1518487921094" TEXT="Instanzen werden automatisch erzeugt"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1492461052551" ID="ID_1120178298" MODIFIED="1518487921094" TEXT="Objekt-IDs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1492461062788" ID="ID_685772910" MODIFIED="1518487921094" TEXT="was wird verwendet, um auf Objekte zu verweisen"/>
|
|
<node CREATED="1492461075842" ID="ID_1775175141" MODIFIED="1518487921094" TEXT="Möglichkeiten">
|
|
<node CREATED="1492461081978" ID="ID_1041621476" MODIFIED="1518487921094" TEXT="LuidH">
|
|
<node CREATED="1492461102167" ID="ID_541671903" MODIFIED="1518487921094" TEXT="schon unterstützt"/>
|
|
</node>
|
|
<node CREATED="1492461084232" ID="ID_1450157918" MODIFIED="1518487921094" TEXT="EntryID">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1492461110341" ID="ID_1884085083" MODIFIED="1518487921094" TEXT="müßte in GenNode transportiert werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1492461121691" ID="ID_1456848003" MODIFIED="1518487921094" TEXT="GenNode-Datentypen erweitern">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1616946908520" HGAP="14" ID="ID_616646922" MODIFIED="1616946925604" TEXT="Gesten und Kontext-IDs" VSHIFT="3">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1616946854861" ID="ID_1000039605" MODIFIED="1616947006922" TEXT="Thema wartet auf eine viel weiter gediehene konkrete Implementierung">
|
|
<linktarget COLOR="#565ec8" DESTINATION="ID_1000039605" ENDARROW="Default" ENDINCLINATION="-1327;-47;" ID="Arrow_ID_33928560" SOURCE="ID_273700034" STARTARROW="None" STARTINCLINATION="-397;16;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1616947016539" ID="ID_955611798" MODIFIED="1616947047035" TEXT="Übersetzung findet statt">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1616947023730" ID="ID_1003665654" MODIFIED="1616947029562" TEXT="in CmdContext"/>
|
|
<node CREATED="1616947030273" ID="ID_892803974" MODIFIED="1616947043732" TEXT="in GestureState (Service"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1488672593812" ID="ID_1454459609" MODIFIED="1518487921094" TEXT="konkret"/>
|
|
</node>
|
|
<node CREATED="1448063874479" HGAP="43" ID="ID_739054690" MODIFIED="1557498707235" TEXT="UI-Binding" VSHIFT="1">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1538957594154" ID="ID_2785316" MODIFIED="1557498707235" TEXT="erwartete Modell-Struktur">
|
|
<node COLOR="#435e98" CREATED="1538957611472" ID="ID_580392349" MODIFIED="1557498707235" TEXT="gemäß systematischem UI Modell-Schema">
|
|
<arrowlink COLOR="#919fc6" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-641;482;" ID="Arrow_ID_593956858" STARTARROW="None" STARTINCLINATION="1171;75;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1538957611472" ID="ID_1483911882" MODIFIED="1557498707235" TEXT="Aufgabe: Placement GUI-Repräsentation">
|
|
<arrowlink COLOR="#919fc6" DESTINATION="ID_388585037" ENDARROW="None" ENDINCLINATION="-682;462;" ID="Arrow_ID_726807054" STARTARROW="Default" STARTINCLINATION="638;-81;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1540748268638" ID="ID_59379201" MODIFIED="1557498707235" TEXT="Grundkonzept">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1540748279917" ID="ID_85147625" MODIFIED="1557498707235" TEXT="materialisierte Eigenschaften erscheinen auf dem Target"/>
|
|
<node CREATED="1540748293067" ID="ID_1744964690" MODIFIED="1557498707235" TEXT="(meta)-Einstellungen des Placements erscheinen in einem geschachtelten Objekt"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544839734136" ID="ID_1725773887" MODIFIED="1557498707235" TEXT="Aufgabe: Model anreichern und explizieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#435e98" CREATED="1544839748278" ID="ID_819383617" MODIFIED="1557498707235" TEXT="das systematische UI-Modell ist explizit">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1539134733747" ID="ID_1179407482" MODIFIED="1557498707235" TEXT="vom Diff-Constituent zu leisten">
|
|
<arrowlink COLOR="#4e31e2" DESTINATION="ID_1189184036" ENDARROW="Default" ENDINCLINATION="-432;-65;" ID="Arrow_ID_1794591374" STARTARROW="None" STARTINCLINATION="-1379;-131;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539138549468" ID="ID_515593613" MODIFIED="1557498707235" TEXT="existiert "irgendwo" in der Session"/>
|
|
<node CREATED="1539138556651" ID="ID_1569094364" MODIFIED="1557498707235" TEXT="wird anderweitig getriggert"/>
|
|
<node CREATED="1539138563657" ID="ID_1039045631" MODIFIED="1557498707235" TEXT="erzeugt Diff-Emanation"/>
|
|
<node CREATED="1544840079986" ID="ID_1423447891" MODIFIED="1557498707235" TEXT="fertig aufbereitet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544839802910" ID="ID_1966850162" MODIFIED="1557498707235" TEXT="auszuführen">
|
|
<node CREATED="1544839813006" ID="ID_790942961" MODIFIED="1557498707235" TEXT="Ruler-Configs für jeden Track"/>
|
|
<node CREATED="1544839819212" ID="ID_685715164" MODIFIED="1557498707235" TEXT="Steuer-Elemente gemäß Placement"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680567463215" ID="ID_1184528519" MODIFIED="1680567476289" TEXT="Datenstrom-Routing">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567534405" ID="ID_212457558" MODIFIED="1680567618172" TEXT="Medien-Datenverbindung: Grundlagen definieren">
|
|
<linktarget COLOR="#ba4677" DESTINATION="ID_212457558" ENDARROW="Default" ENDINCLINATION="-1225;-80;" ID="Arrow_ID_1272242151" SOURCE="ID_1328492043" STARTARROW="None" STARTINCLINATION="360;22;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128074725" FOLDED="true" HGAP="28" ID="ID_933994138" MODIFIED="1561827465790" TEXT="Diff-System" VSHIFT="1">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1434128278990" ID="ID_106354755" MODIFIED="1518487921094" TEXT="Diff-Darstellung"/>
|
|
<node CREATED="1434128267381" ID="ID_823706141" MODIFIED="1518487921094" TEXT="List-diff">
|
|
<icon BUILTIN="go"/>
|
|
</node>
|
|
<node CREATED="1434128078638" ID="ID_1704749549" MODIFIED="1518487921094" TEXT="Tree-Diff">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1434128095838" ID="ID_419405890" MODIFIED="1518487921094" TEXT="Detector">
|
|
<icon BUILTIN="stop"/>
|
|
</node>
|
|
<node CREATED="1434128092877" ID="ID_105246595" MODIFIED="1518487921094" TEXT="Applikator">
|
|
<node CREATED="1434128115462" ID="ID_1299653797" MODIFIED="1518487921094" TEXT="Tree-Mutator"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#c9cfe1" COLOR="#435e98" CREATED="1434128083878" FOLDED="true" ID="ID_937754899" MODIFIED="1573834757669" TEXT="Format">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1434128153773" ID="ID_1289483934" MODIFIED="1518487921094" TEXT="Objekt-Repräs">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1434128243334" ID="ID_1828331212" MODIFIED="1518487921094" TEXT="Typ-Darstellung"/>
|
|
<node CREATED="1434128239517" ID="ID_1886740948" MODIFIED="1518487921094" TEXT="Mapping"/>
|
|
<node CREATED="1434128170381" ID="ID_976705384" MODIFIED="1573834546731" TEXT="GenNode">
|
|
<linktarget COLOR="#4f7ffc" DESTINATION="ID_976705384" ENDARROW="Default" ENDINCLINATION="-55;132;" ID="Arrow_ID_1285375088" SOURCE="ID_553361956" STARTARROW="Default" STARTINCLINATION="-5;-77;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1435421658394" ID="ID_1938259420" MODIFIED="1518487921094" TEXT="ID">
|
|
<node CREATED="1435421670349" ID="ID_1358247529" MODIFIED="1561827465793" TEXT="verwende EntryID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1435421678004" ID="ID_691179282" MODIFIED="1512926192296" TEXT="Abhängigkeitsprobleme">
|
|
<node CREATED="1435421693260" ID="ID_1314021887" MODIFIED="1435942753226" TEXT="generische ID-Funktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1435421739988" ID="ID_405602814" MODIFIED="1435885199446" TEXT="EntryID gehört in Library">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1435885214592" ID="ID_1198930165" MODIFIED="1512926192296" TEXT="sanitise stört">
|
|
<node CREATED="1435885226222" ID="ID_776697956" MODIFIED="1435942745458" TEXT="verschiebe in EntryID">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1435885235583" ID="ID_444167455" MODIFIED="1435942747401" TEXT="verwende Subklasse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439842285584" ID="ID_334339765" MODIFIED="1518487921094" TEXT="spezielle Ref-IDs"/>
|
|
</node>
|
|
<node CREATED="1434128174030" ID="ID_1395250463" MODIFIED="1525124215304" TEXT="Variant">
|
|
<node CREATED="1435943070542" ID="ID_949070153" MODIFIED="1561827465794" TEXT="Wert-Semantik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1435943077974" ID="ID_280152814" MODIFIED="1435943080682" TEXT="kopierbar"/>
|
|
<node CREATED="1435943081438" ID="ID_159359464" MODIFIED="1435943083738" TEXT="zuweisbar"/>
|
|
<node CREATED="1435943085206" ID="ID_734188530" MODIFIED="1512926192298" TEXT="const-ness liegt beim User">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. der usage context entscheidet, ob wir einen Wert,
|
|
</p>
|
|
<p>
|
|
eine Referenz oder einen konstanten Wert verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1435943194398" ID="ID_587131941" MODIFIED="1435943203161" TEXT="GenNode gibt Referenz auf Wert"/>
|
|
<node CREATED="1435943203662" ID="ID_1772960325" MODIFIED="1435943274743" TEXT="const GenNode gibt const&">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1435943214822" ID="ID_723738462" MODIFIED="1435943233983">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Record selber ist immuable
|
|
</p>
|
|
<p>
|
|
aber hat eine Builder-Mechanik
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1435943121046" ID="ID_16399922" MODIFIED="1435943145278" TEXT="brauche const Variante">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eigentlich fehlte nur die get()-Operation
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128217645" FOLDED="true" ID="ID_1790054544" MODIFIED="1573834533842" TEXT="Monade">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1435932580854" ID="ID_1307223527" MODIFIED="1512926192300" TEXT="Daten einwickeln">
|
|
<node CREATED="1435932589853" ID="ID_180643071" MODIFIED="1435932595665" TEXT="ctor forward"/>
|
|
<node CREATED="1435932598197" ID="ID_951223738" MODIFIED="1512926192301" TEXT="Problem mit copy ctor">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erledigt... ähm vertagt
|
|
</p>
|
|
<p>
|
|
aber nicht wirklich; der workaround könnte schon die Lösung sein #963
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1435932667701" HGAP="22" ID="ID_1069242347" MODIFIED="1512926192302" TEXT="Copy matcht generischen ctor" VSHIFT="-9">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1435932714261" ID="ID_1395890846" MODIFIED="1435932719281" TEXT="gleiches Problem schon bei Variant"/>
|
|
<node CREATED="1435932719709" ID="ID_188423010" MODIFIED="1435932783846" TEXT="dort explizit gemacht, da komplex">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich hatte damals beim Variant und zugehörigen Buffer die Sorge,
|
|
</p>
|
|
<p>
|
|
daß ich die Implikationen einer generischen Lösung nicht durchdringen kann.
|
|
</p>
|
|
<p>
|
|
Und ich wollte keine Zeit auf einen exzessiven Unit-Test verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1435942764328" ID="ID_1740355148" MODIFIED="1435942879414">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
generische Lösung verschoben <font color="#990033">#963</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#ff3333" DESTINATION="ID_1935900779" ENDARROW="Default" ENDINCLINATION="188;0;" ID="Arrow_ID_1626382520" STARTARROW="Default" STARTINCLINATION="2;73;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1435942827511" ID="ID_614756812" MODIFIED="1435942844839">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
C++11 erlaubt <b>=default</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1435932611653" ID="ID_1701726752" MODIFIED="1435932628945" TEXT="Ansatz-1 (einfach): explizit"/>
|
|
<node CREATED="1435932629517" ID="ID_1935900779" MODIFIED="1435942879415" TEXT="Ansatz-2: Selbst-Typ ausblenden">
|
|
<linktarget COLOR="#ff3333" DESTINATION="ID_1935900779" ENDARROW="Default" ENDINCLINATION="188;0;" ID="Arrow_ID_1626382520" SOURCE="ID_1740355148" STARTARROW="Default" STARTINCLINATION="2;73;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1435942891695" ID="ID_947731706" MODIFIED="1561827465802" TEXT="Iteration">
|
|
<linktarget COLOR="#98e2df" DESTINATION="ID_947731706" ENDARROW="Default" ENDINCLINATION="-78;95;" ID="Arrow_ID_197324270" SOURCE="ID_1665153106" STARTARROW="None" STARTINCLINATION="168;-25;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1440983732337" HGAP="35" ID="ID_792682966" MODIFIED="1440983809484" TEXT="monadische Iteration" VSHIFT="12">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nicht klar, ob wir das überhaupt brauchen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
entweder nur die unmittelbaren Kinder -> komplexe Logik fällt auf den Client
|
|
</li>
|
|
<li>
|
|
oder nur die Blätter -> man kann die Baum-Struktur nicht wirklich nutzen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1440983598369" ID="ID_1025556053" MODIFIED="1512926192305">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung
|
|
</p>
|
|
<p>
|
|
<font size="1">was wir brauchen</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1440983617193" ID="ID_532213208" MODIFIED="1440983627459" TEXT="bracketing"/>
|
|
<node CREATED="1440983628399" ID="ID_1711016962" MODIFIED="1440983642457" TEXT="node prefix"/>
|
|
<node CREATED="1440983643445" ID="ID_1023025658" MODIFIED="1440983656648" TEXT="depth-first"/>
|
|
</node>
|
|
<node CREATED="1440983661027" ID="ID_507018481" MODIFIED="1512926192307" TEXT="Impl">
|
|
<node CREATED="1440983668537" ID="ID_1230038295" MODIFIED="1441936954788" TEXT="IterExplorer verwenden">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1440984024736" ID="ID_1554494729" MODIFIED="1512926192308" TEXT="Chained Iters">
|
|
<node CREATED="1440984028959" ID="ID_896818992" MODIFIED="1440984040210" TEXT="pfiffig"/>
|
|
<node CREATED="1440984040870" ID="ID_1008957395" MODIFIED="1440984048057" TEXT="müßte der IterIter implementieren"/>
|
|
<node CREATED="1440984048380" ID="ID_917358570" MODIFIED="1440984080184">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geht nicht:
|
|
</p>
|
|
<p>
|
|
rekursiver Abstieg in der Mitte eines Iterators
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1440983855875" ID="ID_1991218497" MODIFIED="1561827465804" TEXT="RecursiveSelfIntegration">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das war die Quintessenz der ganzen Entwicklung zum IterExplorer
|
|
</p>
|
|
<p>
|
|
Nachdem ich die depth-first / breadth-first -Strategien systematisch aufgebaut hatte,
|
|
</p>
|
|
<p>
|
|
habe ich das dann reduziert und kompakt nochmal geschrieben.
|
|
</p>
|
|
<p>
|
|
Sehr schön!
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
übrigens: genau den verwenden wir auch zur Job-Planung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1440983865102" ID="ID_306959180" MODIFIED="1440983871265" TEXT="hoch effizient"/>
|
|
<node CREATED="1440983872517" ID="ID_1633584594" MODIFIED="1440983880175" TEXT="paßt genau"/>
|
|
<node CREATED="1440983880715" ID="ID_617483189" MODIFIED="1440983893678" TEXT="erfordert speziellen ResultIter"/>
|
|
<node COLOR="#999999" CREATED="1440984125546" ID="ID_461442477" MODIFIED="1533608414037" TEXT="TODO">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1440984130872" ID="ID_579146044" MODIFIED="1561827465804" TEXT="ResultIter">
|
|
<node CREATED="1440984214126" ID="ID_1124020862" MODIFIED="1441937180496" TEXT="GenNode-Zeiger"/>
|
|
<node CREATED="1440984221636" ID="ID_1279195509" MODIFIED="1441937180496" TEXT="Scope-Marker"/>
|
|
</node>
|
|
<node CREATED="1440984158949" ID="ID_1602941967" MODIFIED="1441937180496" TEXT="BuilderTrait"/>
|
|
<node CREATED="1440984166132" ID="ID_761913732" MODIFIED="1561827465804" TEXT="explorer Funktion">
|
|
<node CREATED="1440984256512" ID="ID_1965762804" MODIFIED="1441937180496" TEXT="verwendet Variant::Visitor"/>
|
|
<node CREATED="1440984273357" ID="ID_153302412" MODIFIED="1441937180496" TEXT="steigt in Records ein"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1441935566556" ID="ID_128176235" MODIFIED="1561827465805" TEXT="oder doch depthFirst?">
|
|
<icon BUILTIN="full-2"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1441935596503" ID="ID_119941709" MODIFIED="1441935613232" TEXT="verwendet einen einfacheren Iterator"/>
|
|
<node CREATED="1441935617115" ID="ID_1743908800" MODIFIED="1441935704268" TEXT="hat dafür den Stack (deque) explizit"/>
|
|
<node CREATED="1441935708383" ID="ID_1709495985" MODIFIED="1441936067879" TEXT="Erkenntnis: Stack ist unvermeidbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir müssen den Weg zurück finden.
|
|
</p>
|
|
<p>
|
|
Wenn also eine Datenstruktur nur einfach verzeigert ist, oder direkt rekursiv (wie bei uns),
|
|
</p>
|
|
<p>
|
|
dann ist es <i>absolut unmöglich,</i> eine Traversierung mit konstantem Speicher zu machen.
|
|
</p>
|
|
<p>
|
|
Das geht nur bei einer Struktur mit Rückreferenzen -- diese enthalten dann nämlich genau den Speicher,
|
|
</p>
|
|
<p>
|
|
der während dem Einstieg in die einfach verzeigerte Struktur auf dem Stack liegt. Aber letztere
|
|
</p>
|
|
<p>
|
|
braucht nur eine logarithmische Menge an Speicher, und das auch nur während der Traversierung.
|
|
</p>
|
|
<p>
|
|
Dies ist die Abwägung, und darunter läßt sich nichts weghandeln.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Der einzige verbleibende Freiheitsgrad ist, bei einer unmittelbaren rekursiven Programmierung
|
|
</p>
|
|
<p>
|
|
direkt den Prozessor-Stack für die Speicherung des Rückweges mitzuverwenden;
|
|
</p>
|
|
<p>
|
|
in dem Moment, wo ich mich für einen Iterator entscheide, ist diese Möglichkeit weg.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1441936092427" ID="ID_199084223" MODIFIED="1441936126886">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann genauso effizient werden
|
|
</p>
|
|
<p>
|
|
aber nur, wenn man die Initialisierung hinbekommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1441936132022" ID="ID_183615098" MODIFIED="1441936141832" TEXT="trotzdem muß man die Funktion speichern"/>
|
|
<node CREATED="1441936142563" ID="ID_161796731" MODIFIED="1441936150975" TEXT="und wir brauchen gar keine flexible Funktion"/>
|
|
</node>
|
|
<node CREATED="1441936154834" ID="ID_1320687783" MODIFIED="1561827465806">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oder diese Logik
|
|
</p>
|
|
<p>
|
|
fest verdrahten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-3"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1441936260132" ID="ID_600953695" MODIFIED="1441936270614" TEXT="der IterExplorer zeigt genau, was zu tun ist"/>
|
|
<node CREATED="1441936271274" ID="ID_567626167" MODIFIED="1441936284756" TEXT="aber das mehrfache Kopieren zur Initialisierung entfällt"/>
|
|
<node CREATED="1441936285368" ID="ID_1119180152" MODIFIED="1441936296746" TEXT="wir brauchen genauso einen maßgeschneiderten Scope-Iterator"/>
|
|
<node CREATED="1441936356831" ID="ID_1423049913" MODIFIED="1441936372500" TEXT="aber die Indirektion für die Funktion fällt weg">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1441936386803" ID="ID_588658088" MODIFIED="1533608414039" TEXT="TODO">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1441936422725" ID="ID_1581368426" MODIFIED="1441936433181" TEXT="ScopeExplorer-Mechanismus mit Stack">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1441936434644" ID="ID_455233841" MODIFIED="1561827465807" TEXT="innerer Iterator">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1441936451042" ID="ID_1773948072" MODIFIED="1441936476114" TEXT="disjunktiver Typ"/>
|
|
<node CREATED="1441936869273" ID="ID_864580946" MODIFIED="1441936878867" TEXT="entweder GenNode, oder Rec"/>
|
|
<node CREATED="1441936494164" ID="ID_1837843513" MODIFIED="1441936749098" TEXT="Variant ohne Selector?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da es sich um einen disjunktiven Typ (entweder-oder-Typ) handelt,
|
|
</p>
|
|
<p>
|
|
könnte man die Storage mit beiden Bedeutungen überlagern.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Voraussetzung wäre, daß man anhand der konkreten Daten <b>gefahrlos</b>  jeweils herausfinden kann,
|
|
</p>
|
|
<p>
|
|
welcher Zweig grade gilt. Da wir aber keine Introspektion haben (und auch nicht wollen!),
|
|
</p>
|
|
<p>
|
|
würde das auf Taschenspielertricks mit der Implementierung hinauslaufen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
GenNode und Record beginnen beide fraktisch mit einem String. Man müßte diesen interpretieren können
|
|
</li>
|
|
<li>
|
|
oder man nutzt die letzten Bits des Pointers, um sich dort eine Flag zu speichern...
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Damit ist schon klar: <i>sowas macht man nicht ohne Grund</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1441936883063" ID="ID_428834793" MODIFIED="1441936894393" TEXT="GenNode erfordert nur einen Pointer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1441936900076" ID="ID_1582043438" MODIFIED="1561827465808" TEXT="Explorer-Funktion">
|
|
<node CREATED="1441936911211" ID="ID_722452490" MODIFIED="1441936917230" TEXT="kommt in DataCap"/>
|
|
<node CREATED="1441936983313" ID="ID_1843183144" MODIFIED="1441936990892" TEXT="muß den inneren Iterator liefern"/>
|
|
<node CREATED="1441937000487" ID="ID_312630797" MODIFIED="1441937028412">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung: <i>falls</i> eingebetteter Record
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1441937037498" ID="ID_1964865459" MODIFIED="1443147539495" TEXT="Initialisierung bedenken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443147571765" ID="ID_1651952492" MODIFIED="1512926192315" TEXT="HierarchyOrientation">
|
|
<node CREATED="1443147582018" ID="ID_1791945362" MODIFIED="1443147603945" TEXT="fest einbauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1443147586241" ID="ID_904848069" MODIFIED="1443147706043" TEXT="besser: nur level zugänglich machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Begründung: das Durchlaufen und Rekonstruieren eines Baumes
|
|
</p>
|
|
<p>
|
|
ist letztlich doch ein sehr spezieller Fall, und rechtfertigt nicht,
|
|
</p>
|
|
<p>
|
|
den HierarchyOrientationIndicator in jeden Iterator einzubetten.
|
|
</p>
|
|
<p>
|
|
Zumal -- wenn der level zugänglich ist -- kann man diese Mechanik genauso gut
|
|
</p>
|
|
<p>
|
|
dort direkt ansiedeln, wo sie gebraucht wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443147730941" ID="ID_196989292" MODIFIED="1443147751954">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also <i>keine</i> Monade
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1440984348699" HGAP="64" ID="ID_1327214042" MODIFIED="1518487921094" TEXT="Prädikate" VSHIFT="-26">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1440984366937" ID="ID_1806640214" MODIFIED="1518487921094">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gleichheit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1440984381982" ID="ID_187772178" MODIFIED="1518487921095" TEXT="Wert-Match">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1440984392453" ID="ID_1665153106" MODIFIED="1518487921095" TEXT="Contains">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kombiniert den Wert-Match mit der Iteration
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#98e2df" DESTINATION="ID_947731706" ENDARROW="Default" ENDINCLINATION="-78;95;" ID="Arrow_ID_197324270" STARTARROW="None" STARTINCLINATION="168;-25;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128176918" ID="ID_863330674" MODIFIED="1561827465814" TEXT="Record">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1434128198957" ID="ID_1224215957" MODIFIED="1512926192319" TEXT="Konstuktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1434421381345" ID="ID_752165044" MODIFIED="1436042396321" TEXT="DSL zur Daten-Definition">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1434421403406" ID="ID_1085825017" MODIFIED="1434421414073" TEXT="Alternative zur Diff-Repräsentation"/>
|
|
<node CREATED="1434421422582" ID="ID_1730569377" MODIFIED="1434421448187">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zweck: kompaktes Anschreiben
|
|
</p>
|
|
<p>
|
|
von literalen Daten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1435973418262" ID="ID_1847939996" MODIFIED="1512926192321">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Object <b>builder</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1435973448902" ID="ID_1729239555" MODIFIED="1512926192322" TEXT="wie definieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem ist, wir definieren den Typ Record generisch,
|
|
</p>
|
|
<p>
|
|
verwenden dann aber nur die Spezialisierung Record<GenNode>
|
|
</p>
|
|
<p>
|
|
Und die Builder-Funktionen brauchen eigentlich spezielles Wissen über den zu konstruierenden Zieltyp
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1436042433806" ID="ID_601307933" MODIFIED="1436042451130" TEXT="Erweiterungspunkt"/>
|
|
<node CREATED="1436042451694" ID="ID_1270184731" MODIFIED="1436042458786" TEXT="durch explizite Spezialiserung"/>
|
|
<node CREATED="1436042460726" ID="ID_818066421" MODIFIED="1436042468802" TEXT="nur für genNode()"/>
|
|
<node CREATED="1436042480886" ID="ID_1194557524" MODIFIED="1436042502641">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mutator selber is <i>noncopyable</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1435973566277" ID="ID_1320441333" MODIFIED="1512926192323">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ergebnis move
|
|
</p>
|
|
<p>
|
|
<font size="1">pro / contra</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Move ist <b>gefährlich </b>
|
|
</p>
|
|
<p>
|
|
aber auch deutlich effizienter,
|
|
</p>
|
|
<p>
|
|
denn wir müssen sonst das ganze erzeugte Ergebnis einmal kopieren.
|
|
</p>
|
|
<p>
|
|
Nicht sicher, ob der Optimiser das hinbekommt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1436042507254" ID="ID_1832904297" MODIFIED="1436042518877">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nur</i> auf dem Mutator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1436042520942" ID="ID_1700762999" MODIFIED="1436042539843">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieser ist nicht kopierbar
|
|
</p>
|
|
<p>
|
|
und muß dediziert erstellt werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1436042542502" ID="ID_890092502" MODIFIED="1436042552578" TEXT="move passiert immer explizit"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1436042774669" FOLDED="true" ID="ID_714336641" MODIFIED="1573834498253" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1436042783700" ID="ID_381817780" MODIFIED="1436042788584" TEXT="zwei Collections"/>
|
|
<node CREATED="1436042814044" ID="ID_1455779230" MODIFIED="1436042818312" TEXT="aber semantisch eine Liste"/>
|
|
<node CREATED="1436924462201" ID="ID_1369837914" MODIFIED="1512926192324" TEXT="Probleme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1436924502056" ID="ID_1085481788" MODIFIED="1512926192326" TEXT="Rückgabetyp von Attribut-Gettern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
möglicherweise schon gelöst,
|
|
</p>
|
|
<p>
|
|
denn Record ist insgesamt immutable.
|
|
</p>
|
|
<p>
|
|
Also können wir einen Find mit einem const_iterator machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439826834113" ID="ID_1331810475" MODIFIED="1439826858261">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
was sinnvoll ist,
|
|
</p>
|
|
<p>
|
|
hängt vom Payload-Typ ab
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439826859630" ID="ID_658403513" MODIFIED="1439826896096">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bei einer 'key = value' -Syntax mit strings
|
|
</p>
|
|
<p>
|
|
ist nur ein Value-Rückgabewert sinnvoll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439826896985" ID="ID_180703618" MODIFIED="1439826904996" TEXT="habe es daher generisch/konfigurierbar gemacht"/>
|
|
<node CREATED="1439826905728" ID="ID_955222288" MODIFIED="1439826937458" TEXT="-> überhaupt eine Typkonfiguration ist sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...auch kann man auf diesem Weg die Storage konfigurierbar machten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1436924529208" ID="ID_1300693998" MODIFIED="1512926192327" TEXT="Handhabung des Typ-Feldes">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1436925315589" ID="ID_327577903" MODIFIED="1533608414041" TEXT="herausfiltern">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1439826509444" ID="ID_333663358" MODIFIED="1439826524386" TEXT="ja">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1439826512572" ID="ID_1522833188" MODIFIED="1439826522070" TEXT="aus beliebigem Attribut"/>
|
|
</node>
|
|
<node CREATED="1436924568352" ID="ID_1243616839" MODIFIED="1533608414041" TEXT="in Attribut-Iterator">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1439826529649" ID="ID_1514781996" MODIFIED="1439826559628" TEXT="wäre schön">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1439826535625" ID="ID_872404626" MODIFIED="1439826563061" TEXT="ist aber aufwendig">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1439826545167" ID="ID_185501908" MODIFIED="1439826726913" TEXT="geht nur mit Metadata-Collection">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da wir einen IterAdapter verwenden, können wir nur eine 'pos' (einen Quell-Iterator)
|
|
</p>
|
|
<p>
|
|
als Zustands-Markierung verwenden; die gleiche 'pos' wird aber auch inkrementiert und dereferenziert.
|
|
</p>
|
|
<p>
|
|
Daher ist die einzige praktikable Lösung, daß die Typ-ID in einem weiteren Vektor gespeichert wird.
|
|
</p>
|
|
<p>
|
|
Das könnte dann ein Metadaten-Vektor sein.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Natürlich ist dieser Ansatz nur sinnvoll, <i>wenn wir wirklich Metadaten brauchen.</i>
|
|
</p>
|
|
<p>
|
|
Denn jeder Record zahlt den Preis für die komplexere (zusätzliche) Datenstruktur!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1436924578936" ID="ID_677097690" MODIFIED="1533608414042" TEXT="in Attribut-Collection ablegen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1439826758699" ID="ID_873913305" MODIFIED="1439826761999" TEXT="pfiffige Idee"/>
|
|
<node CREATED="1439826762731" ID="ID_339809602" MODIFIED="1439826766758" TEXT="aber eigentlich ein Pfusch"/>
|
|
<node CREATED="1439826767274" ID="ID_1506445345" MODIFIED="1439826777093" TEXT="man müßte jede Eingans-Collection normalisieren"/>
|
|
<node CREATED="1439826782368" ID="ID_386953463" MODIFIED="1439826789763" TEXT="man müßte Duplikate filtern"/>
|
|
<node CREATED="1439826792343" ID="ID_775227666" MODIFIED="1439826804002" TEXT="NJET">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439827003483" ID="ID_514691403" MODIFIED="1512926192329" TEXT="'magische' IDs als Attribute">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439827021297" ID="ID_154339557" MODIFIED="1439827028484" TEXT="brauche ich für die Diff-Language"/>
|
|
<node CREATED="1439827061051" ID="ID_1563625085" MODIFIED="1439827543682" TEXT="implementiert als spezielle, magische ID-Referenzen">
|
|
<arrowlink COLOR="#5bf0d0" DESTINATION="ID_913220298" ENDARROW="Default" ENDINCLINATION="366;-59;" ID="Arrow_ID_806648905" STARTARROW="None" STARTINCLINATION="347;320;"/>
|
|
</node>
|
|
<node CREATED="1439827599485" ID="ID_426467512" MODIFIED="1439827625675" TEXT="ist es problematisch, wenn solche in die normalen Attribute geraten">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1439827636256" ID="ID_339472941" MODIFIED="1439827645763" TEXT="entscheidet sich im Diff-Algorithmus, sonst wurscht"/>
|
|
<node CREATED="1439827647038" ID="ID_1668349556" MODIFIED="1439827693504" TEXT="also gehört das in einen höheren Layer">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1439827663860" ID="ID_582619719" MODIFIED="1439827698437" TEXT="Record sollte sich hier neutral verhalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128179406" HGAP="25" ID="ID_1833179523" MODIFIED="1512926192330" TEXT="Referez" VSHIFT="13">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1434129158157" ID="ID_1777328498" MODIFIED="1512926192330" TEXT="sicher dereferenzierbar">
|
|
<node CREATED="1434205928410" ID="ID_733269570" MODIFIED="1434205947253" TEXT="entweder zwangsweise gebunden"/>
|
|
<node CREATED="1434205947841" ID="ID_871233558" MODIFIED="1434205955964" TEXT="oder NULL-Zustand mit Exception"/>
|
|
<node CREATED="1434205957177" ID="ID_499991180" MODIFIED="1434205968740" TEXT="inherente Unsicherheit einer Referenz"/>
|
|
</node>
|
|
<node CREATED="1434129167805" ID="ID_819452470" MODIFIED="1512926192330" TEXT="stand-in">
|
|
<arrowlink COLOR="#00ff33" DESTINATION="ID_654762061" ENDARROW="Default" ENDINCLINATION="-390;37;" ID="Arrow_ID_724106052" STARTARROW="Default" STARTINCLINATION="-48;187;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1434129196709" ID="ID_1004519740" MODIFIED="1436042656829" TEXT="Subklasse von Rec">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
scheidet aus, wegen Wertsemantik
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1434129204149" ID="ID_1688475597" MODIFIED="1561827465820" TEXT="GenNode">
|
|
<linktarget COLOR="#66ff66" DESTINATION="ID_1688475597" ENDARROW="Default" ENDINCLINATION="219;91;" ID="Arrow_ID_57985873" SOURCE="ID_60404225" STARTARROW="Default" STARTINCLINATION="23;-52;"/>
|
|
<node CREATED="1434205661969" ID="ID_1484374626" MODIFIED="1434205705054">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mit <i>speziellem </i>Ref-Typ
|
|
</p>
|
|
<p>
|
|
<font size="1">-- im DataCap</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ffcccc" COLOR="#990033" CREATED="1434205598709" ID="ID_235720343" MODIFIED="1533608414042" TEXT="stand-in heißt...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1434205739609" ID="ID_1185983904" MODIFIED="1434205778045" TEXT="kann anstelle eines Objektes treten"/>
|
|
<node CREATED="1434205834506" ID="ID_1477654683" MODIFIED="1434205859229" TEXT="transparent für den Aufrufer"/>
|
|
<node CREATED="1434205862449" ID="ID_1736858324" MODIFIED="1434205879837" TEXT="Konsequenz: DataCap muß das verstehen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128128869" ID="ID_244966341" MODIFIED="1518487921095" TEXT="Verben">
|
|
<node CREATED="1434128134508" ID="ID_553361956" MODIFIED="1573834578527" TEXT="ID-Repräs">
|
|
<arrowlink COLOR="#4f7ffc" DESTINATION="ID_976705384" ENDARROW="Default" ENDINCLINATION="-55;132;" ID="Arrow_ID_1285375088" STARTARROW="Default" STARTINCLINATION="-5;-77;"/>
|
|
<node CREATED="1434128393429" ID="ID_1275202366" MODIFIED="1518487921095" TEXT="muß GenNode sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1434128412934" ID="ID_1319614474" MODIFIED="1561827465826" TEXT="Repräs entscheiden">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1434128438565" ID="ID_913220298" MODIFIED="1512926192335" TEXT="als ID erkennbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
heißt: in der Diff-Verarbeitung wird dieser spezielle check verwendet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5bf0d0" DESTINATION="ID_913220298" ENDARROW="Default" ENDINCLINATION="366;-59;" ID="Arrow_ID_806648905" SOURCE="ID_1563625085" STARTARROW="None" STARTINCLINATION="347;320;"/>
|
|
<node CREATED="1434128740117" ID="ID_1537979881" MODIFIED="1434128764209" TEXT="spezielles Baumuster"/>
|
|
<node CREATED="1434128764893" ID="ID_1430586148" MODIFIED="1434128768689" TEXT="Gefahr von clashes"/>
|
|
<node CREATED="1434128769325" ID="ID_866845827" MODIFIED="1512926192335" TEXT="entscheide">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1434128779661" ID="ID_1739097548" MODIFIED="1434236311060" TEXT="marker-ID + string-Payload">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1434128917125" ID="ID_392407967" MODIFIED="1436021562160" TEXT=""fehlkonstruierte" ID + prüf-Prädikat">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1434128981381" ID="ID_101281763" MODIFIED="1436042656881" TEXT="spezielle Ref-Payload">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
m.E. die einzig saubere Desgin-Variante!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1436021576224" ID="ID_1239136010" MODIFIED="1512926192336" TEXT="Begründung">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1436021581655" ID="ID_124352424" MODIFIED="1436021603779" TEXT="hash-identische ID sorgt für transparente Integration"/>
|
|
<node CREATED="1436021610648" ID="ID_1621632066" MODIFIED="1436021618067" TEXT="das nimmt Komplexität aus der Anwendung heraus"/>
|
|
<node CREATED="1436021623799" ID="ID_929212705" MODIFIED="1436021637115" TEXT="für die Dereferenzierung zahlt nur die Referenz"/>
|
|
<node CREATED="1436021694039" ID="ID_1657867881" MODIFIED="1436021817445" TEXT="Nachteil ist Gefahr der Verwirrung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
man kann alternativ auch eine RecordRef direkt in eine elementare GenNode packen
|
|
</li>
|
|
<li>
|
|
diese verhält sich dann nicht transparent, denn sie hat eine andere Identität als ihr Ziel
|
|
</li>
|
|
<li>
|
|
das kann aber als spezielles Ausdrucksmittel genutzt werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1436021719055" ID="ID_1039111553" MODIFIED="1436021730099" TEXT="ist nur ein halber Nachteil"/>
|
|
<node CREATED="1436021731615" ID="ID_1576857183" MODIFIED="1436021741970" TEXT="kann nämlich auch Ausdrucksmittel sein"/>
|
|
<node CREATED="1436021848790" ID="ID_742066846" MODIFIED="1436021874042" TEXT="problematisch ist die Implementerung des Erkennungs-Prädikates"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434128446029" ID="ID_1779802587" MODIFIED="1512926192338" TEXT="hash-identisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
heißt: wird direkt von standard-equality so behandelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1434128685597" ID="ID_690649535" MODIFIED="1434128705631">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauche speziellen Builder,
|
|
</p>
|
|
<p>
|
|
der das so fabriziert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1434128706589" ID="ID_1001559218" MODIFIED="1512926192339">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bekomme einen
|
|
</p>
|
|
<p>
|
|
"ungenutzten" DataCap
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1434128996949" ID="ID_654762061" MODIFIED="1434239007746" TEXT="könnte zur Ref ausgebaut werden">
|
|
<linktarget COLOR="#00ff33" DESTINATION="ID_654762061" ENDARROW="Default" ENDINCLINATION="-390;37;" ID="Arrow_ID_724106052" SOURCE="ID_819452470" STARTARROW="Default" STARTINCLINATION="-48;187;"/>
|
|
</node>
|
|
<node CREATED="1434130839653" HGAP="22" ID="ID_60404225" MODIFIED="1512926192341" VSHIFT="8">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Idee: <font color="#990033"><b>Ref-GenNode</b></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#66ff66" DESTINATION="ID_1688475597" ENDARROW="Default" ENDINCLINATION="219;91;" ID="Arrow_ID_57985873" STARTARROW="Default" STARTINCLINATION="23;-52;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1434130866693" ID="ID_1402852366" MODIFIED="1434130886826">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
als Ref erkennbar
|
|
</p>
|
|
<p>
|
|
<font size="1">(Prädikat)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1434130888581" ID="ID_369455584" MODIFIED="1434130912181">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hash-identische
|
|
</p>
|
|
<p>
|
|
Ziel-ID ableitbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1434206472689" ID="ID_561057428" MODIFIED="1434206482829" TEXT="Variant-Subklasse"/>
|
|
<node CREATED="1434206483657" ID="ID_473311646" MODIFIED="1434206508445" TEXT="Cast auf Rec-Typ prüfen"/>
|
|
<node CREATED="1434206509201" ID="ID_717222987" MODIFIED="1434206522117" TEXT="nur Ref-Fall zahlt Overhead"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1434129043245" ID="ID_1120430427" MODIFIED="1518487921095" TEXT="brauchen wir einen ref-Typ">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1434129063053" ID="ID_1242923371" MODIFIED="1518487921095">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verarbeiten
|
|
</p>
|
|
<p>
|
|
von Teilbäumen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1436019533354" ID="ID_1500539399" MODIFIED="1518487921095" TEXT="Konzept-Bruch">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1436042718309" ID="ID_109270255" MODIFIED="1518487921095" TEXT="Ja!">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573834946400" ID="ID_1344414345" MODIFIED="1573834960224" TEXT="Ergänzungen/Weiterungen">
|
|
<icon BUILTIN="stop"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1573834997505" ID="ID_358670935" MODIFIED="1573835010544" TEXT="Diagnose">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1573834982323" ID="ID_1326387627" MODIFIED="1573834995669" TEXT="Hilfen zur Erzeugung">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1573835265349" ID="ID_352943196" MODIFIED="1573835276049" TEXT="Diff-Anwendung einbinden">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1611218580537" ID="ID_1387738684" MODIFIED="1611218916752" TEXT=""habituellen" Standard-Fall etablieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611218653199" ID="ID_353919229" MODIFIED="1611218879611" TEXT="einzelne Objekt-Properties werden explizit gebunden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611218673196" ID="ID_104829523" MODIFIED="1611218882295" TEXT="ansonsten nur Sub-Collections">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1611218685874" ID="ID_503186465" MODIFIED="1611218887833" TEXT="STL-Collection von Smart-Pointern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611218698241" ID="ID_766067661" MODIFIED="1611218890019" TEXT="das Pointee ist wieder DiffMutable">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611218724397" ID="ID_495328814" MODIFIED="1611218907878" TEXT="Bindungs-Schema">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1611218730812" ID="ID_718558563" MODIFIED="1611218900241" TEXT="der Selector prüft ein Typfeld">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1611218788908" ID="ID_1503520124" MODIFIED="1611218900241" TEXT="der Matcher prüft die Objekt-ID">
|
|
<arrowlink COLOR="#4a72bc" DESTINATION="ID_1274607629" ENDARROW="Default" ENDINCLINATION="366;0;" ID="Arrow_ID_289559805" STARTARROW="None" STARTINCLINATION="155;13;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1611218813169" ID="ID_1174818531" MODIFIED="1611218900241" TEXT="der Konstruktor enthält das relevante Closure-Binding">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611218846053" ID="ID_1626706964" MODIFIED="1611402381612" TEXT="Standard-Implementierung für den rekursiven Kind-Mutator">
|
|
<arrowlink COLOR="#64b2d0" DESTINATION="ID_341242193" ENDARROW="Default" ENDINCLINATION="-1947;126;" ID="Arrow_ID_1779456185" STARTARROW="None" STARTINCLINATION="1123;53;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611402402991" ID="ID_1274607629" MODIFIED="1611402440457" TEXT="Standard-Implementierung für Matcher auf Objekt-ID">
|
|
<linktarget COLOR="#4a72bc" DESTINATION="ID_1274607629" ENDARROW="Default" ENDINCLINATION="366;0;" ID="Arrow_ID_289559805" SOURCE="ID_1503520124" STARTARROW="None" STARTINCLINATION="155;13;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573835763482" ID="ID_1220310042" MODIFIED="1576441741737" TEXT="Problem: Slave-Collection">
|
|
<arrowlink COLOR="#519b84" DESTINATION="ID_727500820" ENDARROW="Default" ENDINCLINATION="-67;7;" ID="Arrow_ID_115955006" STARTARROW="None" STARTINCLINATION="71;200;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1573835793926" ID="ID_13734498" MODIFIED="1573835796913" TEXT="Situation">
|
|
<node CREATED="1573835798165" ID="ID_71062099" MODIFIED="1573835827477" TEXT="Diff-System verwaltet eine Master-Collection (Node-Children)"/>
|
|
<node CREATED="1573835830889" ID="ID_866446286" MODIFIED="1573835845435" TEXT="jedes Element in dieser hat einen/mehrere Delegates"/>
|
|
<node CREATED="1573835848966" ID="ID_1735677052" MODIFIED="1573835898353">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
diese Delegates sind <i>anderswo </i>in eine Collection eingebunden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1573835862988" ID="ID_1733434217" MODIFIED="1573835890810">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und deren Reihenfolge <i>ist dort </i>von Bedeutung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1573837634757" ID="ID_101148427" MODIFIED="1575577381370" TEXT="Aufgabe: Ordnung (re)Konstruieren">
|
|
<linktarget COLOR="#624d7d" DESTINATION="ID_101148427" ENDARROW="Default" ENDINCLINATION="-3637;-782;" ID="Arrow_ID_498364014" SOURCE="ID_646844971" STARTARROW="None" STARTINCLINATION="2862;94;"/>
|
|
<linktarget COLOR="#624d7d" DESTINATION="ID_101148427" ENDARROW="Default" ENDINCLINATION="-3637;-782;" ID="Arrow_ID_1277214644" SOURCE="ID_350484232" STARTARROW="None" STARTINCLINATION="3792;340;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1573837829595" ID="ID_613778773" MODIFIED="1573837833320" TEXT="immer wenn...">
|
|
<node CREATED="1573837834482" ID="ID_980057100" MODIFIED="1573837839549" TEXT="ein Element hinzugekommen ist"/>
|
|
<node CREATED="1573837840543" ID="ID_749166782" MODIFIED="1573837845620" TEXT="ein Element entfernt wurde"/>
|
|
<node CREATED="1573837847552" ID="ID_1255347678" MODIFIED="1573837852995" TEXT="Element umgeordnet wurden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576441498133" ID="ID_1914385407" MODIFIED="1576441705766">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauche Detektor für <i>structural change</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#2340b6" DESTINATION="ID_1914385407" ENDARROW="Default" ENDINCLINATION="-316;5;" ID="Arrow_ID_960988463" SOURCE="ID_727500820" STARTARROW="None" STARTINCLINATION="306;48;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1576168044826" ID="ID_230800629" MODIFIED="1576441618407" TEXT="#1206 diff structure change listener">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576360824678" ID="ID_1466401339" MODIFIED="1576441463530" TEXT="API definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576360879043" ID="ID_1998526926" MODIFIED="1576361042423" TEXT="Entscheidung: allgemein in TreeMutator-DSL">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...man könnte auch auf die Idee kommen, es nur in das Collection-Binding einzuhängen.
|
|
</p>
|
|
<p>
|
|
Das wäre aber zu kurz gedacht; auch wenn im Moment dieses die einzige Implementierung ist, die den Listener tatsächlich triggern kann, verbietet uns niemand in der Zukunft, noch eine anderes TreeMutator-Binding zu erfinden. Hinzu kommt, daß ein Listener zusätzliche Storage und zusätzlichen Aufwand bedeutet, und deshalb besser als eigener »onion layer« implementiert wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576361062012" ID="ID_591681960" MODIFIED="1576441459874" TEXT="Name: onSeqChange(lambda)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576189076819" FOLDED="true" ID="ID_817894648" MODIFIED="1576441575820" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576189086866" ID="ID_99179892" MODIFIED="1576189103864" TEXT="Ansatzpunkt: TreeMutator">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576189115934" ID="ID_1929426370" MODIFIED="1576189130272" TEXT="vermutlich direkt in's collection-binding"/>
|
|
<node COLOR="#338800" CREATED="1576189131908" ID="ID_1843660348" MODIFIED="1576441468375" TEXT="brauche Testfall">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576189189125" FOLDED="true" ID="ID_791562073" MODIFIED="1576282487252" TEXT="huch... brauche einfachen Diff-Test">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1576281969322" ID="ID_163244559" MODIFIED="1576281981742">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar etwas <i>wirklich Einfaches</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1576281982520" ID="ID_1973953856" MODIFIED="1576282009657" TEXT="und nicht etwas Elementares">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn "elementar" bedeutet in diesem Fall, es wird ziemlich technisch und komplex
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576199505619" FOLDED="true" ID="ID_1589343634" MODIFIED="1576281940111" TEXT="erweitern auf einfaches Vector-Binding">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1576199519956" ID="ID_446671513" MODIFIED="1576281889609" TEXT="AUA... Inkonsistenzen im Collection-Binding">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
oh ja....
|
|
</p>
|
|
<p>
|
|
das war ziemlich halbgar, und wäre früher oder später ganz übel in's Auge gegangen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Erinnere mich, daß ich damals beim Einführen des MockElm dann eben doch eine »Attribute-Map« gebaut habe, obwohl ich vorher mich eigentlich gegen dieses Konzept entschieden hatte. Es ist in der Praxis dann doch manchmal sinnvolle, wie dieser Fall zeigt. Damit wurde aber mein TreeMutator-Collection-Binding "wackelig", und ich hab mich da mehr oder weniger durchgefrickelt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Jetzt gibt es also echte ContainerTraits, und damit ist der Aufbau zukunftsfest.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1576281616730" ID="ID_1695910920" MODIFIED="1576281693124" TEXT="gelöst durch Einführen von ContainerTraits">
|
|
<arrowlink COLOR="#2eb28a" DESTINATION="ID_640546093" ENDARROW="Default" ENDINCLINATION="-191;-682;" ID="Arrow_ID_562122794" STARTARROW="None" STARTINCLINATION="485;33;"/>
|
|
</node>
|
|
<node CREATED="1576281921050" ID="ID_1921471268" MODIFIED="1576281938762" TEXT="erkennt nun sogar von STL-Containern abgeleitete Typen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576281890992" ID="ID_171789869" MODIFIED="1576281906090" TEXT="gutdaßwirdarübergeredethaben">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="10"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576359839479" ID="ID_1358290407" MODIFIED="1576441467264" TEXT="direkt an die Test-Klasse binden, incl Listener">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576361096645" ID="ID_643127461" MODIFIED="1576441434562" TEXT="Change-Listener-Layer implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1576366663548" ID="ID_656541265" MODIFIED="1576366682488" TEXT="Arbeitsmuster definieren">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1576366684169" ID="ID_110323698" MODIFIED="1576366703873" TEXT="TreeMutator is disposable one-way">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576366712798" ID="ID_801623795" MODIFIED="1576366723977" TEXT="d.h. wir setzen eine Flag direkt im Objekt"/>
|
|
</node>
|
|
<node CREATED="1576366728980" ID="ID_1022783655" MODIFIED="1576366739950" TEXT="welche Operationen?">
|
|
<node CREATED="1576367767800" ID="ID_1235301864" MODIFIED="1576367778488" TEXT="siehe tree-diff.cpp">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576366782896" ID="ID_179852387" MODIFIED="1576367797511" TEXT="INS -> injectNew"/>
|
|
<node CREATED="1576366789484" ID="ID_405222529" MODIFIED="1576367822460" TEXT="DEL -> skipSrc"/>
|
|
<node CREATED="1576366797722" ID="ID_1163886447" MODIFIED="1576367834487" TEXT="FIND -> findSrc"/>
|
|
<node CREATED="1576366804866" ID="ID_1100124063" MODIFIED="1576367840849" TEXT="SKIP -> skipSrc"/>
|
|
<node CREATED="1576366806910" FOLDED="true" ID="ID_1967747316" MODIFIED="1576367751236" TEXT="AFTER">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1576366810811" ID="ID_604915658" MODIFIED="1576366818740" TEXT="aber nicht AFTER (Ref::END)"/>
|
|
<node CREATED="1576366829887" ID="ID_1189421464" MODIFIED="1576366936668" TEXT="weil ein dediziertes AFTER zum partiellen Akzeptieren verwendet werden könnte"/>
|
|
<node COLOR="#435e98" CREATED="1576366942761" ID="ID_1416606569" MODIFIED="1576367685024" TEXT="Vorsicht ... da ist eine Lücke im Argument">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1576367086708" ID="ID_1929510503" MODIFIED="1576367168398" TEXT="man kann indirekt das Ende kappen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...indem man nur teilweise PICK-Verben sendet, und dann einfach weggeht.
|
|
</p>
|
|
<p>
|
|
Dann wir der Rest mit dem Mutator zusammen weggeworfen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1576367169888" ID="ID_1591005930" MODIFIED="1576367275787">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
um <i>das</i> zu unterbinden, müßten alle Binding-Layer kollaborieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
..weil man diesen Umstand nicht generisch erkennen kann.
|
|
</p>
|
|
<p>
|
|
Nach gegenwärtigem Stand kann das nur im Collection-Binding auftreten;
|
|
</p>
|
|
<p>
|
|
dieses aber hätte auch die notwendigen Informationen, um diese Situation zu erkennen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1576367369197" ID="ID_1086320549" MODIFIED="1576367380152" TEXT="HA! daran hab ich schon gedacht">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576367381612" ID="ID_197359864" MODIFIED="1576367388367" TEXT="TreeMutator::completeScope()"/>
|
|
<node CREATED="1576367467232" ID="ID_1177835259" MODIFIED="1576367468924" TEXT="TreeDiffMutatorBinding::__expect_end_of_scope"/>
|
|
<node CREATED="1576367469960" ID="ID_785965079" MODIFIED="1576367476719" TEXT="aufgerufen von EMU"/>
|
|
<node CREATED="1576367477423" ID="ID_1067589529" MODIFIED="1576367508185" TEXT="CollectionBinding prüft tatsächlich auf Vollständigkeit hier">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. es prüft, ob keine Elemente im Arbeitspuffer übrig sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576367510259" ID="ID_1290532508" MODIFIED="1576367530122" TEXT="leider bleibt top-level hier außen vor">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576367556845" ID="ID_1005031158" MODIFIED="1576367744992" TEXT="Konsequenz: ein solches DIFF ist formal nicht korrekt">
|
|
<arrowlink COLOR="#ca636f" DESTINATION="ID_332168125" ENDARROW="Default" ENDINCLINATION="23;-62;" ID="Arrow_ID_761091686" STARTARROW="None" STARTINCLINATION="-147;8;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576367573138" ID="ID_332168125" MODIFIED="1576367744992" TEXT="STOP. Dieser fall ist mithin zu 99% redundant">
|
|
<linktarget COLOR="#ca636f" DESTINATION="ID_332168125" ENDARROW="Default" ENDINCLINATION="23;-62;" ID="Arrow_ID_761091686" SOURCE="ID_1005031158" STARTARROW="None" STARTINCLINATION="-147;8;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1576367626367" ID="ID_1026459150" MODIFIED="1576367638221" TEXT="es bleibt zwar eine Lücke auf top-level"/>
|
|
<node CREATED="1576367638889" ID="ID_829309668" MODIFIED="1576367650884" TEXT="aber rein formal sollte es nicht auftreten"/>
|
|
<node CREATED="1576367652203" ID="ID_141662474" MODIFIED="1576367665480" TEXT="und damit wird AFTER selber immer neutral sein"/>
|
|
<node CREATED="1576367666205" ID="ID_392117818" MODIFIED="1576367677816" TEXT="und es braucht dann schon ein explizites INS, DEL, FIND, SKIP"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576377684248" ID="ID_1419015987" MODIFIED="1576414100918" TEXT="Probleme mit der Builder-Konstruktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576377697727" ID="ID_202863640" MODIFIED="1576377709748" TEXT="Template-Error....">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1576377711045" ID="ID_108442931" MODIFIED="1576377734670" TEXT="seltsamerweise... denn im Prinzip das Gleiche funktioniert doch für collection und Attribute"/>
|
|
<node CREATED="1576378164751" ID="ID_326483835" MODIFIED="1576378173210" TEXT="mehrere Probleme">
|
|
<node COLOR="#435e98" CREATED="1576378177126" ID="ID_940209297" MODIFIED="1576413723637" TEXT="doppelt gewickelter Builder tritt auf">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576378190100" ID="ID_1161663563" MODIFIED="1576413711984" TEXT="Verdacht: implizite Konversion?">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1576378201634" ID="ID_1282623104" MODIFIED="1576378225818" TEXT="mache mal den Builder-ctor explizit">
|
|
<node CREATED="1576378226991" ID="ID_553975580" MODIFIED="1576378241185" TEXT="den ein-elementigen Template ctor"/>
|
|
<node CREATED="1576378241893" ID="ID_1087579586" MODIFIED="1576378246208" TEXT="mit move-Argument"/>
|
|
<node CREATED="1576378247040" ID="ID_1200403421" MODIFIED="1576378259841" TEXT="denn der könnte versehentlich einen Move-ctor generieren"/>
|
|
</node>
|
|
<node CREATED="1576378261915" ID="ID_564333709" MODIFIED="1576378272885" TEXT="einige Stellen im Code repariert"/>
|
|
<node CREATED="1576378273593" ID="ID_539526347" MODIFIED="1576378331296" TEXT="ist wohl insgesamt besser so, da explizit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn <i>einfacher</i> wird der Code dadurch nicht, nur kürzer.
|
|
</p>
|
|
<p>
|
|
Und mühsam für den Leser ist er so oder so... dann also lieber alles ausschreiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576378343418" ID="ID_1269344650" MODIFIED="1576413734213" TEXT="angeblich Aufruf gesperrter Copy-Ctorn">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1576378359957" ID="ID_1488794757" MODIFIED="1576378478485" TEXT="das ist immer ein Ketten-Argument">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da muß man auch erst mal drauf kommen, was einem der Compiler da so sagen will.
|
|
</p>
|
|
<p>
|
|
use of deleted function <some copy-ctor>
|
|
</p>
|
|
<p>
|
|
note: function <some-copy-ctor> is deleted, because the default definition would be ill formed
|
|
</p>
|
|
<p>
|
|
error: <b>...und hier kommt nun die default-definition... </b>
|
|
</p>
|
|
<p>
|
|
<i>und damit wiederholt sich das Ketten-Argument bis zur Basisklasse runter!!!</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1576378488388" ID="ID_467081251" MODIFIED="1576378531986" TEXT="schließlich lande ich beim class TreeMutator : util::MoveOnly"/>
|
|
<node CREATED="1576378541509" ID="ID_1269318107" MODIFIED="1576378548503" TEXT="wenn ich das entferne....">
|
|
<node CREATED="1576378549586" ID="ID_557832776" MODIFIED="1576378560918" TEXT="und auch noch diverse redundante definitionen mit dazu"/>
|
|
<node CREATED="1576378561650" ID="ID_270407327" MODIFIED="1576378578043" TEXT="(beachte: sobald irgendwo ein Move-ctor definiert ist, gibt es keinen copy-ctor mehr)"/>
|
|
</node>
|
|
<node CREATED="1576378580863" ID="ID_761583276" MODIFIED="1576378586645" TEXT="...dann gehts"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576378589343" ID="ID_1164539927" MODIFIED="1576413693950" TEXT="also: irgendwo schwenkt die Kette auf einen copy-ctor um">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1576378609851" ID="ID_669880694" MODIFIED="1576413678942" TEXT="Frage-1 : wo?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1576413599727" ID="ID_601054330" MODIFIED="1576413602019" TEXT="in Detector4StructuralChanges"/>
|
|
<node CREATED="1576413602872" ID="ID_1037688378" MODIFIED="1576413616834" TEXT="der hat einen explizit definierten dtor"/>
|
|
<node CREATED="1576413622373" ID="ID_676470389" MODIFIED="1576413665197" TEXT="und damit keinen impliziten move-ctor mehr!!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
selbst wenn er über x Basisklassen von MoveOnly erbt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1576378616851" ID="ID_1283591083" MODIFIED="1576413685202" TEXT="Frage-2 : warum?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1576410342653" ID="ID_1010651919" MODIFIED="1576413594966" TEXT="weil der betr. move-Ctor nicht (implizit) definiert ist">
|
|
<arrowlink COLOR="#4963d8" DESTINATION="ID_1999847041" ENDARROW="Default" ENDINCLINATION="-4316;0;" ID="Arrow_ID_809724531" STARTARROW="None" STARTINCLINATION="-6312;349;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576416522053" ID="ID_910911447" MODIFIED="1576418727445" TEXT="listener wird nicht getriggert">
|
|
<linktarget COLOR="#3fe09e" DESTINATION="ID_910911447" ENDARROW="Default" ENDINCLINATION="-217;7;" ID="Arrow_ID_929225071" SOURCE="ID_159550911" STARTARROW="None" STARTINCLINATION="-2;-97;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1576416597927" ID="ID_805984773" MODIFIED="1576416619356" TEXT="ctor vom top-Level nicht aufgerufen"/>
|
|
<node CREATED="1576416620136" ID="ID_1598925580" MODIFIED="1576416632057" TEXT="denn der top-Level-TreeMutator lebt weiter"/>
|
|
<node CREATED="1576416632790" ID="ID_141285194" MODIFIED="1576416640381" TEXT="...solange der DiffApplikator lebt"/>
|
|
<node CREATED="1576416641269" ID="ID_605158809" MODIFIED="1576416645584" TEXT="ist das gut so?">
|
|
<node CREATED="1576416647561" ID="ID_486491592" MODIFIED="1576416658877" TEXT="viele Tests verwenden den Applikator mehrfach"/>
|
|
<node CREATED="1576416659587" ID="ID_791956106" MODIFIED="1576416715929" TEXT="nicht jedoch die produktive Verwendung in ctrl::Nexus::change (ID, MutationMessage&& diff)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1576416749566" ID="ID_1371891888" MODIFIED="1576417191286" TEXT="das könnte später auch ein Ansatzpunkt für Caching sein">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1576417156080" ID="ID_1679161356" MODIFIED="1576417199243" TEXT="aber: jede neue Anwendung konstruiert einen neuen TreeMutator">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576417208152" ID="ID_974220547" MODIFIED="1576418711474" TEXT="also braucht die Diff-Anwendung einen Abschluß">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576189140651" FOLDED="true" ID="ID_835328626" MODIFIED="1576441578044" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1576189161697" ID="ID_1786250967" MODIFIED="1576441422008" TEXT="Strukturänderungen triggern Listener">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1576416511260" ID="ID_159550911" MODIFIED="1576418741174" TEXT="tut noch nicht...">
|
|
<arrowlink COLOR="#3fe09e" DESTINATION="ID_910911447" ENDARROW="Default" ENDINCLINATION="-217;7;" ID="Arrow_ID_929225071" STARTARROW="None" STARTINCLINATION="-2;-97;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576419878367" ID="ID_1026985691" MODIFIED="1576441431851" TEXT="sonstiger Testfall läuft nicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1576419891302" ID="ID_1789182359" MODIFIED="1576441417632" TEXT="mein spezielles SET-Val-Konstrukt scheitert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576419910287" ID="ID_1413678907" MODIFIED="1576419939398" TEXT="default-Binding für collection definiert Matcher">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
matchElement([](GenNode const& spec, ELM const& elm)
|
|
</p>
|
|
<p>
|
|
                         {
|
|
</p>
|
|
<p>
|
|
                           return spec.matches(elm);
|
|
</p>
|
|
<p>
|
|
                         })
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1576419949229" ID="ID_1686698811" MODIFIED="1576419955465" TEXT="spec.matches(elm)"/>
|
|
<node CREATED="1576419966419" ID="ID_394542951" MODIFIED="1576419977223" TEXT="GenNode::match(string)"/>
|
|
<node CREATED="1576419982536" ID="ID_1434821598" MODIFIED="1576419998348" TEXT="data.matchText">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1576420000406" ID="ID_241418574" MODIFIED="1576420012017" TEXT="d.h. er matcht gegen den Content"/>
|
|
<node CREATED="1576420021236" ID="ID_1847609894" MODIFIED="1576420035463" TEXT="und nicht gegen die ID, wie ich geglaubt habe">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576420037817" ID="ID_1216654521" MODIFIED="1576441407046" TEXT="brauche wohl speziellen Matcher">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576189172445" ID="ID_1803915875" MODIFIED="1576441423630" TEXT="andere Änderungen triggern nicht">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1573835063441" ID="ID_1630863893" MODIFIED="1573835079773" TEXT="Architektur-Anpassungen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1573835082117" ID="ID_1921828362" MODIFIED="1573835086169" TEXT="Konsequenzen">
|
|
<node CREATED="1573835152100" ID="ID_31277125" MODIFIED="1573835175700" TEXT="Spannungen mit einem konvetionellen Datenmodell"/>
|
|
</node>
|
|
<node CREATED="1573835389094" ID="ID_1063481542" MODIFIED="1573835396665" TEXT="Protokoll-Adapter">
|
|
<node CREATED="1573837337894" ID="ID_414910178" MODIFIED="1573837342377" TEXT="Observer">
|
|
<node CREATED="1573837508831" ID="ID_1332948192" MODIFIED="1573837531855" TEXT="onChangeLocal">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1573837514565" ID="ID_1974559184" MODIFIED="1573837528817" TEXT="onChangeSubtree">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1573837592850" ID="ID_727500820" MODIFIED="1582988538202" TEXT="onSeqChange">
|
|
<arrowlink COLOR="#2340b6" DESTINATION="ID_1914385407" ENDARROW="Default" ENDINCLINATION="-316;5;" ID="Arrow_ID_960988463" STARTARROW="None" STARTINCLINATION="306;48;"/>
|
|
<linktarget COLOR="#4d8b82" DESTINATION="ID_727500820" ENDARROW="Default" ENDINCLINATION="-1160;0;" ID="Arrow_ID_680446238" SOURCE="ID_1492167964" STARTARROW="None" STARTINCLINATION="-1645;0;"/>
|
|
<linktarget COLOR="#519b84" DESTINATION="ID_727500820" ENDARROW="Default" ENDINCLINATION="-67;7;" ID="Arrow_ID_115955006" SOURCE="ID_1220310042" STARTARROW="None" STARTINCLINATION="71;200;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1584309662354" ID="ID_274485695" MODIFIED="1584309897727" TEXT="onLocalChange">
|
|
<linktarget COLOR="#427176" DESTINATION="ID_274485695" ENDARROW="Default" ENDINCLINATION="-1913;0;" ID="Arrow_ID_1484023114" SOURCE="ID_161551669" STARTARROW="None" STARTINCLINATION="926;63;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1584309681495" HGAP="26" ID="ID_466790810" MODIFIED="1584309702146" TEXT="einfache Ergänzung" VSHIFT="14"/>
|
|
<node CREATED="1584309688390" ID="ID_9063913" MODIFIED="1584309697322" TEXT="schließt auch Wert-Zuweisungen mit ein"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1475449611754" FOLDED="true" HGAP="33" ID="ID_1285123321" MODIFIED="1576281597012" TEXT="Grundsatzfrage: Attribut-Map" VSHIFT="1">
|
|
<linktarget COLOR="#ef6e6e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="-571;0;" ID="Arrow_ID_524729956" SOURCE="ID_275833424" STARTARROW="None" STARTINCLINATION="886;42;"/>
|
|
<linktarget COLOR="#9f719e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="170;-624;" ID="Arrow_ID_23523127" SOURCE="ID_1739941135" STARTARROW="None" STARTINCLINATION="875;242;"/>
|
|
<linktarget COLOR="#b85f4e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="-735;0;" ID="Arrow_ID_1644325647" SOURCE="ID_854221294" STARTARROW="None" STARTINCLINATION="-651;70;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475449654357" ID="ID_1802368116" MODIFIED="1475449659480" TEXT="Ordnung / Unordnung"/>
|
|
<node CREATED="1475449660020" ID="ID_286191859" MODIFIED="1475449740005" TEXT="Diff geht von Listen-Ordnung aus">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1475449777532" ID="ID_476663339" MODIFIED="1575133341421" TEXT="Symptom: Compile-Fehler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Map hat kein emplace_back
|
|
</li>
|
|
<li>
|
|
Map hat kein back()
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Beides ist erst mal sinnvoll. Map hat zwar ein emplace, aber das fügt eben <i>irgendwo</i> ein
|
|
</p>
|
|
<p>
|
|
Und es gibt nicht sowas wie das "zuletzt behandelte" Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1475506967550" HGAP="42" ID="ID_1112268061" MODIFIED="1576203628630" TEXT="ist aber implementierbar" VSHIFT="8">
|
|
<arrowlink COLOR="#9f96d9" DESTINATION="ID_453712930" ENDARROW="Default" ENDINCLINATION="722;-59;" ID="Arrow_ID_1263259661" STARTARROW="Default" STARTINCLINATION="1873;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1475449719180" ID="ID_6178930" MODIFIED="1533608413999" TEXT="Sinnvoll das zu erweitern">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1475450034810" ID="ID_445949466" MODIFIED="1561827465612" TEXT="pro">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1475450042009" FOLDED="true" ID="ID_1941838908" MODIFIED="1561827483837" TEXT="man könnte">
|
|
<node CREATED="1475450050824" ID="ID_1660008285" MODIFIED="1475450053243" TEXT="ins"/>
|
|
<node CREATED="1475450055775" ID="ID_1213643084" MODIFIED="1475450058698" TEXT="after::END"/>
|
|
<node CREATED="1475450064470" ID="ID_754885592" MODIFIED="1475450069265" TEXT="assign / mutate"/>
|
|
</node>
|
|
<node CREATED="1475450148771" FOLDED="true" ID="ID_736367412" MODIFIED="1561827483837">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Reihenfolge
|
|
</p>
|
|
<p>
|
|
erhalten!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1475450179591" ID="ID_793985703" MODIFIED="1475450197936" TEXT="dann sogar del"/>
|
|
<node CREATED="1475450053927" ID="ID_1110207658" MODIFIED="1475450055018" TEXT="pick"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475450038953" ID="ID_1285250844" MODIFIED="1561827465614" TEXT="con">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1475450285336" ID="ID_288261682" MODIFIED="1475450300712" TEXT="kein Schutz gegen sinnlose Operationen"/>
|
|
<node CREATED="1475450229944" ID="ID_957217069" MODIFIED="1475450239042" TEXT="Reihenfolge ist Impl-Detail"/>
|
|
<node CREATED="1475450240318" ID="ID_1993698586" MODIFIED="1575133341545" TEXT="Hashmap">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...hat eine "zufällige" Reihenfolge, die von den Hash-Werten der gespeicherten Daten abhängt.
|
|
</p>
|
|
<p>
|
|
Das bricht mit unserem grundsätzlichen Konzept der <b>kongruenten</b>  Daten-Strukturen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1475450272442" ID="ID_567969130" MODIFIED="1575133341561" TEXT="inkompatibel mit GenNode">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ein Diff, das von einer ETD gezogen wurde,
|
|
</p>
|
|
<p>
|
|
läßt sich nicht auf eine Map-Implementierung aufspielen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475506346525" ID="ID_574367406" MODIFIED="1533608414015" VSHIFT="6">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1475506358863" ID="ID_120379432" MODIFIED="1475506391795" TEXT="wird nicht empfohlen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="13"/>
|
|
</node>
|
|
<node CREATED="1475506368078" ID="ID_1568414977" MODIFIED="1475506381941" TEXT="vollständigkeitshalber unterstützt">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1475506411768" ID="ID_583086851" MODIFIED="1575133341643" TEXT="kann sinnvoll sein...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...zum Beispiel wie grade hier, beim MockElm
|
|
</p>
|
|
<p>
|
|
das wird vermutlich niemals wirklich in einem vollen Diff-Zusammenhang gebraucht.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und dann ist unbestreitbar eine Map eine sehr einfache Implementierung
|
|
</p>
|
|
<p>
|
|
und auch im Diff-Applikator nicht wirklich schwierig zu unterstützen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1475506514203" HGAP="45" ID="ID_1183193114" MODIFIED="1561827465614" TEXT="Begründung" VSHIFT="23">
|
|
<node CREATED="1475506528937" ID="ID_1971084550" MODIFIED="1475506538324" TEXT="es verletzt die Prinzipien"/>
|
|
<node CREATED="1475506538983" ID="ID_1555995664" MODIFIED="1475506547491" TEXT="insofern aber wie Feld-Attribute auch"/>
|
|
<node CREATED="1475506549886" ID="ID_275560362" MODIFIED="1475506558609" TEXT="eingeschränkt unterstützbar"/>
|
|
<node CREATED="1475506559309" ID="ID_1767038604" MODIFIED="1475506896798" TEXT="Objekt -> ETD -> Objekt">
|
|
<arrowlink COLOR="#807bce" DESTINATION="ID_1795458386" ENDARROW="Default" ENDINCLINATION="671;0;" ID="Arrow_ID_1621793396" STARTARROW="Default" STARTINCLINATION="994;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443733567706" FOLDED="true" HGAP="325" ID="ID_143203937" MODIFIED="1573834336766" TEXT="Diff-Language" VSHIFT="41">
|
|
<cloud COLOR="#cfba9d"/>
|
|
<linktarget COLOR="#a9acc1" DESTINATION="ID_143203937" ENDARROW="Default" ENDINCLINATION="115;-2033;" ID="Arrow_ID_136706418" SOURCE="ID_1091994004" STARTARROW="None" STARTINCLINATION="1656;0;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1443733726563" ID="ID_410650103" MODIFIED="1443733731422" TEXT="Grundlagen">
|
|
<node CREATED="1443733732938" ID="ID_73184558" MODIFIED="1443733737277" TEXT="Folge von Verben"/>
|
|
<node CREATED="1443733738296" ID="ID_994909291" MODIFIED="1443733743181" TEXT="konstante Größe"/>
|
|
<node CREATED="1443733744169" ID="ID_1410679171" MODIFIED="1443733756330" TEXT="ein Argument pro Verb"/>
|
|
<node CREATED="1443733768621" ID="ID_183648684" MODIFIED="1443733796453">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Interpreter</b> definiert Sprache
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#56397a" CREATED="1443733800322" ID="ID_1544242343" MODIFIED="1488423307267" TEXT="Nutz-Muster">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<node CREATED="1443733822780" ID="ID_756812969" MODIFIED="1512926192344" TEXT="Basis-Fälle">
|
|
<node CREATED="1443733856089" ID="ID_1358940500" MODIFIED="1512926192345">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ROOT
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1443733978248" ID="ID_724172314" MODIFIED="1443733983252" TEXT="Wurzel pflanzen"/>
|
|
<node CREATED="1443733984336" ID="ID_109703386" MODIFIED="1443733993674" TEXT="Außerhalb der Sprache"/>
|
|
<node CREATED="1443733994310" ID="ID_52662692" MODIFIED="1443733998417" TEXT="...oder rekursiv"/>
|
|
</node>
|
|
<node CREATED="1443733868958" ID="ID_676848577" MODIFIED="1512926192345">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
INIT
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1443734005660" ID="ID_1028914628" MODIFIED="1512926192346">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
leeres
|
|
</p>
|
|
<p>
|
|
Objekt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1443734026466" ID="ID_1051774321" MODIFIED="1512926192346" TEXT="typen">
|
|
<node CREATED="1443735007685" ID="ID_1426207394" MODIFIED="1443735015668" TEXT=""type"-Attribut">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443734030329" ID="ID_257027438" MODIFIED="1443734033052" TEXT="befüllen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443733903314" ID="ID_1973278843" MODIFIED="1512926192347" TEXT="NAV">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1443734039776" ID="ID_1572908212" MODIFIED="1512926192347" TEXT="pick">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1444349667741" ID="ID_1407797227" MODIFIED="1444349672062" TEXT="by-name"/>
|
|
<node CREATED="1444349672792" ID="ID_267468753" MODIFIED="1444349690748" TEXT="anonym">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
pick(Ref::CHILD)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443734637416" ID="ID_461220696" MODIFIED="1512926192348" TEXT="after">
|
|
<node CREATED="1443741466072" ID="ID_1108877437" MODIFIED="1444349773888" TEXT="Frage: wrap erlauben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
würde sagen: ja, aber auch <i>nur</i> für das after-Verb!
|
|
</p>
|
|
<p>
|
|
allgemein halte ich einen wrap-around für keine gute Idee,
|
|
</p>
|
|
<p>
|
|
weil er zu Zweideutigekeigen führt und daher Struktur oder Konsistenzfehler überspielt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443733891492" ID="ID_1727724941" MODIFIED="1512926192348" TEXT="MOD">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1443734646734" ID="ID_841341176" MODIFIED="1512926192349" TEXT="INS">
|
|
<node CREATED="1443734713781" ID="ID_10743682" MODIFIED="1443734720912" TEXT="vorne"/>
|
|
<node CREATED="1443734721692" ID="ID_1206301961" MODIFIED="1443734723047" TEXT="innen"/>
|
|
<node CREATED="1443734723899" ID="ID_614189310" MODIFIED="1443734740809" TEXT="APPEND">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443734649902" ID="ID_1557261619" MODIFIED="1512926192349" TEXT="DEL">
|
|
<node CREATED="1443734770118" ID="ID_1863350908" MODIFIED="1443734772777" TEXT="nächsten"/>
|
|
<node CREATED="1443734773317" ID="ID_738630660" MODIFIED="1443734775409" TEXT="letzten"/>
|
|
</node>
|
|
<node CREATED="1443734652509" ID="ID_72317753" MODIFIED="1512926192349" TEXT="PERM">
|
|
<node CREATED="1443734781868" ID="ID_868966231" MODIFIED="1443734785215" TEXT="find-fetch"/>
|
|
<node CREATED="1443734785971" ID="ID_1082279397" MODIFIED="1512926192350" TEXT="push">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1443734808360" ID="ID_1918783570" MODIFIED="1443734832562" TEXT="Parameter">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1443734796346" ID="ID_1017278649" MODIFIED="1443734869522" TEXT="überflüssig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
läßt sich stets duch eine inverse Folge von <i>find</i> und <i>pick</i>  emulieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443733895611" ID="ID_1632274940" MODIFIED="1512926192350" TEXT="MUT">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1443734664572" ID="ID_602667530" MODIFIED="1512926192351" TEXT="by-name">
|
|
<node CREATED="1443734917130" ID="ID_583238947" MODIFIED="1443734923740" TEXT="nur im Scope"/>
|
|
<node CREATED="1443734926912" ID="ID_634765493" MODIFIED="1443734937699" TEXT="eröffnet sub-Scope"/>
|
|
</node>
|
|
<node CREATED="1443734668267" ID="ID_1281243531" MODIFIED="1512926192351" TEXT="_THIS_">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
<node CREATED="1443734884526" ID="ID_1720972097" MODIFIED="1443734907375" TEXT="gilt postfix"/>
|
|
<node CREATED="1443734942974" ID="ID_72035627" MODIFIED="1443734946841" TEXT="sonst wie normales MUT"/>
|
|
<node CREATED="1443734955012" ID="ID_132520838" MODIFIED="1443734972286" TEXT="erlaubt Anlegen + Populieren"/>
|
|
<node CREATED="1460934541540" ID="ID_789170184" MODIFIED="1460934562112" TEXT="von fragwürdigem Nutzen!">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443735171208" HGAP="46" ID="ID_1757651048" MODIFIED="1525124215375" TEXT="Objekt-Baum-Semantik" VSHIFT="13">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1443735379267" ID="ID_628105032" MODIFIED="1512926192352" TEXT="Wurzel">
|
|
<node CREATED="1443735418201" ID="ID_1521312079" MODIFIED="1443735418201" TEXT="wird vorausgesetzt"/>
|
|
<node CREATED="1443735385523" ID="ID_1179435276" MODIFIED="1443735425593" TEXT="ist stets ein Record"/>
|
|
</node>
|
|
<node CREATED="1443735531351" ID="ID_1428234818" MODIFIED="1512926192353" TEXT="Objekt">
|
|
<node CREATED="1443735554379" ID="ID_676366486" MODIFIED="1443735571653" TEXT="Inhalt als Liste"/>
|
|
<node CREATED="1443735572833" ID="ID_343264561" MODIFIED="1512926192353" TEXT="Zonen">
|
|
<node CREATED="1443735596550" ID="ID_236186740" MODIFIED="1443735598258" TEXT="Meta"/>
|
|
<node CREATED="1443735598966" ID="ID_1441633165" MODIFIED="1443735601009" TEXT="Attribute"/>
|
|
<node CREATED="1443735601477" ID="ID_1740180586" MODIFIED="1443735605393" TEXT="Scope"/>
|
|
</node>
|
|
<node CREATED="1443735621027" ID="ID_850995598" MODIFIED="1512926192353" TEXT="Protokoll">
|
|
<node CREATED="1443735625714" ID="ID_1979053137" MODIFIED="1443735638372" TEXT="Reihenfolge erhaltend"/>
|
|
<node CREATED="1443735638840" ID="ID_1930287259" MODIFIED="1443735642020" TEXT="nicht sortiert"/>
|
|
<node CREATED="1443735643536" ID="ID_1397296376" MODIFIED="1443735648747" TEXT="nach Zonen geordnet"/>
|
|
</node>
|
|
<node CREATED="1443735736427" ID="ID_735577464" MODIFIED="1512926192354" TEXT="Konformität">
|
|
<node CREATED="1443736349465" ID="ID_1312270317" MODIFIED="1561827465845" TEXT="strikt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vorerst verworfen, da zusätzlicher Prüf-Aufwand
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1443736367255" ID="ID_1634633098" MODIFIED="1443736380225" TEXT="Meta-Attribute zuerst"/>
|
|
<node CREATED="1443736626731" ID="ID_600165347" MODIFIED="1443736652396" TEXT="keine Attribut-Duplikate"/>
|
|
<node CREATED="1443736388180" ID="ID_435516555" MODIFIED="1443736666538" TEXT="Attribute strikt vor Kindern"/>
|
|
</node>
|
|
<node CREATED="1443736354800" FOLDED="true" ID="ID_1024688383" MODIFIED="1573834317454" TEXT="locker">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443735740907" ID="ID_1103250008" MODIFIED="1443735747902" TEXT="Meta-Attribute sind magisch"/>
|
|
<node CREATED="1473353076877" ID="ID_1936057196" MODIFIED="1561827465846" TEXT="2-Layer binding">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1473353083492" ID="ID_1800912467" MODIFIED="1512926192356" TEXT="es gibt eine Schicht">
|
|
<node CREATED="1473353090435" ID="ID_708279376" MODIFIED="1473353094535" TEXT="für Attribute"/>
|
|
<node CREATED="1473353095051" ID="ID_484062615" MODIFIED="1473353096974" TEXT="für Kinder"/>
|
|
</node>
|
|
<node CREATED="1473353098274" ID="ID_1387467215" MODIFIED="1473353107805" TEXT="jede Schicht arbeitet in sich konsistent"/>
|
|
<node CREATED="1473353109241" ID="ID_132411161" MODIFIED="1473353115884" TEXT="sichtbare Reihenfolge bleibt fest"/>
|
|
</node>
|
|
<node CREATED="1443736688027" ID="ID_1189409086" MODIFIED="1512926192357" TEXT="Attribut-Handhabung">
|
|
<node CREATED="1443737483704" ID="ID_1359413673" MODIFIED="1561827465846" TEXT="Modell "Liste"">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443737510238" ID="ID_1135997794" MODIFIED="1443737510238" TEXT="Duplikate anhängen"/>
|
|
<node CREATED="1443737516852" ID="ID_636329172" MODIFIED="1443737527750" TEXT="Einfügen erlauben"/>
|
|
<node CREATED="1443737528578" ID="ID_1554159544" MODIFIED="1443737538461" TEXT="Umordnen erlauben"/>
|
|
<node CREATED="1443737570229" ID="ID_28119998" MODIFIED="1443737576392" TEXT="Löschen erfordert Ansteuern"/>
|
|
</node>
|
|
<node CREATED="1443737497870" ID="ID_113467015" MODIFIED="1561827465847" TEXT="Modell "Map"">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1443737705058" ID="ID_1320189713" MODIFIED="1443737716690" TEXT="Operationen an Storage delegieren"/>
|
|
<node CREATED="1443737578803" ID="ID_1670234515" MODIFIED="1443737602756" TEXT="Duplikate überschreiben"/>
|
|
<node CREATED="1443737605080" ID="ID_609776485" MODIFIED="1443737739674" TEXT="Neue an Standardort anfügen"/>
|
|
<node CREATED="1443737747941" ID="ID_1552219906" MODIFIED="1443737757207" TEXT="Umordnungen verweigern/ignorieren"/>
|
|
<node CREATED="1443737769122" ID="ID_697980786" MODIFIED="1443737777276" TEXT="Löschen an beliebiger Stelle wirksam"/>
|
|
</node>
|
|
<node CREATED="1443738082216" HGAP="38" ID="ID_870184525" MODIFIED="1561827465848" TEXT="Abwägung" VSHIFT="7">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443738097022" ID="ID_1609921484" MODIFIED="1443738178020" TEXT="Modelle schließen sich aus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...Grund: sie werden durch einen jeweils komplett anderen Ansatz implementiert
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
"Liste" beruht auf dem Attribut-Iterator und dem Aufbauen einer neuen Attribut-Sammlung
|
|
</li>
|
|
<li>
|
|
"Map" beruht darauf, alle Operationen an die Storage zu delegieren
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738179947" ID="ID_1249607715" MODIFIED="1533608414043" TEXT=""Liste"">
|
|
<node CREATED="1443738196336" ID="ID_855336404" MODIFIED="1561827465849" TEXT="Vorteile">
|
|
<node CREATED="1443738556296" ID="ID_340267804" MODIFIED="1443738562763" TEXT="verwendet vorhandene Impl"/>
|
|
<node CREATED="1443738563263" ID="ID_583767245" MODIFIED="1443738575817" TEXT="uniforme Semantik der Diff-Sprache"/>
|
|
<node CREATED="1443738577781" ID="ID_1622210655" MODIFIED="1443738793488" TEXT="partielle Ordnung darstellbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, man kann Attribute in einer "sinnvoll lesbaren" Ordnung anschreiben
|
|
</p>
|
|
<p>
|
|
und später angefügte Attribute bleiben so erkennbar.
|
|
</p>
|
|
<p>
|
|
Vorteilhaft für Version-Management
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738653931" ID="ID_604966063" MODIFIED="1443738813866" TEXT="Effizienz des List-Diff">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
profitiert also von allen Verbesserungen des allgemeinen Algorithmus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738592971" ID="ID_790837479" MODIFIED="1455841731908" TEXT="bei uns: hoch effizient">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"hoch effizient", unter der Annahme, daß fast immer nur konforme Änderungen kommen.
|
|
</p>
|
|
<p>
|
|
Weil dann nämlich die in unserer Implementierung ggfs. kostspieligen Umordnungen entfallen,
|
|
</p>
|
|
<p>
|
|
kommen wir auf lineare Komplexität für die Verarbeitung
|
|
</p>
|
|
<p>
|
|
+ NlogN für den Index zur Diff-Erzeugung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443738199160" ID="ID_955544777" MODIFIED="1561827465849" TEXT="Nachteile">
|
|
<node CREATED="1443738500000" ID="ID_201650237" MODIFIED="1443738505571" TEXT="Duplikate toleriert"/>
|
|
<node CREATED="1443738929854" ID="ID_852940283" MODIFIED="1443739153420" TEXT="sinnloser Index-Aufbau (Diff-Erzeugung)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unsere Impl der <i>Diff-Erzeugung (!)</i>
|
|
</p>
|
|
<p>
|
|
baut einen Index auf (N*logN), um Einfügungen/Entfernungen zu erkennen und Umordnungs-Suche zu unterstützen.
|
|
</p>
|
|
<p>
|
|
Wenn wir aber von ausschließlich konformen Operationen ausgehen,
|
|
</p>
|
|
<p>
|
|
wird dieser Index nicht benötigt. Leider können wir das aber nicht garantieren, denn
|
|
</p>
|
|
<p>
|
|
es könnte ja zwischenzeitlich ein Attribut gelöscht und dann später (am Ende) wieder
|
|
</p>
|
|
<p>
|
|
angehängt worden sein, was dann eben doch einen Index erfordert, um einen
|
|
</p>
|
|
<p>
|
|
korrekten Listen-Diff zu erzeugen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443738179947" ID="ID_1861982554" MODIFIED="1533608414045" TEXT=""Map"">
|
|
<node CREATED="1443738196336" ID="ID_997066012" MODIFIED="1561827465849" TEXT="Vorteile">
|
|
<node CREATED="1443738237731" ID="ID_1438410748" MODIFIED="1443738244389" TEXT="Konformität garantiert"/>
|
|
</node>
|
|
<node CREATED="1443738199160" ID="ID_571621671" MODIFIED="1561827465851" TEXT="Nachteile">
|
|
<node CREATED="1443738352419" ID="ID_439396381" MODIFIED="1443738730869" TEXT="Effizienz der Storage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. <i>wenn</i> die Storage hoch-optimiert ist,
|
|
</p>
|
|
<p>
|
|
dann überträgt sich das auf die Diff-Behandlung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738371545" ID="ID_1959160321" MODIFIED="1443738695968" TEXT="bei uns: voll-Quadratisch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da wir Attribute in einer Liste speichern,
|
|
</p>
|
|
<p>
|
|
müssen wir für jede Einfügung eine vollständige Suche machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738416083" ID="ID_793860786" MODIFIED="1443738470421" TEXT="erfordert separate Impl">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...gemeint ist: extra, anders als die normale Listenverarbeitung.
|
|
</p>
|
|
<p>
|
|
Auch wenn diese andere Implementierung nur delegiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443738471955" ID="ID_315855253" MODIFIED="1443738478894" TEXT="versteckte 2.Semantik"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443739215487" HGAP="42" ID="ID_1540836182" MODIFIED="1512926192361" TEXT="Entscheidung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1443739221631" ID="ID_338047062" MODIFIED="1443739227649" TEXT=""Listen"-Modell"/>
|
|
<node CREATED="1443739228542" ID="ID_773218806" MODIFIED="1443739244615" TEXT="eindeutig vorzuziehen"/>
|
|
<node CREATED="1443739245483" ID="ID_1943112941" MODIFIED="1533608414046" TEXT="zwei Gründe">
|
|
<node CREATED="1443739308651" ID="ID_1436069181" MODIFIED="1443739311142" TEXT="Performance"/>
|
|
<node CREATED="1443739311562" ID="ID_1848034442" MODIFIED="1443739314222" TEXT="Wartbarkeit"/>
|
|
</node>
|
|
<node CREATED="1443739323033" ID="ID_1428762486" MODIFIED="1561827465852" TEXT=""zwei Listen"-Modell">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443739335823" ID="ID_860198617" MODIFIED="1443739349777" TEXT="intern führen wir zwei Listen-Diffs durch"/>
|
|
<node CREATED="1443739350869" ID="ID_464299464" MODIFIED="1443739368974" TEXT="ein Trennkriterium führt zum Umschalten"/>
|
|
<node CREATED="1443739399718" ID="ID_686887994" MODIFIED="1443739426315">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
danach noch auftretende Attribute
|
|
</p>
|
|
<p>
|
|
erfordern Sonder-Behandlung,
|
|
</p>
|
|
<p>
|
|
indem sie an die Attributs-Liste angehängt werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443733831475" HGAP="1" ID="ID_1421473885" MODIFIED="1512926192364" TEXT="Fehler-Fälle" VSHIFT="7">
|
|
<node CREATED="1443736788646" ID="ID_672669721" MODIFIED="1512926192364" TEXT="formal">
|
|
<node CREATED="1443736804803" ID="ID_1706990948" MODIFIED="1512926192365" TEXT="Syntax">
|
|
<node CREATED="1443737154028" ID="ID_143683919" MODIFIED="1443737159781" TEXT="durch Typsystem unterbunden">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1443738002250" ID="ID_1398802900" MODIFIED="1443738006115" TEXT="sicher">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443736824112" ID="ID_1520561537" MODIFIED="1512926192365" TEXT="unpassende Parameter">
|
|
<node CREATED="1443737180297" ID="ID_1748864612" MODIFIED="1443737193859" TEXT="Laufzeit-Check">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1443738011018" ID="ID_1408814832" MODIFIED="1443738023248" TEXT="ggfs unvollständig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443736846078" ID="ID_1354240107" MODIFIED="1512926192365" TEXT="Mismatch am Ziel">
|
|
<node CREATED="1443736895663" ID="ID_1436447416" MODIFIED="1443736897539" TEXT="erkennbar"/>
|
|
<node CREATED="1443736897983" ID="ID_636884790" MODIFIED="1443736900051" TEXT="unbemerkt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443736791421" ID="ID_23907569" MODIFIED="1512926192366" TEXT="semantisch">
|
|
<node CREATED="1443737005833" ID="ID_1457267751" MODIFIED="1512926192367" TEXT="INIT aber nicht leer">
|
|
<node CREATED="1443737222707" ID="ID_1242625886" MODIFIED="1443737241501" TEXT="sehr gefährlich bei strikter Konformität"/>
|
|
<node CREATED="1443737242824" ID="ID_461820743" MODIFIED="1443737260482" TEXT="harmlos sonst; wird glattgebogen"/>
|
|
<node CREATED="1443737279172" ID="ID_1485388967" MODIFIED="1443737290806" TEXT="kann dann aber zu undefiniertem Zustand führen"/>
|
|
</node>
|
|
<node CREATED="1443737017511" ID="ID_744413839" MODIFIED="1512926192367" TEXT="INS Attribut-Duplikat">
|
|
<node CREATED="1443739508920" ID="ID_914206763" MODIFIED="1443739536363" TEXT="wird toleriert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wegen Entscheidung für das "Listen"-Modell zur Attribut-Handhabung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443737036108" ID="ID_641574289" MODIFIED="1512926192367" TEXT="INS Child in Attribut-Zone">
|
|
<node CREATED="1473352901693" ID="ID_1444450254" MODIFIED="1473352907657" TEXT="wird toleriert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1473352908876" ID="ID_288202266" MODIFIED="1473352998161" TEXT="bricht aus der Reihenfolge aus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
es wird einfach vom zuständigen Layer (der für die Attribute) aufgegriffen
|
|
</li>
|
|
<li>
|
|
es hat keinen Einfluß auf die nach außen sichtbare Reihenfolge
|
|
</li>
|
|
<li>
|
|
diese Reihenfolge bleibt gruppiert nach Attributen / Kindern
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443737051419" ID="ID_364647539" MODIFIED="1512926192367" TEXT="INS Attribut in Scope">
|
|
<node CREATED="1473352922946" ID="ID_23438081" MODIFIED="1473352926387" TEXT="wird toleriert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1473352927098" ID="ID_1791498124" MODIFIED="1473353001242" TEXT="bricht aus der reihenfolge aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443737064633" ID="ID_67819372" MODIFIED="1512926192368" TEXT="PERM-fetch Child in Attribut-Zone">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1443739787850" ID="ID_31775669" MODIFIED="1443739831711" TEXT="führt zum Fehler wg. "zwei Listen"-Modell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da das Kind in der Liste der Attribute nämlich garnicht gefunden wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1443739798889" ID="ID_1992435989" MODIFIED="1443739912310" TEXT="Spezialbehandlung am Ende der Attributzone notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn wir am Ende der Attribut-Zone stehen,
|
|
</p>
|
|
<p>
|
|
und die nächste Operation ein fetch eines Kindes ist, müssen wir implizit den
|
|
</p>
|
|
<p>
|
|
Wechsel in den Scope vollziehen und die Operation dort ausführen.
|
|
</p>
|
|
<p>
|
|
Aber an allen anderen Stellen in der Attribut-Zone ist ein solcher Fetch ein Fehler!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1473353036195" ID="ID_371361214" MODIFIED="1473353045794" TEXT="obsolet durch neue Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443735208090" HGAP="99" ID="ID_117472593" MODIFIED="1488423307279" TEXT="Entscheidungen" VSHIFT="8">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1443735230768" ID="ID_1544379221" MODIFIED="1443735318881">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
standardmäßig <b>strikt</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1443735286496" ID="ID_1442661683" MODIFIED="1512926192368" TEXT="fuzzy-mode">
|
|
<node CREATED="1443740092337" ID="ID_563359094" MODIFIED="1443740142638" TEXT="PICK nicht Vorhandenes"/>
|
|
<node CREATED="1443740127021" ID="ID_1839086508" MODIFIED="1443740137239" TEXT="DEL nicht Vorhandenes"/>
|
|
<node CREATED="1443740193692" ID="ID_1962095124" MODIFIED="1443740200542" TEXT="FIND nicht Vorhandenes"/>
|
|
<node CREATED="1443740261859" ID="ID_96033673" MODIFIED="1443740266837" TEXT="MUT nicht Vorhandenes"/>
|
|
<node CREATED="1443740311300" ID="ID_1645049477" MODIFIED="1443740327245" TEXT="PICK wird zu AFTER nicht Folgendes"/>
|
|
<node CREATED="1443740353686" ID="ID_1996517233" MODIFIED="1443740369848" TEXT="Rest-Überschuß am Ende"/>
|
|
</node>
|
|
<node CREATED="1443735322787" ID="ID_1404399616" MODIFIED="1512926192369" TEXT="Bindung">
|
|
<node CREATED="1443735336009" ID="ID_1123815488" MODIFIED="1443735347412" TEXT="Diff vs. Daten"/>
|
|
<node CREATED="1443735348800" ID="ID_1003830940" MODIFIED="1443735353234" TEXT="erst hier die Semantik"/>
|
|
<node CREATED="1443740402472" ID="ID_341902192" MODIFIED="1443740407355" TEXT=""zwei Listen"-Modell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443741905157" FOLDED="true" HGAP="342" ID="ID_1960988662" MODIFIED="1561827465879" TEXT="Diff-Implementierung" VSHIFT="91">
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1444522932841" HGAP="-19" ID="ID_48288704" MODIFIED="1573834426834" TEXT="Architektur" VSHIFT="-52">
|
|
<edge STYLE="linear"/>
|
|
<node CREATED="1444522939928" ID="ID_490994681" MODIFIED="1444522986895" TEXT="destruktiv?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1444522961462" ID="ID_1164434859" MODIFIED="1512926192369">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
List-Diff
|
|
</p>
|
|
<p>
|
|
als Spezialfall
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1444523008207" ID="ID_385890020" MODIFIED="1512926192370" TEXT="Sprache: geht nicht">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1444523018726" ID="ID_874967614" MODIFIED="1444523024345" TEXT="Problem DiffStep"/>
|
|
<node CREATED="1444523025148" ID="ID_1403562226" MODIFIED="1444523033774" TEXT="ist eingebettet in die Sprache"/>
|
|
<node CREATED="1444523034795" ID="ID_1203331178" MODIFIED="1444523041573" TEXT="es gibt keinen gemeinsamen Obertyp"/>
|
|
<node CREATED="1444523042138" ID="ID_675305475" MODIFIED="1512926192371">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann auch nicht
|
|
</p>
|
|
<p>
|
|
wegen dem Interpreter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1444523078581" ID="ID_318811786" MODIFIED="1444523091591" TEXT="liefert Token -> kovariant"/>
|
|
<node CREATED="1444523091939" ID="ID_720826260" MODIFIED="1444523103670" TEXT="akzeptiert Interpreter -> kontravariant"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1444523111792" ID="ID_1544468161" MODIFIED="1512926192373" TEXT="Implementierungs-Ebene">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1444523131486" ID="ID_37078397" MODIFIED="1444523139993" TEXT="Anwendung setzt nur Vector voraus"/>
|
|
<node CREATED="1444523140605" ID="ID_1673268008" MODIFIED="1444523237002">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
leicht auf generischen Container
|
|
</p>
|
|
<p>
|
|
zu verallgemeinern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1444523168561" ID="ID_1180296210" MODIFIED="1444523205481">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Erkennung hat die Sprache als Parameter,
|
|
</p>
|
|
<p>
|
|
und verwendet sie zur Token-Generierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1444523206427" ID="ID_713432486" MODIFIED="1444523230705">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man kann auch dem List-Detector
|
|
</p>
|
|
<p>
|
|
eine Tree-Diff-Language geben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1444522881125" ID="ID_172319057" MODIFIED="1444522895130" TEXT="Anwendung">
|
|
<node CREATED="1443741923547" ID="ID_1978439060" MODIFIED="1443741930738" TEXT="Listen-Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1443741931858" FOLDED="true" ID="ID_484829805" MODIFIED="1576202977258" TEXT="Baum-Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1445295424277" ID="ID_1084177503" MODIFIED="1525124215397">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font size="5" color="#e97664">Frage</font>: <i>in-Place?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1445295501531" ID="ID_1542006741" MODIFIED="1512926192377" TEXT="Problem: Teilbäume">
|
|
<node CREATED="1445295582392" ID="ID_243770452" MODIFIED="1445295587819" TEXT="Umhängen von Teilbäumen"/>
|
|
<node CREATED="1445295588127" ID="ID_1541079773" MODIFIED="1445295598746" TEXT="Abstieg in Teilbäume"/>
|
|
</node>
|
|
<node CREATED="1445295543653" ID="ID_39528388" MODIFIED="1512926192377" TEXT="wie wird das UI-Model verwendet">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1445295714215" ID="ID_472108592" MODIFIED="1445295722937" TEXT="um Diffs aufzuspielen"/>
|
|
<node CREATED="1445295726940" ID="ID_1067776624" MODIFIED="1445295736327" TEXT="um UI-Elemente anzusprechend"/>
|
|
<node CREATED="1445295737436" ID="ID_1529650757" MODIFIED="1512926192378" TEXT="für Callbacks vom UI">
|
|
<node CREATED="1445299235061" ID="ID_336159819" MODIFIED="1445299267675">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>entscheidende Frage</b>: wie addressieren?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1445299271761" ID="ID_1895578975" MODIFIED="1445299278275" TEXT="Bus-Term hat eine ID..."/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1445299292301" HGAP="134" ID="ID_1169271905" MODIFIED="1512926192378" TEXT="pro" VSHIFT="12">
|
|
<node CREATED="1445299310971" ID="ID_1955674144" MODIFIED="1445299339570" TEXT="vermeidet Kopieren"/>
|
|
<node CREATED="1445299340375" ID="ID_485304706" MODIFIED="1445299346562" TEXT="speziell der nicht betroffenen Teile"/>
|
|
<node CREATED="1445299347173" ID="ID_232158633" MODIFIED="1445299356224" TEXT="das ist genau der Sinn des Diff"/>
|
|
</node>
|
|
<node CREATED="1445299298932" HGAP="127" ID="ID_602638586" MODIFIED="1512926192379" TEXT="contra" VSHIFT="-5">
|
|
<node CREATED="1445299306659" ID="ID_1695051638" MODIFIED="1445299308751" TEXT="Locking"/>
|
|
<node CREATED="1445389209031" ID="ID_1394943777" MODIFIED="1445389223268" TEXT="GenNode ist ein value type"/>
|
|
</node>
|
|
<node CREATED="1445389251289" HGAP="39" ID="ID_1700933130" MODIFIED="1512926192380" TEXT="Entscheidung" VSHIFT="28">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<node CREATED="1445389298770" ID="ID_1935262520" MODIFIED="1512926192381" TEXT="Kompromiß">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1445389275998" ID="ID_1081466244" MODIFIED="1512926192382" TEXT="intern kopieren">
|
|
<node CREATED="1445389355802" ID="ID_745348631" MODIFIED="1445389365541" TEXT="wir arbeiten auf einer interen Kopie"/>
|
|
<node CREATED="1445389366298" ID="ID_432143676" MODIFIED="1445389372460" TEXT="diese gehört der Implementierung"/>
|
|
<node CREATED="1445389373168" ID="ID_1925613497" MODIFIED="1445389404465">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und wird durch die Diff-Anwendung <i>konsumiert</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1445389291404" ID="ID_309801260" MODIFIED="1512926192382" TEXT="aber move-ctor anbieten">
|
|
<node CREATED="1445389423050" ID="ID_802906323" MODIFIED="1445389433477" TEXT="zur Initialisierung ein bestehendes Objekt übernehmen"/>
|
|
<node CREATED="1445389434753" ID="ID_532431684" MODIFIED="1445389454234" TEXT="das Ergebnis in ein bestehendes Objekt schieben"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1445550734547" ID="ID_960791539" MODIFIED="1512926192443" TEXT="oder doch den Mutator erweitern">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1445550748169" ID="ID_1764723062" MODIFIED="1445550752365" TEXT="Vorteil: explizit"/>
|
|
<node CREATED="1445550752832" ID="ID_1506018584" MODIFIED="1445550807621" TEXT="Manipulation hat gewisse Vorteile"/>
|
|
<node CREATED="1445550808281" ID="ID_1970167609" MODIFIED="1445550842143">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Immutablility</i> erzwingt
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
persistente Datenstrukturen
|
|
</li>
|
|
<li>
|
|
garbage-collector
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1445555721981" ID="ID_292803227" MODIFIED="1512926192444">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösung: wir arbeiten <i>auf </i>einem Mutator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1445556525714" ID="ID_1223708278" MODIFIED="1445556595037" TEXT="damit funktioniert es 1:1 wie List-Diff">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1445556567980" ID="ID_783100840" MODIFIED="1445556591370" TEXT="Voraussetzung: der Mutator muß die Attribut/Kinder-Listen exponieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1445644203808" ID="ID_1105228896" MODIFIED="1445644221661">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf dem Umweg über einen <b>ContentMutator</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1445550873904" ID="ID_1781797833" MODIFIED="1445556509368" TEXT="copy + transaktional als optionaler 2.Layer"/>
|
|
<node CREATED="1445550893222" ID="ID_2118555" MODIFIED="1445550915111" TEXT="Diff-Applikator = destruktiver Mutator"/>
|
|
<node CREATED="1445389311690" ID="ID_1926972913" MODIFIED="1445389323819" TEXT="und dieses rekursiv..."/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#391f9e" CREATED="1445391990778" HGAP="148" ID="ID_464295846" MODIFIED="1576203232155" TEXT="Implementierung" VSHIFT="4">
|
|
<arrowlink COLOR="#2ab880" DESTINATION="ID_61713493" ENDARROW="Default" ENDINCLINATION="-125;-80;" ID="Arrow_ID_958576106" STARTARROW="None" STARTINCLINATION="-317;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1445392080175" ID="ID_341024968" MODIFIED="1445392101243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Innereien des alten Record <i>verbrauchen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1445392105075" ID="ID_1377567733" MODIFIED="1445392113677" TEXT="zwei neue, lokale Vektoren aufbauen"/>
|
|
<node CREATED="1445392114217" ID="ID_71124283" MODIFIED="1445392120973" TEXT="daraus den neuen Record konstruieren"/>
|
|
<node CREATED="1445556634395" FOLDED="true" ID="ID_1143865339" MODIFIED="1576201918968" TEXT="technische Komplikation: "2 Listen"-Modell">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1445620914088" ID="ID_1919426539" MODIFIED="1445621018036" TEXT="Verhalten ändert sich je nach Scope">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1445620938421" ID="ID_557124057" MODIFIED="1445621022038" TEXT="Verzweigung in jedem Diff-Fall">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1445620947332" ID="ID_1684844100" MODIFIED="1445621010162" TEXT="Code-Redundanz">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1445620961570" ID="ID_965863635" MODIFIED="1445621006245" TEXT="in Wrapper wegpacken!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1445620972825" ID="ID_1467461119" MODIFIED="1445621002208" TEXT="schon in den Record::Mutator einbinden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1445620991326" ID="ID_513677356" MODIFIED="1445620998003" TEXT="eigener Test">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1473352753713" HGAP="10" ID="ID_1353201178" MODIFIED="1512926192448" TEXT="besserer Ansatz" VSHIFT="22">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1473352767432" ID="ID_1220456854" MODIFIED="1473352784089" TEXT="als interne Repräsentation klassifizieren"/>
|
|
<node CREATED="1473352784533" ID="ID_1907760521" MODIFIED="1473352794511" TEXT="das normale Binding für opaque Datenstrukturen verwenden"/>
|
|
<node CREATED="1473352794988" ID="ID_652168710" MODIFIED="1473352818517" TEXT="vorkonfiguriert: 2-Layer Binding"/>
|
|
<node CREATED="1473352820096" ID="ID_329351043" MODIFIED="1473352835764" TEXT="Spezialfälle aus der Sprache entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1473352801547" ID="ID_1001891556" MODIFIED="1473352809203" TEXT="integriert in generischen Diff-Applikator">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446159438278" FOLDED="true" HGAP="29" ID="ID_563496669" MODIFIED="1576201937328" VSHIFT="8">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: <b><font color="#ed1c02" size="4">Rekursion</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1446159517914" ID="ID_1749096609" MODIFIED="1446159530661" TEXT="wir müssen rekursiv in Sub-Scope einsteigen"/>
|
|
<node CREATED="1446159531745" ID="ID_1660140345" MODIFIED="1446159550795" TEXT="eingeschachtelt wieder ein Record::Mutator"/>
|
|
<node CREATED="1446159551718" ID="ID_608514705" MODIFIED="1446159563593" TEXT="Wohin mit der Storage?"/>
|
|
<node CREATED="1446159564725" ID="ID_893302390" MODIFIED="1512926192449" TEXT="zwei Lösungsansätze">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1446159584034" ID="ID_1845322273" MODIFIED="1512926192450" TEXT="rekursiv konsumieren">
|
|
<node CREATED="1446159632603" ID="ID_1950074103" MODIFIED="1446160677236">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ein MUT kommt
|
|
</p>
|
|
<p>
|
|
erzeugt man lokal einen DiffApplikator für den geschachtelten Kontext
|
|
</p>
|
|
<p>
|
|
und gibt ihm rekursiv den Diff hinein. Wenn dieser Aufruf zurückkehrt
|
|
</p>
|
|
<p>
|
|
ist der gesammte Diff für den eingeschachtelten Kontext konsumiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1446159744053" ID="ID_1735127502" MODIFIED="1512926192451" TEXT="pro">
|
|
<node CREATED="1446159775161" ID="ID_192461503" MODIFIED="1446159832244" TEXT="elegant, selbstähnlich"/>
|
|
<node CREATED="1446159790702" ID="ID_905335387" MODIFIED="1446159823622" TEXT="sauber, state bleibt lokal"/>
|
|
<node CREATED="1446159833753" ID="ID_539121048" MODIFIED="1446159854442" TEXT="kein expliziter Stack, Daten auf dem Callstack"/>
|
|
</node>
|
|
<node CREATED="1446159751068" ID="ID_1466026714" MODIFIED="1512926192451" TEXT="contra">
|
|
<node CREATED="1446159936323" ID="ID_1344861000" MODIFIED="1446159961793" TEXT="keine einfache Iteration mehr"/>
|
|
<node CREATED="1446159910374" ID="ID_1307975840" MODIFIED="1446159998967" TEXT="man muß das Token anschauen"/>
|
|
<node CREATED="1446159999939" ID="ID_1385561919" MODIFIED="1446160014569" TEXT="nicht kompatibel mit userem "Interpreter"-Modell"/>
|
|
<node CREATED="1446159858701" ID="ID_751122481" MODIFIED="1446160039239" TEXT="Applikator muß selber Diff konsumieren"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446159589369" ID="ID_1854873736" MODIFIED="1512926192453" TEXT="internen Stack">
|
|
<node CREATED="1446160049196" ID="ID_893515494" MODIFIED="1446160680983">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ein MUT kommt,
|
|
</p>
|
|
<p>
|
|
pusht der Applikator seinen privaten Zustand
|
|
</p>
|
|
<p>
|
|
auf einen explizit im Heap verwalteten std::stack
|
|
</p>
|
|
<p>
|
|
und legt einen neuen Mutator an für den nested scope
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1446160209758" ID="ID_1949126696" MODIFIED="1512926192453" TEXT="pro">
|
|
<node CREATED="1446160223212" ID="ID_189646771" MODIFIED="1446160248517" TEXT="kompatibel mit unserem "Interpreter"-Modell"/>
|
|
<node CREATED="1446160249609" ID="ID_1437127411" MODIFIED="1446160256555" TEXT="Diff wird einfach weiter iteriert"/>
|
|
</node>
|
|
<node CREATED="1446160212502" ID="ID_572617599" MODIFIED="1512926192453" TEXT="contra">
|
|
<node CREATED="1446160522212" ID="ID_1824677628" MODIFIED="1446160588767" TEXT="wir manipulieren state in einer Komponente"/>
|
|
<node CREATED="1446160621127" ID="ID_391572254" MODIFIED="1446160635561" TEXT="diese Manipulation passiert mitten aus einem Token-Aufruf"/>
|
|
<node CREATED="1446160592347" ID="ID_126615043" MODIFIED="1446160608364" TEXT="Storage-Management ist verwirrend"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446168257072" HGAP="81" ID="ID_91568209" MODIFIED="1446168481874" VSHIFT="5">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung:
|
|
</p>
|
|
<p>
|
|
interner Stack
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....begründet duch die generische Architektur.
|
|
</p>
|
|
<p>
|
|
Die Trennung von Diff-Iteration und dem Interpreter ermöglicht verschiedene Sprach-Ebenen.
|
|
</p>
|
|
<p>
|
|
Allerdings werde ich für die Anwendung auf konkrete Datenstrukturen,
|
|
</p>
|
|
<p>
|
|
also den TreeMutator, vermutlich das andere Modell (rekursiv konsumieren) verwenden.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446356556349" ID="ID_1068649765" MODIFIED="1512926192454" TEXT="offen...">
|
|
<node COLOR="#338800" CREATED="1446356765393" ID="ID_293921295" MODIFIED="1473352607814" TEXT="IDs in Testdaten für GenNode_test">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem sind mal wieder die automatisch generierten IDs.
|
|
</p>
|
|
<p>
|
|
Die sind natürlich anders, wenn wir die ganze Testsuite ausführen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446356588505" ID="ID_895292312" MODIFIED="1512926192454" TEXT="gründlicher Test">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1473352634730" ID="ID_955392554" MODIFIED="1473352641908" TEXT="bis jetzt nur "positiv-Tests""/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1473352642473" ID="ID_839131437" MODIFIED="1473352654368" TEXT="Abdeckung der Grenzfälle">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1444522895718" ID="ID_598781690" MODIFIED="1444522897802" TEXT="Generierung">
|
|
<node CREATED="1443741923547" ID="ID_1091408512" MODIFIED="1443741930738" TEXT="Listen-Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1443741931858" ID="ID_826609799" MODIFIED="1443741945481" TEXT="Baum-Diff">
|
|
<icon BUILTIN="flag"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576202545211" ID="ID_862025814" MODIFIED="1582387512534" TEXT="Diff-Bindung">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1576202990623" ID="ID_1903460265" MODIFIED="1576203228840" TEXT="konkret entwickelt für das UI-Element">
|
|
<arrowlink COLOR="#298c9e" DESTINATION="ID_645743424" ENDARROW="Default" ENDINCLINATION="-928;-33;" ID="Arrow_ID_653906070" STARTARROW="None" STARTINCLINATION="-2105;61;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1456506101544" FOLDED="true" HGAP="322" ID="ID_61713493" MODIFIED="1611315117066" TEXT="Implementierung: Diff-Anbindung" VSHIFT="87">
|
|
<linktarget COLOR="#47e573" DESTINATION="ID_61713493" ENDARROW="Default" ENDINCLINATION="-3400;234;" ID="Arrow_ID_1763921751" SOURCE="ID_486184645" STARTARROW="None" STARTINCLINATION="-792;48;"/>
|
|
<linktarget COLOR="#2ab880" DESTINATION="ID_61713493" ENDARROW="Default" ENDINCLINATION="-125;-80;" ID="Arrow_ID_958576106" SOURCE="ID_464295846" STARTARROW="None" STARTINCLINATION="-317;9;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1456506128581" FOLDED="true" HGAP="-12" ID="ID_158225677" MODIFIED="1576200599620" TEXT="Abwägungen" VSHIFT="184">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1456506135028" HGAP="29" ID="ID_780210307" MODIFIED="1512926191965" TEXT="Indirektionen" VSHIFT="-5">
|
|
<node CREATED="1456506145826" ID="ID_1611309527" MODIFIED="1575133329132" TEXT="kosten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Diff-Anwendung wird massiv und in der Breite stattfinden
|
|
</li>
|
|
<li>
|
|
sie wird als Reaktion auf UI-Events auftreten
|
|
</li>
|
|
<li>
|
|
sie dient dazu, andere UI-Operationen einzusparen
|
|
</li>
|
|
<li>
|
|
also muß speziell das Traversieren bis an den Anwendungsort bedacht werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456506151065" ID="ID_258224244" MODIFIED="1575133329148" TEXT="bisher nur drei">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. die bis jetzt geschriebene TreeApplikator-Implementierung
|
|
</p>
|
|
<p>
|
|
ist erstaunlich leichtgewichtig. Zu den zwei Indirektionien der Sprache
|
|
</p>
|
|
<p>
|
|
kommt nur entweder ein weiterer aus der GenNode bzw stattedessen ein dynamic cast hinzu.
|
|
</p>
|
|
<p>
|
|
Alles andere steckt in dem <b>expliziten Mutator-Typ </b>
|
|
</p>
|
|
<p>
|
|
 -- das gibt einen wichtigen Hinweis --
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456506160472" ID="ID_1961176321" MODIFIED="1575133329163" TEXT="zwei sind das Minimum">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da wir eine verb-basierte Sprache implementieren,
|
|
</p>
|
|
<p>
|
|
also einen double-dispatch haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456506385130" ID="ID_310848516" MODIFIED="1512926191966" TEXT="für generische Zieldaten">
|
|
<node CREATED="1456506446002" ID="ID_1039988752" MODIFIED="1456506470075" TEXT="kommt eine Indirektion hinzu"/>
|
|
<node CREATED="1456506471159" ID="ID_1219883167" MODIFIED="1512926191966" TEXT="es sei denn...">
|
|
<node CREATED="1456506475686" ID="ID_1548290778" MODIFIED="1456506487232" TEXT="man tauscht jeweils den Sprach-Interpreter aus"/>
|
|
<node CREATED="1456506487796" ID="ID_1287273135" MODIFIED="1456506499239" TEXT="das setzt aber rekursives Konsumieren des Diff voraus"/>
|
|
<node CREATED="1456506500187" ID="ID_860348703" MODIFIED="1456506511565" TEXT="und das zwingt uns, den Typ des Diff explizit zu machen"/>
|
|
<node CREATED="1456506512721" ID="ID_1880366369" MODIFIED="1575133329277" TEXT="der nicht-explizite Typ ist im Moment von Vorteil....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil wir den Anwendungs-Kontext noch überhaupt nicht kennen.
|
|
</p>
|
|
<p>
|
|
Man könnte also später, wenn das ganze System "steht",
|
|
</p>
|
|
<p>
|
|
das Diff-System noch einmal reimplementieren, dann mit einem vorgegebenen Diff-Typ
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456506607428" HGAP="31" ID="ID_1872426329" MODIFIED="1456506627511" VSHIFT="8">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beschluß: <i>akzeptiert</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456506647447" HGAP="32" ID="ID_821326055" MODIFIED="1512926191967" TEXT="Zielvorgabe: weitere vermeiden" VSHIFT="12">
|
|
<node CREATED="1456506661421" ID="ID_1563053672" MODIFIED="1456506689357" TEXT="d.h. nur entweder front-end oder back-end sind virtuell"/>
|
|
<node CREATED="1456506689834" ID="ID_748345000" MODIFIED="1456506713270">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Sinn von "polymorpic value" ist <b>das Backend virtuell</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1456506719949" ID="ID_819603941" MODIFIED="1456506725568" TEXT="keine virtuellen Iteratoren"/>
|
|
<node CREATED="1456506726060" ID="ID_327781503" MODIFIED="1456506738455" TEXT="Front-End muß Typedefs bereitstellen"/>
|
|
<node CREATED="1456506740323" ID="ID_605676202" MODIFIED="1456506747838" TEXT="elaboriertes Typkonstrukt notwendig"/>
|
|
<node CREATED="1456506749234" ID="ID_1370097863" MODIFIED="1575133329379" TEXT="zumindest für jeden Compund-Zieltyp ein eigener Interpreter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....wenngleich auch dieser aus einem Template generiert wird
|
|
</p>
|
|
<p>
|
|
(will sagen, es ist nicht sofort offensichtlich, daß wir jeweils einen Interpreter generieren)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457038737878" HGAP="44" ID="ID_1927444795" MODIFIED="1512926191968" TEXT="Abstraktions-Grad">
|
|
<node CREATED="1457119812475" ID="ID_1000349478" MODIFIED="1457119817575" TEXT="Elemente bleiben opaque"/>
|
|
<node CREATED="1457119818091" ID="ID_72516983" MODIFIED="1512926191969">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir <i>verzichten</i> auf Introspektion der Elemente
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1457119990420" ID="ID_417857" MODIFIED="1457120011276" TEXT="...denn die müßte die jeweilige Implementierung erbringen"/>
|
|
<node CREATED="1457120011721" ID="ID_130453051" MODIFIED="1457120024027" TEXT="und das würde das Übel der Introspektion überall hineindrücken"/>
|
|
<node CREATED="1457120026343" ID="ID_1643851302" MODIFIED="1457120043288" TEXT="Nachteil: keine klare Fehlerdiagnose möglich"/>
|
|
<node CREATED="1457120043925" ID="ID_1806333421" MODIFIED="1512926191970" TEXT="ist akzeptierbar...">
|
|
<node CREATED="1457120079542" ID="ID_680592754" MODIFIED="1457120079542">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn genau zu diesem Zweck haben wir die "External Tree Description"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1457120084135" ID="ID_1299212353" MODIFIED="1457120093706" TEXT="auf diese sollte ein Diff zuerst angewendet werden"/>
|
|
<node CREATED="1457120094302" ID="ID_629900491" MODIFIED="1457120105488" TEXT="und diese bietet Introspektion und klare Diagnose"/>
|
|
<node CREATED="1457120105908" ID="ID_702164974" MODIFIED="1457120131741" TEXT="Annahme ist also, daß ein Diff auf real-Datenstrukturen per Konstruktion erfolgreich ist"/>
|
|
<node CREATED="1457120134297" ID="ID_790286427" MODIFIED="1457120154250" TEXT="und ein Fehler dabei ist zwingenderweise ein Fehler in der Programmlogik"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457119844767" ID="ID_1188396825" MODIFIED="1457119861265" TEXT="wir bieten nur einen Match auf die Diff-Spec"/>
|
|
<node CREATED="1457119876899" ID="ID_1854037055" MODIFIED="1457119902755" TEXT="Mutations-Primitive bieten bool Erfolgs-Check"/>
|
|
<node CREATED="1457119903391" ID="ID_71718000" MODIFIED="1457119909602" TEXT="aber keine Exceptions"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456506821808" ID="ID_1291391164" MODIFIED="1512926191970" TEXT="Typ-Konstrukt">
|
|
<node CREATED="1461879209050" ID="ID_819509222" MODIFIED="1461879267131" TEXT="Kernproblem: wie groß muß der Buffer sein?">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1461879239310" ID="ID_1466777093" MODIFIED="1461879260051" TEXT="wie bekomme ich diese Info von nicht a priori bekannten Typen">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456523437616" FOLDED="true" HGAP="34" ID="ID_769898615" MODIFIED="1576200587803" TEXT="Manipulations-Interface" VSHIFT="6">
|
|
<node COLOR="#338800" CREATED="1456523455997" ID="ID_451867054" MODIFIED="1561827465480" TEXT="Design lösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1456523507910" ID="ID_10011481" MODIFIED="1456523518005" TEXT="Henne oder Ei?"/>
|
|
<node CREATED="1456523471851" ID="ID_1473020572" MODIFIED="1456523485597" TEXT="komm nicht vom Fleck"/>
|
|
<node CREATED="1456523487089" ID="ID_996191540" MODIFIED="1456523501995" TEXT="zirkuläre Bezüge im Design"/>
|
|
<node CREATED="1456523522693" ID="ID_258858244" MODIFIED="1512926191971" TEXT="abstrakter Entwurf">
|
|
<arrowlink COLOR="#6b77a6" DESTINATION="ID_1103254276" ENDARROW="Default" ENDINCLINATION="-116;0;" ID="Arrow_ID_1002137074" STARTARROW="None" STARTINCLINATION="-819;487;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1456523558304" ID="ID_157371441" MODIFIED="1456523564050" TEXT="baue einen Dummy">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1456523569111" ID="ID_27774245" MODIFIED="1456523580721" TEXT="...als eine Spezialisierung des Adapters"/>
|
|
<node CREATED="1456523593731" ID="ID_1278455785" MODIFIED="1456528188767" TEXT="Interface ohne reale Daten"/>
|
|
<node CREATED="1456528076005" ID="ID_1627557179" MODIFIED="1512926191972" TEXT="Diagnose">
|
|
<node CREATED="1456528119297" ID="ID_1804796459" MODIFIED="1456528119297" TEXT="hat ein EventLog eingebaut"/>
|
|
<node CREATED="1456528148107" ID="ID_423438892" MODIFIED="1456528165925" TEXT="protokolliert Schatten-Kinder-Liste"/>
|
|
<node CREATED="1456528167440" ID="ID_1949477356" MODIFIED="1575133329792" TEXT="transparenter Dekorator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h,
|
|
</p>
|
|
<p>
|
|
kann zusätzlich zu einem anderen Adaptor
|
|
</p>
|
|
<p>
|
|
in die Mutator-Dekorator-Kette gehängt werden
|
|
</p>
|
|
<p>
|
|
und protokolliert somit "nebenbei" was an Anforderungen an ihm vorbeigeht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456523612849" ID="ID_1653882286" MODIFIED="1456523625883" TEXT="Test zum Aufbau des Interfaces"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456528418823" HGAP="30" ID="ID_823162035" MODIFIED="1561827465487" TEXT="Bestandteile" VSHIFT="-1">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1456528424246" FOLDED="true" ID="ID_478070427" MODIFIED="1576200583821" STYLE="fork" TEXT="Selektor">
|
|
<linktarget COLOR="#7caed5" DESTINATION="ID_478070427" ENDARROW="Default" ENDINCLINATION="466;133;" ID="Arrow_ID_1332735015" SOURCE="ID_1033631571" STARTARROW="None" STARTINCLINATION="681;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1457741609884" ID="ID_631276890" MODIFIED="1512926191973" TEXT="bin ich zuständig?">
|
|
<node CREATED="1458094312266" ID="ID_1589695576" MODIFIED="1458094316157" TEXT="isApplicable"/>
|
|
<node CREATED="1458094316697" ID="ID_954342243" MODIFIED="1512926191974" TEXT="Festlegung:">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1458094327095" ID="ID_506349775" MODIFIED="1458094334354" TEXT="nur auf Basis der spec"/>
|
|
<node CREATED="1458094334991" ID="ID_559579301" MODIFIED="1458094343401" TEXT="ohne Daten-Introspektion"/>
|
|
</node>
|
|
<node CREATED="1458094507048" ID="ID_1527865890" MODIFIED="1512926191974" TEXT="Problem">
|
|
<node CREATED="1458094510463" ID="ID_1994183062" MODIFIED="1575133329935" TEXT="Spec bietet wenig Anhaltspunkte">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
streng genommen ist es nur erlaubt, das ID-Symbol auszuwerten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1458094562800" ID="ID_81556108" MODIFIED="1458094568467" TEXT="ID-Symbol"/>
|
|
<node CREATED="1458094569128" ID="ID_1725026097" MODIFIED="1458094579369" TEXT="attribute / child"/>
|
|
</node>
|
|
<node CREATED="1458094599835" HGAP="24" ID="ID_696146244" MODIFIED="1533608413876" TEXT="Zugang zum Payload-Typ" VSHIFT="10">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1458094616417" ID="ID_1705273642" MODIFIED="1458094632012" TEXT="Introspection / Switch-on-Type">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1458094634167" ID="ID_1910509473" MODIFIED="1575133329998">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Visitor bedeutet <b>zwei</b> Indirektionen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist nicht akzeptabel für ein reines Selektor-Prädikat!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458094716364" ID="ID_1379758002" MODIFIED="1561827465489" TEXT="eingeschränkt auf Objekt-Typ">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1458094735673" ID="ID_1998804888" MODIFIED="1458094743492" TEXT="Semantischer Typ"/>
|
|
<node CREATED="1458094743960" ID="ID_753315620" MODIFIED="1458094767704" TEXT="vs. Typisierung in der Sprache"/>
|
|
<node CREATED="1458094769365" ID="ID_1449818159" MODIFIED="1458094773848" TEXT="pattern match"/>
|
|
<node CREATED="1458094823973" ID="ID_384485794" MODIFIED="1458094841971">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denkbar nur bei Sub-<i>Objekten</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458094850490" ID="ID_1694517643" MODIFIED="1458094856797" TEXT="d.h. bei Record-Daten"/>
|
|
<node CREATED="1458094864424" ID="ID_1328934076" MODIFIED="1458094872787" TEXT="Record hat ein (semantisches) Typfeld"/>
|
|
<node CREATED="1458094922024" ID="ID_93367660" MODIFIED="1458094954604">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gilt für <i>alle</i> praktischen Anwendungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458094956636" ID="ID_664751342" MODIFIED="1575133330121" TEXT="denn nur Objekt-Kinder machen Sinn">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....auch wenn man zehnmal meinen könnte,
|
|
</p>
|
|
<p>
|
|
Kinder eines reinen Wert-Typs wären sinnvoll --
|
|
</p>
|
|
<p>
|
|
sie sind es nicht!
|
|
</p>
|
|
<p>
|
|
Jede sinnvolle <i>Entität</i> hat mehr als ein Attribut<i>! </i>
|
|
</p>
|
|
<p>
|
|
denn es macht keinen Sinn, Entitäten und reine Wert-Elemente
|
|
</p>
|
|
<p>
|
|
auf der gleichen Ebene in der gleichen Sammlung zu mischen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
D.h., entweder man hat ein Objekt, das als Kinder z.B. eine Liste von Strings hat,
|
|
</p>
|
|
<p>
|
|
oder man hat eine Entität, die z.b. zwei getypte Objekt-Kinder-Sammlungen hat,
|
|
</p>
|
|
<p>
|
|
wie z.B: eine Spur mit Labels und Clips
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458095217737" FOLDED="true" ID="ID_438870027" MODIFIED="1561827483835" TEXT="um das zu unterstützen...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458095230175" ID="ID_1191105811" MODIFIED="1458095239258" TEXT="müßte DataCap helfen"/>
|
|
<node CREATED="1458095367701" ID="ID_796317531" MODIFIED="1458095376400" TEXT="es gäbe dann einen Bottom-Wert"/>
|
|
<node CREATED="1458095240158" ID="ID_603223644" MODIFIED="1458095284084" TEXT="Introspektions-Verbot etwas aufgeweicht"/>
|
|
<node CREATED="1458095304886" ID="ID_164280831" MODIFIED="1458095318800" TEXT="dieser Gebrauch ist aber mit dem Objekt-Typfeld schon angelegt"/>
|
|
<node CREATED="1458095320692" ID="ID_842760339" MODIFIED="1458095332942" TEXT="die Bedeutung wird vom Client privat definiert"/>
|
|
<node CREATED="1458095409800" ID="ID_1254459851" MODIFIED="1458095442503" TEXT="ebenso wird aber auch die Bedeutung der ETD lokal definiert"/>
|
|
<node CREATED="1458095443115" ID="ID_1232895036" MODIFIED="1458095455459" TEXT="erscheint mir plausibel und vertretbar">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1461881999377" ID="ID_1658273003" MODIFIED="1461882004217" TEXT="so implementiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458095528224" ID="ID_1210077486" MODIFIED="1512926191979" TEXT="falls nein...">
|
|
<node CREATED="1458095540807" ID="ID_1604150177" MODIFIED="1458095553929" TEXT="übernimmt der nächste Onion-Layer"/>
|
|
<node CREATED="1458095554548" ID="ID_841667917" MODIFIED="1458095566303" TEXT="scheitert am Ende die Diff-Anwendung"/>
|
|
<node CREATED="1458095567123" ID="ID_1522962628" MODIFIED="1533608413880" TEXT="das kann nicht sein">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1458095599015" ID="ID_167965734" MODIFIED="1458095611129" TEXT="denn Struktur wird per Diff aufgebaut"/>
|
|
<node CREATED="1458095611645" ID="ID_381366724" MODIFIED="1458095623023" TEXT="und Diff wird von einer konsistenten Struktur generiert"/>
|
|
<node CREATED="1458095623563" ID="ID_616935645" MODIFIED="1458095636789" TEXT="wenngleich es sich auch um eine funktionale Struktur handeln kann..."/>
|
|
<node CREATED="1458095660150" ID="ID_521761960" MODIFIED="1458095668777" TEXT="wir sind nicht tolerant bei der Diff-Anwendung"/>
|
|
<node CREATED="1458095669437" ID="ID_1556672181" MODIFIED="1458095672801" TEXT="und das ist gut so."/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457741617655" ID="ID_1780561133" MODIFIED="1512926191980" TEXT="was ist ein "match"?">
|
|
<node CREATED="1458094392679" ID="ID_160796096" MODIFIED="1460755241888">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"target <i>matches</i> spec"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1458094428506" ID="ID_1974144009" MODIFIED="1458094435693" TEXT="darf Annahmen über den Typ der Spec machen"/>
|
|
<node CREATED="1458094397350" ID="ID_1351948326" MODIFIED="1458094427326" TEXT="darf in die Payload der Spec schauen"/>
|
|
<node CREATED="1458094437249" ID="ID_636183740" MODIFIED="1458094463529" TEXT="darf Methoden des Datenobjekts aufrufen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457038643034" ID="ID_2715278" MODIFIED="1515978009310" TEXT="abstrakte Position">
|
|
<node CREATED="1460755065016" ID="ID_505782373" MODIFIED="1460755138704" TEXT="wird niemals direkt repräsentiert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1460755072903" ID="ID_1689810775" MODIFIED="1460755130181">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber existiert <i>nominell </i>und kontext-abhängig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1460755080894" ID="ID_433210103" MODIFIED="1460755106150" TEXT="und faktisch unabhängig in jedem »onion layer«"/>
|
|
</node>
|
|
<node CREATED="1457038527402" HGAP="16" ID="ID_1999301096" MODIFIED="1512926191982" TEXT="Mutations-Primitive" VSHIFT="7">
|
|
<node CREATED="1457038788583" ID="ID_745585126" MODIFIED="1457038801193" TEXT="einheitlich benannt"/>
|
|
<node CREATED="1457038801733" ID="ID_61865380" MODIFIED="1457038805816" TEXT="auf mehreren Ebenen"/>
|
|
<node CREATED="1457119943698" ID="ID_1184811956" MODIFIED="1512926191982" TEXT="Fehlerbehandlung">
|
|
<node CREATED="1457119949785" ID="ID_854748958" MODIFIED="1457119953012" TEXT="Match-Check"/>
|
|
<node CREATED="1457119953384" ID="ID_1221897136" MODIFIED="1457119957324" TEXT="aber keine Exception"/>
|
|
<node CREATED="1457119959408" ID="ID_1918915677" MODIFIED="1457119961803" TEXT="sondern NOP"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457227228502" ID="ID_1837209046" MODIFIED="1512926191983" TEXT="sub-Mutator">
|
|
<node CREATED="1457227237269" ID="ID_13363638" MODIFIED="1457227296340" TEXT="wird über ein Handle implantiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1457227248779" ID="ID_1651719395" MODIFIED="1457227279155" TEXT="Implementierungs-Schicht kennt Typ"/>
|
|
<node CREATED="1457227279703" ID="ID_1075464109" MODIFIED="1457227288610" TEXT="aber Tree-Mutator übernimmt ownership"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456528462585" HGAP="48" ID="ID_777775203" MODIFIED="1512926191983" TEXT="Elemente" VSHIFT="21">
|
|
<node CREATED="1456528472016" ID="ID_1698126172" MODIFIED="1456528476211" TEXT="bleiben abstrakt"/>
|
|
<node CREATED="1456528477415" ID="ID_729445573" MODIFIED="1512926191984" TEXT="abstrakte "Position"">
|
|
<node CREATED="1456533135345" ID="ID_1812393019" MODIFIED="1465428629652" TEXT="Problem: wem gehört diese Position?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1456533146055" ID="ID_1492337931" MODIFIED="1456533213989" TEXT="muß stets über API klar gemacht werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1456533166197" ID="ID_1236312189" MODIFIED="1456533204589" TEXT="der Selektor entscheidet, wer gemeint ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1456528485326" ID="ID_1937076501" MODIFIED="1512926191984" TEXT="getypte Kinder">
|
|
<node CREATED="1456528491109" ID="ID_1937415602" MODIFIED="1456528504567" TEXT="auf Einzelfall-Basis"/>
|
|
<node CREATED="1456528505395" ID="ID_644319871" MODIFIED="1456528519117" TEXT="wer per Selektor zuständig ist"/>
|
|
<node CREATED="1456528539799" ID="ID_276410608" MODIFIED="1456528550465" TEXT="Typisierung ergibt sich als Effekt"/>
|
|
<node CREATED="1456528551029" ID="ID_998833201" MODIFIED="1465428643785" TEXT="Typisierung wird nicht eigens repräsentiert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1457232376244" HGAP="29" ID="ID_45251842" MODIFIED="1575133330682" TEXT="onion layer" VSHIFT="26">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das sind die konkreten Implementierungen
|
|
</p>
|
|
<p>
|
|
für spezifische Arten von Bindings
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1457232408368" FOLDED="true" HGAP="29" ID="ID_1582052207" MODIFIED="1576200546205" TEXT="TestWireTap / TestMutationTarget" VSHIFT="-6">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1457232426238" ID="ID_1103254276" MODIFIED="1457232567024" TEXT="brauche ich, um das API zu entwickeln">
|
|
<linktarget COLOR="#6b77a6" DESTINATION="ID_1103254276" ENDARROW="Default" ENDINCLINATION="-116;0;" ID="Arrow_ID_1002137074" SOURCE="ID_258858244" STARTARROW="None" STARTINCLINATION="-819;487;"/>
|
|
</node>
|
|
<node CREATED="1457232433157" ID="ID_176264041" MODIFIED="1457232443415" TEXT="ggfs später nützlich zur Diagnose"/>
|
|
<node CREATED="1457232444075" ID="ID_334975575" MODIFIED="1457232459765" TEXT="soll stets über andere, konkrete Mutation-Layer gelegt werden"/>
|
|
<node CREATED="1457232579073" ID="ID_1549772477" MODIFIED="1512926191986" TEXT="Grenzen">
|
|
<node CREATED="1457232582704" ID="ID_1363198759" MODIFIED="1457232590595" TEXT="protokolliert nur String-Repräsentation"/>
|
|
<node CREATED="1457232591087" ID="ID_1500483325" MODIFIED="1575133330772">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann <i>niemals </i>geschachtelte sub-Mutatoren modellieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ja wirklich, das wäre nicht sinnvoll!!!!!
|
|
</p>
|
|
<p>
|
|
auch wenn man meinen könnte, es geht.
|
|
</p>
|
|
<p>
|
|
Grund ist nämlich, es kann jeweils nur ein Onion-Layer für ein gegebenes Element "zuständig" sein.
|
|
</p>
|
|
<p>
|
|
Und aus Gründen der logischen Konsistenz darf dieser Diagnose-Layer niemals für ein Element zuständig sein,
|
|
</p>
|
|
<p>
|
|
denn sonst würde er es für darunter liegende Layer verschatten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457232734636" FOLDED="true" ID="ID_743556019" MODIFIED="1576281702665" TEXT="STL Collection">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1458175823858" ID="ID_1221299499" MODIFIED="1512926191990" TEXT="Design-Grundlagen">
|
|
<node CREATED="1457741673001" ID="ID_1785153368" MODIFIED="1512926191990" TEXT="konkrete Beispiele">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1457741683687" ID="ID_733055764" MODIFIED="1457741691409" TEXT="Timelines"/>
|
|
<node CREATED="1457741691837" ID="ID_458049766" MODIFIED="1457741697832" TEXT="Tracks"/>
|
|
<node CREATED="1457741753006" ID="ID_1923812777" MODIFIED="1457742102003" TEXT="Clips / Effekte / Marken"/>
|
|
<node CREATED="1457741809422" ID="ID_1768016408" MODIFIED="1457741815657" TEXT="Effekte / Transitions"/>
|
|
</node>
|
|
<node CREATED="1457742434714" ID="ID_340131034" MODIFIED="1457742717208">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ <i>immer</i> Mitwirkung des Elements
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1457742547067" HGAP="33" ID="ID_585833263" MODIFIED="1512926191991" TEXT="Selector explizit bauen" VSHIFT="7">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1457742554722" ID="ID_1033631571" MODIFIED="1469918265250" TEXT="Selector-Interface">
|
|
<arrowlink COLOR="#7caed5" DESTINATION="ID_478070427" ENDARROW="Default" ENDINCLINATION="466;133;" ID="Arrow_ID_1332735015" STARTARROW="None" STARTINCLINATION="681;0;"/>
|
|
</node>
|
|
<node CREATED="1457742626368" ID="ID_166928002" MODIFIED="1512926191991" TEXT="2.Ausdrucks-Ebene">
|
|
<node CREATED="1457742639703" ID="ID_285055499" MODIFIED="1457742645826" TEXT="neben der Identität"/>
|
|
<node CREATED="1457742646366" ID="ID_1443547530" MODIFIED="1533608413881" TEXT="logische Typisierung">
|
|
<node CREATED="1457742667947" ID="ID_1038084970" MODIFIED="1457742677734" TEXT="entweder anhand Payload-Typ"/>
|
|
<node CREATED="1457742678185" ID="ID_298458662" MODIFIED="1457742684533" TEXT="oder versteckt in der ID"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175861176" FOLDED="true" HGAP="33" ID="ID_1824353830" MODIFIED="1576200485063" TEXT="Design-Anforderungen">
|
|
<node CREATED="1458175880034" ID="ID_1162706656" MODIFIED="1512926191992" TEXT="gegeben ist eine STL-Collection">
|
|
<node CREATED="1458175892400" ID="ID_1414371056" MODIFIED="1458175904674" TEXT="allgemeinstes STL-Container-Interface"/>
|
|
<node CREATED="1458175905766" ID="ID_1684884906" MODIFIED="1458175919817" TEXT="Wert-Typ per typedef abgreifen"/>
|
|
</node>
|
|
<node CREATED="1455927276314" HGAP="91" ID="ID_1546815224" MODIFIED="1525124215145" TEXT="brauche zusätzliche Operationen" VSHIFT="-3">
|
|
<cloud COLOR="#fce9c0"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1458175942866" ID="ID_1696569407" MODIFIED="1512926191994" TEXT="match">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177113846" ID="ID_1566509772" MODIFIED="1458177953094" TEXT="stellt fest, ob das Ziel paßt"/>
|
|
<node CREATED="1458177136475" ID="ID_595613576" MODIFIED="1458177953094" TEXT="greift auf eine ID des Zieles zurück"/>
|
|
<node CREATED="1458177147897" ID="ID_1293563447" MODIFIED="1458177953094" TEXT="muß daher in der Regel bereitgestellt werden"/>
|
|
<node CREATED="1458177166543" ID="ID_1334737539" MODIFIED="1533608413881" TEXT="Ersatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458177169406" ID="ID_1424015065" MODIFIED="1458177953094" TEXT="content-Match"/>
|
|
<node CREATED="1458177173574" ID="ID_1148713847" MODIFIED="1575133331142" TEXT="Konsequenz: man kann keine Assignements machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil beim Assignment die Spec (=GenNode) eben
|
|
</p>
|
|
<p>
|
|
zwar die ID des Zieles, aber den neu zuzuweisenden Wert enthält.
|
|
</p>
|
|
<p>
|
|
Also wird sich das Ziel nicht anhand des neuen Wertes finden lassen,
|
|
</p>
|
|
<p>
|
|
weil es eben grade noch nicht diesen neuen Wert trägt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458177198643" ID="ID_179880742" MODIFIED="1458177953094" TEXT="Konsequenz: Suche kann das falsche Resultat erwischen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175960615" ID="ID_1831530423" MODIFIED="1512926191995" TEXT="ctor">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177315803" ID="ID_179295186" MODIFIED="1458177953094" TEXT="konstruiert aus der Spec ein neues Element"/>
|
|
<node CREATED="1458177335632" ID="ID_1308099027" MODIFIED="1458177953094" TEXT="muß typischerweise die Interna des Zieles kennen"/>
|
|
<node CREATED="1458177347622" ID="ID_1077558487" MODIFIED="1533608413881" TEXT="Ersatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458177489444" ID="ID_1781927029" MODIFIED="1458177953094" TEXT="unterstelle Payload == Zieltyp"/>
|
|
<node CREATED="1458177572865" ID="ID_1189103336" MODIFIED="1458177953094" TEXT="Konstruktor auf dem Ziel, der eine GenNode nimmt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175991795" ID="ID_711298865" MODIFIED="1512926191995" TEXT="optional...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458176002762" ID="ID_1018722356" MODIFIED="1533608413882" TEXT="selector">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177605869" ID="ID_405530200" MODIFIED="1458177953094" TEXT="bestimmt ob die Spec für diesen Binding-Layer überhaupt relevant ist"/>
|
|
<node CREATED="1458177631409" ID="ID_1214963706" MODIFIED="1458177953094" TEXT="erlaubt das Filtern mit mehreren Bindings"/>
|
|
<node CREATED="1458177642144" ID="ID_60004797" MODIFIED="1561827465503" TEXT="Ersatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458177646671" ID="ID_231593517" MODIFIED="1458177953094" TEXT="kein Selector"/>
|
|
<node CREATED="1458177652662" ID="ID_65084807" MODIFIED="1458177953094" TEXT="es kann dann also nur ein Binding geben"/>
|
|
<node CREATED="1458177664868" ID="ID_643667548" MODIFIED="1458177953094" TEXT="das ist aber auch der häufigste Fall"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176008025" ID="ID_1481953509" MODIFIED="1533608413883" TEXT="setter">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177697657" ID="ID_1719649092" MODIFIED="1458177953095" TEXT="erlaubt Zuweisung"/>
|
|
<node CREATED="1458177712798" ID="ID_1927197411" MODIFIED="1458177953095" TEXT="setzt Auswahl per match voraus"/>
|
|
<node CREATED="1458177735635" ID="ID_760968660" MODIFIED="1561827465503" TEXT="Ersatz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1458177738499" ID="ID_465396536" MODIFIED="1458177953095" TEXT="keiner"/>
|
|
<node CREATED="1458177741155" ID="ID_389524826" MODIFIED="1458177953095" TEXT="dann gibt's eben keine Zuweisung"/>
|
|
<node CREATED="1458177749233" ID="ID_137083197" MODIFIED="1458177953095" TEXT="auch nicht nötig bei sub-Scopes"/>
|
|
<node CREATED="1458177803730" ID="ID_796394975" MODIFIED="1458177953095" TEXT="auch nicht nötig bei immutable values"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176018087" ID="ID_161071725" MODIFIED="1533608413884" TEXT="mutator">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177821712" ID="ID_1562278983" MODIFIED="1458177953095" TEXT="baut einen sub-Mutator für einen nested scope"/>
|
|
<node CREATED="1458177851988" ID="ID_1086989195" MODIFIED="1458177953095" TEXT="setzt Auswahl per match voraus"/>
|
|
<node CREATED="1458177857939" ID="ID_1441498229" MODIFIED="1561827465504" TEXT="Ersatz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1458177861162" ID="ID_895205483" MODIFIED="1458177953095" TEXT="keiner"/>
|
|
<node CREATED="1458177863506" ID="ID_1223351113" MODIFIED="1458177953095" TEXT="dann gibts eben keine Behandlung von nested scopse"/>
|
|
<node CREATED="1458177874760" ID="ID_1180989735" MODIFIED="1458177953095" TEXT="auch nicht nötig bei primitive values"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176048564" ID="ID_1687741268" MODIFIED="1512926191998" TEXT="Flexibilität">
|
|
<node CREATED="1458176054154" ID="ID_470009160" MODIFIED="1458176076851" TEXT="so wenig typ-Feslegung wie möglich"/>
|
|
<node CREATED="1458176077368" ID="ID_1813716923" MODIFIED="1458176092658" TEXT="fallback bei fehlendern Operationen"/>
|
|
<node CREATED="1458176093958" ID="ID_1948085876" MODIFIED="1512926191999" TEXT="Argument: "dann halt nicht"">
|
|
<node CREATED="1458176117266" ID="ID_1409813294" MODIFIED="1458176127813" TEXT="es ist so wie es ist"/>
|
|
<node CREATED="1458176128352" ID="ID_272673102" MODIFIED="1458176139563" TEXT="die Gegenseite weiß schon was sie will"/>
|
|
<node CREATED="1458176252336" ID="ID_1153956310" MODIFIED="1533608413885" TEXT="ich bin, also bin ich konsistent">
|
|
<node CREATED="1458176267382" ID="ID_1638809288" MODIFIED="1458176296319" TEXT="konsistent ist, was der diff erzeugt"/>
|
|
<node CREATED="1458176297282" ID="ID_1916492291" MODIFIED="1458176305981" TEXT="alles wird per diff erzeugt"/>
|
|
<node CREATED="1458176306593" ID="ID_1118529331" MODIFIED="1458176314868" TEXT="also ist alles, was existiert, auch konsistent"/>
|
|
</node>
|
|
<node CREATED="1458176787953" ID="ID_289940321" MODIFIED="1533608413887" TEXT="sinnvoll gewählt">
|
|
<node CREATED="1458176794848" ID="ID_1468708263" MODIFIED="1458176810370" TEXT="native datenstruktur ist so gewählt, daß sie ihren Zweck erfüllt"/>
|
|
<node CREATED="1458176883836" ID="ID_1253939379" MODIFIED="1458176899324">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
generische Repräsentaton ist so gewählt,
|
|
</p>
|
|
<p>
|
|
daß sich alle relevanten Eigenschaften darstellen lassen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458176911161" ID="ID_431800648" MODIFIED="1561827465504">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn also ein Teil der diff-Funkttionalität nicht verfügbar ist,
|
|
</p>
|
|
<p>
|
|
dann wird es wohl so sein, daß sie auch nicht gebraucht wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1458176947972" ID="ID_1847366222" MODIFIED="1458176965869" TEXT="Beispiel: primitive Werte sind eben kein sub-Scope"/>
|
|
<node CREATED="1458176966665" ID="ID_332748706" MODIFIED="1458176981459" TEXT="Beispiel: immutable elements sind eben nicht zuweisbar"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176998437" ID="ID_280086408" MODIFIED="1575133331758" TEXT="keine unnötigen Einschränkungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwar erscheint es nicht sonderlich sinnvoll,
|
|
</p>
|
|
<p>
|
|
als target auch eine Menge von primitiven Werten zuzulassen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Es gibt aber auch keinen wirklichen Grund, dies zu verbieten,
|
|
</p>
|
|
<p>
|
|
sofern es gelingt, die Funktionalität gutmütig zu degradieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458178113697" HGAP="46" ID="ID_1695144986" MODIFIED="1512926192002" TEXT="Design-Schlußfolgerungen" VSHIFT="-5">
|
|
<node CREATED="1458178126159" ID="ID_1000523444" MODIFIED="1458178131587" TEXT="Rahmenklasse + Closures"/>
|
|
<node CREATED="1458178133078" ID="ID_594771691" MODIFIED="1458851636692" TEXT="Closures mit der Ersatz-Impl vorbelegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1458178150916" ID="ID_184029363" MODIFIED="1458178174848" TEXT="Problem: komplexe Konstruktion">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1458178165322" ID="ID_813311479" MODIFIED="1512926192002" TEXT="Lösung: nested DSL">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458178203821" ID="ID_1772782569" MODIFIED="1458178222190" TEXT="die Top-Level Builder-Funktion erwartet das volle Binding"/>
|
|
<node CREATED="1458178223723" ID="ID_489567599" MODIFIED="1458178247755" TEXT="es gibt eine freie Funktion, die einen nested Builder für das Binding liefert"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1458178288690" FOLDED="true" ID="ID_788822286" MODIFIED="1576281513362" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1458178298328" ID="ID_1990195829" MODIFIED="1512926192003" TEXT="Builder">
|
|
<node CREATED="1458325962991" ID="ID_548735792" MODIFIED="1460753004725" TEXT="Typ-Definitionen schwierig anzuschreiben">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1458325973486" ID="ID_1681473580" MODIFIED="1458325992405" TEXT="Code ziemlich redundant und undurchsichtig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1458326045724" ID="ID_65072201" MODIFIED="1575133331952" TEXT="Typ-Check erst sehr spät">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen,
|
|
</p>
|
|
<p>
|
|
da sind mehrere Layer an praktisch ungebundenem Template-Code dazwischen,
|
|
</p>
|
|
<p>
|
|
so daß zu befürchten steht, daß ein unpassendes Lambda erst weit entfernt
|
|
</p>
|
|
<p>
|
|
eine womöglich irreführende Meldung generiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink DESTINATION="ID_1678218183" ENDARROW="Default" ENDINCLINATION="176;0;" ID="Arrow_ID_1136171372" STARTARROW="None" STARTINCLINATION="176;0;"/>
|
|
</node>
|
|
<node CREATED="1472498654730" ID="ID_4691477" MODIFIED="1472498676884" TEXT="gelöst durch static_assert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458178300984" ID="ID_1281780083" MODIFIED="1512926192004" TEXT="Binding-Layer">
|
|
<node CREATED="1458850722203" ID="ID_1721325933" MODIFIED="1512926192004" TEXT="Fehler bei fehlender Funktionalität">
|
|
<node CREATED="1458850733769" ID="ID_668556812" MODIFIED="1458850744620" TEXT="kein Setter"/>
|
|
<node CREATED="1458850746184" ID="ID_34346680" MODIFIED="1458850752370" TEXT="kein Mutator"/>
|
|
</node>
|
|
<node CREATED="1458850782747" ID="ID_956633485" MODIFIED="1458850793430" TEXT="Umgang mit fehlendem Selector"/>
|
|
<node CREATED="1458934854051" ID="ID_1793475507" MODIFIED="1512926192004" TEXT="Binding stärker abschließen">
|
|
<node CREATED="1458934863225" ID="ID_1054692405" MODIFIED="1458934897237" TEXT="contentBuffer könnte privat sein">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1458934878911" ID="ID_1685655700" MODIFIED="1458934893132" TEXT="welche Iteratoren müssen exponiert werden">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1460762013033" ID="ID_513991249" MODIFIED="1512926192005" TEXT="Mutation">
|
|
<node CREATED="1460762015777" ID="ID_671701663" MODIFIED="1533608413888">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erfordert <i>wirklich</i> Kooperation
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1460762025520" ID="ID_840517858" MODIFIED="1460762032675" TEXT="zwischen dem gesendeten Diff"/>
|
|
<node CREATED="1460762033119" ID="ID_104073581" MODIFIED="1460762045704" TEXT="und der empfangenden Implementierungs-Datenstruktur"/>
|
|
</node>
|
|
<node CREATED="1460762065371" ID="ID_1300484830" MODIFIED="1533608413889" TEXT="brauche wohl "Introspection light"">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1460762101046" ID="ID_1986146276" MODIFIED="1460762111448" TEXT="damit ich einen Sub-Scope vorbereiten kann"/>
|
|
<node CREATED="1460762111924" ID="ID_258947464" MODIFIED="1460762120759" TEXT="in separater privater Datenstrukcur"/>
|
|
<node CREATED="1460762121259" ID="ID_1701228640" MODIFIED="1575133332206" TEXT="ist aber nur rein hier im Test ein Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir verwenden hier als "private" Datenstruktur
|
|
</p>
|
|
<p>
|
|
eine etwas komische Collection von Strings,
|
|
</p>
|
|
<p>
|
|
in die wir die String-Repräsentation der Spec-Payload schreiben.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
In der Praxis dagegen würde man wirklich einen privaten Datentyp verwenden,
|
|
</p>
|
|
<p>
|
|
und dann auch voraussetzen, daß man <i>nur</i> Kinder dieses Typs (oder zuweisungskompatibel) bekommt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Mein Poblem hier ist, daß ich in dieser Demonstrations-Datenstruktur keine nested scopes repräsentieren kann.
|
|
</p>
|
|
<p>
|
|
Aber hey!, es ist meine private Datenstruktur -- also kann ich einfach eine Map von nested scopes
|
|
</p>
|
|
<p>
|
|
daneben auf die grüne Wiese stellen. Ist ja nur ein Test :-D
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1460762330487" ID="ID_1060781290" MODIFIED="1575133332223" TEXT="Nein! Schwein gehabt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dankenswerterweise hat der subscript-Operator von std::Map
|
|
</p>
|
|
<p>
|
|
die nette Eigenschaft, beim ersten Zugriff auf einen neuen Key
|
|
</p>
|
|
<p>
|
|
dessen payload per default-konstruktor zu erzeugen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458868836883" ID="ID_776863625" MODIFIED="1512926192006" TEXT="Beobachtungen">
|
|
<node CREATED="1458868852849" ID="ID_474120946" MODIFIED="1575133332262" TEXT="Sonderbarer "this"-Typ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Builder in der nested DSL generiert einen sonderbar falschen "this"-Typ,
|
|
</p>
|
|
<p>
|
|
genauer gesagt, eine TYPID die falsch ist.
|
|
</p>
|
|
<p>
|
|
Und zwar kommt es da zum "Übersprechen" von einem Typ-Parameter in den anderen.
|
|
</p>
|
|
<p>
|
|
Im Besonderen hab ich beobachtet, daß, wenn man auf den 3.Typparameter ein Lambda gibt,
|
|
</p>
|
|
<p>
|
|
dann auf dem 4. oder 5. Typparameter der bisherige /alte Typ des 3.Typparameters auftaucht,
|
|
</p>
|
|
<p>
|
|
u.U auch eingeschachtelt als ein Argument.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Habe mich aber davon überzeugt, daß die eigentlichen Typ-Parameter in Ordnung sind.
|
|
</p>
|
|
<p>
|
|
Und zwar habe ich das verifiziert
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
durch Ausgeben der Typen im Konstruktor (mithilfe meiner typeStr<TY>()
|
|
</li>
|
|
<li>
|
|
durch Einbauen einer Static-Assertion mit Signatur-Match
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458850516270" ID="ID_960489546" MODIFIED="1512926192006" TEXT="Test">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1458850521270" ID="ID_10780308" MODIFIED="1512926192007" TEXT="Fälle">
|
|
<arrowlink COLOR="#639ad5" DESTINATION="ID_1333254858" ENDARROW="Default" ENDINCLINATION="1091;0;" ID="Arrow_ID_1011836019" STARTARROW="None" STARTINCLINATION="1150;185;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1458850526133" ID="ID_1314105749" MODIFIED="1458850550109" TEXT="Binden an Sammlung aus Primitiven"/>
|
|
<node CREATED="1458850550705" ID="ID_1183034205" MODIFIED="1458850572315" TEXT="Binden an Sammlung aus Spezialtypen"/>
|
|
</node>
|
|
<node CREATED="1458850656668" ID="ID_98190211" MODIFIED="1512926192007" TEXT="Defaults">
|
|
<node CREATED="1458850660523" ID="ID_907930269" MODIFIED="1575133332339" TEXT="GenNode-verträglicher Payload-Typ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gemeint ist:
|
|
</p>
|
|
<p>
|
|
die native Datenstruktur ist eine Collection von Elementen,
|
|
</p>
|
|
<p>
|
|
welche ohne Weiteres direkt in eine GenNode gepackt werden könnten. Denn dann läßt
|
|
</p>
|
|
<p>
|
|
sich eine einfache Default-Implementierung des Matchers angeben
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Typisches Beispiel: eine STL-Collection von Strings.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458850672705" ID="ID_1189075551" MODIFIED="1458850675197" TEXT="kein Setter"/>
|
|
<node CREATED="1458850675641" ID="ID_1246319832" MODIFIED="1458850678564" TEXT="kein Mutator"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576201164862" ID="ID_1192285970" MODIFIED="1576201174765" TEXT="Anwendung/Weiterungen">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1576201177204" ID="ID_1553674095" MODIFIED="1576201185379" TEXT="konkrete STL-Container">
|
|
<node COLOR="#435e98" CREATED="1576201634998" ID="ID_1964972550" MODIFIED="1576201711423" TEXT="Kriterium: Anfügen in Iterations-Ordnung möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, wir können Elemente in der gleichen Reihenfolge anfügen, in der sie später dann in der Iteration erscheinen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1576201686151" ID="ID_621927049" MODIFIED="1576201705653" TEXT="das schließt z.B. die std::forward_list aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463687466573" ID="ID_453712930" MODIFIED="1576203666771" TEXT="»Attribut-Map« via Collection-Binding">
|
|
<linktarget COLOR="#9f96d9" DESTINATION="ID_453712930" ENDARROW="Default" ENDINCLINATION="722;-59;" ID="Arrow_ID_1263259661" SOURCE="ID_1112268061" STARTARROW="Default" STARTINCLINATION="1873;0;"/>
|
|
<linktarget COLOR="#9f96d9" DESTINATION="ID_453712930" ENDARROW="Default" ENDINCLINATION="478;123;" ID="Arrow_ID_1448345273" SOURCE="ID_1994979880" STARTARROW="None" STARTINCLINATION="479;26;"/>
|
|
<node CREATED="1576201733178" ID="ID_150341491" MODIFIED="1576201748321" TEXT="clever aber etwas faul">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1576201756590" ID="ID_1699263676" MODIFIED="1576201764691" TEXT="im Widerspruch zum Konzept"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576203601492" ID="ID_1611724080" MODIFIED="1576203790175" TEXT="auf technischer Ebene problematisch">
|
|
<linktarget COLOR="#e69f98" DESTINATION="ID_1611724080" ENDARROW="Default" ENDINCLINATION="-741;702;" ID="Arrow_ID_1638749746" SOURCE="ID_42201574" STARTARROW="None" STARTINCLINATION="1526;117;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1475449660020" ID="ID_1478336994" MODIFIED="1475449740005" TEXT="Diff geht von Listen-Ordnung aus">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1475449777532" ID="ID_631032937" MODIFIED="1575133341421" TEXT="Symptom: Compile-Fehler">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Map hat kein emplace_back
|
|
</li>
|
|
<li>
|
|
Map hat kein back()
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Beides ist erst mal sinnvoll. Map hat zwar ein emplace, aber das fügt eben <i>irgendwo</i> ein
|
|
</p>
|
|
<p>
|
|
Und es gibt nicht sowas wie das "zuletzt behandelte" Element
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576204849307" ID="ID_1683329492" MODIFIED="1576204859597" TEXT="getriggert vom include von MockElm"/>
|
|
<node CREATED="1576204860969" ID="ID_886723912" MODIFIED="1576204978226" TEXT="dieses definiert CollectionBindingBuilder<std::map<string,string>, ....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
MockElm, Z 260 : .attach (collection(attrib)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576281315883" ID="ID_640546093" MODIFIED="1576281693125" TEXT="Lösung: ContainerTraits">
|
|
<linktarget COLOR="#2eb28a" DESTINATION="ID_640546093" ENDARROW="Default" ENDINCLINATION="-191;-682;" ID="Arrow_ID_562122794" SOURCE="ID_1695910920" STARTARROW="None" STARTINCLINATION="485;33;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576281324121" ID="ID_1199488349" MODIFIED="1576281329357" TEXT="zunächst pragmatisch..."/>
|
|
<node CREATED="1576281330011" ID="ID_1351721283" MODIFIED="1576281335828" TEXT="für std::vector"/>
|
|
<node CREATED="1576281336488" ID="ID_3661697" MODIFIED="1576281340447" TEXT="für std::map">
|
|
<node CREATED="1576281341463" ID="ID_774200305" MODIFIED="1576281347109" TEXT="auch wenn's nicht schön ist..."/>
|
|
<node CREATED="1576281347766" ID="ID_1789296590" MODIFIED="1576281368023" TEXT="prinzipiell gibt es keinen Grund, diese Alternative nicht zu bieten"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1576281371403" ID="ID_424557250" MODIFIED="1576281393116" TEXT="Zukunft: "generischer STL container"">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1576281394776" ID="ID_847933754" MODIFIED="1576281409962" TEXT="vermutlich gibt es nämlich einen kleinsten gemeinsamen Nenner"/>
|
|
<node CREATED="1576281412733" ID="ID_193628368" MODIFIED="1576281422192" TEXT="möglicherweise mit C++20 / Concepts"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457232752458" FOLDED="true" ID="ID_679000009" MODIFIED="1576203843960" TEXT="Attribute">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1458175823858" ID="ID_1006862973" MODIFIED="1512926192010" TEXT="Design-Grundlagen">
|
|
<node CREATED="1461882686190" ID="ID_1889353960" MODIFIED="1575133332435" TEXT="von praktischer Notwendigkeit getrieben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir integrieren Attribute nicht, weil es so schön symmetrisch ist,
|
|
</p>
|
|
<p>
|
|
sondern weil sie essentiell zum Wesen von Objekten gehören.
|
|
</p>
|
|
<p>
|
|
Wenn wir Änderungen an Objekt-Strukturen als Diff erfassen wollen,
|
|
</p>
|
|
<p>
|
|
dann <i>müssen</i> Attribute irgendwie sinnvoll integriert sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1457741673001" ID="ID_162846674" MODIFIED="1512926192010" TEXT="konkrete Beispiele">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1457741683687" ID="ID_1986089780" MODIFIED="1461888218005" TEXT="Position eines Clips"/>
|
|
<node CREATED="1461888218521" ID="ID_805889980" MODIFIED="1461888222508" TEXT="Länge eines Clips"/>
|
|
<node CREATED="1461888223024" ID="ID_1852444919" MODIFIED="1461888302874" TEXT="Typ eines Markers"/>
|
|
<node CREATED="1461888304126" ID="ID_446819203" MODIFIED="1461888305362" TEXT="..."/>
|
|
</node>
|
|
<node CREATED="1457742434714" ID="ID_1724305674" MODIFIED="1461888342584">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ <i>immer</i> in der Klasse verankert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1457742434714" ID="ID_1982563767" MODIFIED="1461888407600">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ es geht eigentlich <i>nur</i> um den Wert des Attributes
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175861176" FOLDED="true" HGAP="39" ID="ID_9781860" MODIFIED="1576200444705" TEXT="Design-Anforderungen" VSHIFT="7">
|
|
<node CREATED="1458175880034" ID="ID_470578362" MODIFIED="1512926192012" TEXT="...ein Objekt hat schon ein bestimmtes Feld">
|
|
<node CREATED="1458175892400" ID="ID_775558171" MODIFIED="1461888660658" TEXT="Typ"/>
|
|
<node CREATED="1461888661462" ID="ID_274214255" MODIFIED="1461888668033" TEXT="default-Wert"/>
|
|
<node CREATED="1458175905766" ID="ID_625777549" MODIFIED="1461888693671">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
manche Felder sind <i>optional</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461888779999" ID="ID_1154997498" MODIFIED="1512926192012" TEXT="innerer Widerspruch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1461888830680" ID="ID_1487174561" MODIFIED="1461888837867" TEXT="Feld vs Attribut"/>
|
|
<node CREATED="1461888838455" ID="ID_1479289808" MODIFIED="1461888848953" TEXT="das Diff drückt sich in Attributen aus"/>
|
|
<node CREATED="1461888982036" ID="ID_1968370725" MODIFIED="1512926192013" TEXT="Umgang mit den Diskrepanzen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1461889012008" ID="ID_40654684" MODIFIED="1533608413889" TEXT="Einfügen eines Attributes">
|
|
<node CREATED="1461889021646" ID="ID_201631788" MODIFIED="1461889026273" TEXT="wo das Feld schon da ist"/>
|
|
<node CREATED="1461889026813" ID="ID_1640082452" MODIFIED="1461889040368" TEXT="wo es kein korrespondierendes Feld gibt"/>
|
|
</node>
|
|
<node CREATED="1461889146846" ID="ID_25411084" MODIFIED="1461889152792" TEXT="Löschen eines Attributes"/>
|
|
<node CREATED="1461889107939" ID="ID_1826186779" MODIFIED="1461889133891" TEXT="Umordnen von Attributen"/>
|
|
</node>
|
|
<node CREATED="1461889187336" ID="ID_385261311" MODIFIED="1512926192015" TEXT="Leitgedanke">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<node CREATED="1461889203662" ID="ID_896442640" MODIFIED="1461889243250" TEXT="»auf GenNode und Objekt gleichermaßen anwendbar«">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1461889253087" ID="ID_1086093590" MODIFIED="1533608413908" TEXT="das heißt...">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
<node CREATED="1461889261806" ID="ID_7827811" MODIFIED="1461889621538" TEXT="wende Diff auf GenNode an">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1461889282580" ID="ID_915026064" MODIFIED="1461889621538" TEXT="wende gleichen Diff auf gebundenes Objekt an">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1461889296634" ID="ID_1803163409" MODIFIED="1461889621537" TEXT="Ergebnis muß semantisch äquivalent sein">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1461889399932" ID="ID_384089086" MODIFIED="1461889621534">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unter der Maßgabe,
|
|
</p>
|
|
<p>
|
|
wie ETD ein Objekt repäsentiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1461889470866" ID="ID_582798205" MODIFIED="1561827465534" TEXT="operational">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1461889474402" ID="ID_478945699" MODIFIED="1575133332828" TEXT="alle Informationen, die die Anwendung nicht nutzt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"Anwendung" : meint das Anwenden eines Diffs auf ein Ziel-Objekt
|
|
</p>
|
|
<p>
|
|
"nicht nutzen" : meint ignorieren und verwerfen der Information
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461889550072" ID="ID_1443097308" MODIFIED="1461889558442" TEXT="dürfen nur Zustands-Änderungen bewirken"/>
|
|
<node CREATED="1461889558983" ID="ID_567185466" MODIFIED="1461889796278" TEXT="welche keinen Einfluß auf nachfolgende Diffs haben">
|
|
<arrowlink COLOR="#be5b66" DESTINATION="ID_325506443" ENDARROW="Default" ENDINCLINATION="28;-28;" ID="Arrow_ID_1504152758" STARTARROW="None" STARTINCLINATION="13;20;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461889656194" HGAP="73" ID="ID_325506443" MODIFIED="1533608413909" TEXT="ist das überhaupt möglich" VSHIFT="23">
|
|
<linktarget COLOR="#be5b66" DESTINATION="ID_325506443" ENDARROW="Default" ENDINCLINATION="28;-28;" ID="Arrow_ID_1504152758" SOURCE="ID_567185466" STARTARROW="None" STARTINCLINATION="13;20;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1461889858863" ID="ID_1007257543" MODIFIED="1575133332880" TEXT="sicher nicht bidirektional">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
meint: ETD -> Objekt und dann später Objekt -> ETD
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
Weil sich in der ETD die Reihenfolge ändern kann,
|
|
</p>
|
|
<p>
|
|
und aber das Aufspielen eines Diffs auf beiden Seiten
|
|
</p>
|
|
<p>
|
|
zwingend die gleiche Reihenfolge erfordert!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461890009355" ID="ID_1795458386" MODIFIED="1575133332917" TEXT="aber ETD als Zwischenstufe ist möglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Objekt -> ETD -> Objekt
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
weil das Quellobjekt keinen Diff erzeugen wird,
|
|
</p>
|
|
<p>
|
|
der sich letztlich nicht auf das Zielobjekt aufspielen läßt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#807bce" DESTINATION="ID_1795458386" ENDARROW="Default" ENDINCLINATION="671;0;" ID="Arrow_ID_1621793396" SOURCE="ID_1767038604" STARTARROW="Default" STARTINCLINATION="994;0;"/>
|
|
</node>
|
|
<node CREATED="1461890240148" ID="ID_755605936" MODIFIED="1561827465535" TEXT="Schutzmechanismen">
|
|
<node CREATED="1461890266377" ID="ID_1129894756" MODIFIED="1461890283701">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
abweisen, was das Kriterium <i>sicher verletzt</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461890289662" ID="ID_708422709" MODIFIED="1461890307247" TEXT="Einfügen eines Feldes, das die Klasse nicht kennt"/>
|
|
<node CREATED="1461891798533" ID="ID_689714781" MODIFIED="1461891807616" TEXT="explizites Umordnen (per seek)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461892011913" HGAP="227" ID="ID_1646969790" MODIFIED="1525124215165" TEXT="Verhaltensmuster" VSHIFT="11">
|
|
<node CREATED="1461892073089" ID="ID_276124788" MODIFIED="1575133333003" TEXT="default vs mandatory">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>mandatory</b> : Wert muß per Konstruktor gegeben sein
|
|
</p>
|
|
<p>
|
|
<b>default</b> : es gibt einen ausgezeichneten Standardwert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1461892285965" ID="ID_649582218" MODIFIED="1533608413911" TEXT="mandatory ">
|
|
<node CREATED="1461892303666" ID="ID_1570612865" MODIFIED="1461892312404" TEXT="Problem der Konstruktor-Repräsentation"/>
|
|
<node CREATED="1461892313049" ID="ID_335222917" MODIFIED="1575133333052" TEXT="einziger Ausweg: komplette ETD-Repräsentation als Wert senden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, in dem ins-Verb ist dann ein komplettes Objekt enthalten,
|
|
</p>
|
|
<p>
|
|
nicht nur eine leere Record-Hülle, die nachfolgend populiert werden kann (aber nicht muß)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461892430466" ID="ID_215866993" MODIFIED="1461892440092" TEXT="ein mandatory-Feld darf nicht gelöscht werden"/>
|
|
</node>
|
|
<node CREATED="1461892444727" ID="ID_1285291323" MODIFIED="1533608413912" TEXT="default">
|
|
<node CREATED="1461892490881" ID="ID_546743858" MODIFIED="1561827465535" TEXT="es gibt zwei Grade">
|
|
<node CREATED="1461892496377" ID="ID_682467781" MODIFIED="1575133333102" TEXT="minder">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konstruktor befüllt das Feld halt irgendwie.
|
|
</p>
|
|
<p>
|
|
Ab dem Punkt verhält es sich aber wie ein normales (mandatory) Feld
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461892554377" ID="ID_1327287438" MODIFIED="1575133333117" TEXT="vollwertig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Objekt selber kann erkennen, ob das Feld sich im "default-Zustand" befindet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461892641949" ID="ID_747303496" MODIFIED="1461892653415" TEXT="Einfügen == vom Default-Wert abweichen"/>
|
|
<node CREATED="1461892654148" ID="ID_1992298354" MODIFIED="1461892662590" TEXT="Löschen == zum Default-Wert zurückkehren"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461966988471" ID="ID_84281476" MODIFIED="1512926192022" TEXT="prüfen vs ignorieren">
|
|
<node CREATED="1461967012164" ID="ID_1394333030" MODIFIED="1533608413912" TEXT="prüfen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1461967015883" ID="ID_659976910" MODIFIED="1461967028022" TEXT="benötigt zusätzliche Mechanismen"/>
|
|
<node CREATED="1461967028489" ID="ID_720327121" MODIFIED="1461967042164" TEXT="verifiziert Validität der Diff-Nachricht"/>
|
|
</node>
|
|
<node CREATED="1461967044480" ID="ID_989829670" MODIFIED="1533608413913" TEXT="ignorieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1461967051095" ID="ID_1280707953" MODIFIED="1461967056946" TEXT="wendet an, was anwendbar ist"/>
|
|
<node CREATED="1461967057462" ID="ID_1792972822" MODIFIED="1461967068248" TEXT="alles andere "durchwinken""/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1461967003141" HGAP="29" ID="ID_590789300" MODIFIED="1533608413916" TEXT="Design-Entscheidung" VSHIFT="19">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1461967143851" ID="ID_1683940966" MODIFIED="1575133333271">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ohne Prüfen ist <b>emptySrc</b> nicht implementierbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil es für <b>emptySrc</b> keine neutrale Antwort gibt.
|
|
</p>
|
|
<p>
|
|
Denn dieses Prädikat wird von der typischen Implementierung des Diff-Applikators
|
|
</p>
|
|
<p>
|
|
in beiden Richtungen verwendet, also sowohl Prüfung auf empty ("expect no further elements"),
|
|
</p>
|
|
<p>
|
|
alsauch der Check, daß überhaupt noch Quellelemente anstehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461967247093" ID="ID_820111448" MODIFIED="1461967294701">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h., man kann nur <i>global auf Prüfung verzichten </i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461967274577" ID="ID_1940471621" MODIFIED="1461967310565">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und da habe ich mich bereits <i><font color="#d3204b">dagegen entschieden</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461967364397" ID="ID_998476299" MODIFIED="1461967379991" TEXT="Prüfung erfordert eine Flag für jedes bekannte Feld"/>
|
|
<node CREATED="1461967384579" ID="ID_602978912" MODIFIED="1461967401644" TEXT="diese Flag wird gesetzt, sobald der Diff das Feld "berührt""/>
|
|
<node CREATED="1461967428061" ID="ID_515874429" MODIFIED="1561827465536" TEXT="außerdem gibt es noch zwei triviale Basis-Checks">
|
|
<node CREATED="1461967451610" ID="ID_1510037111" MODIFIED="1461967462700" TEXT="ist bekannter Attributsname"/>
|
|
<node CREATED="1461967463264" ID="ID_408683865" MODIFIED="1461967487243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Feld unterstützt <b>default</b>-Wert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1475506680125" HGAP="58" ID="ID_1024927289" MODIFIED="1533608413932" TEXT="Variante" VSHIFT="13">
|
|
<node CREATED="1475506691595" ID="ID_1371631530" MODIFIED="1475506704861" TEXT="emptySrc -> hasSrc"/>
|
|
<node CREATED="1475506705641" ID="ID_1680481140" MODIFIED="1475506735169" TEXT="und den nicht implementierbaren Fall tolerieren"/>
|
|
<node CREATED="1475506735949" ID="ID_798651428" MODIFIED="1475506746633" TEXT="im Übrigen: stets prüfen und scheitern">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1475506753523" HGAP="34" ID="ID_1091824657" MODIFIED="1475506765947" TEXT="so umgesetzt" VSHIFT="10">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927276314" HGAP="100" ID="ID_1988815933" MODIFIED="1525124215178" TEXT="Spezifikation" VSHIFT="18">
|
|
<cloud COLOR="#fce9c0"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1461946125744" HGAP="55" ID="ID_803569564" MODIFIED="1512926192031">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Auslegung der
|
|
</p>
|
|
<p>
|
|
<font size="5">Primitiven</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1455927425726" ID="ID_585793339" MODIFIED="1533608413934" TEXT="hasSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928216420" ID="ID_906145373" MODIFIED="1464116966043" TEXT="can not sensibly be implemented">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1464116995888" ID="ID_705527711" MODIFIED="1464117033135" TEXT="always returns true">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1464116967676" ID="ID_289977872" MODIFIED="1464117025435">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
rationale: object fields are hard wired,
|
|
</p>
|
|
<p>
|
|
thus always available
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927425726" ID="ID_1191281077" MODIFIED="1533608413934" TEXT="skipSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="closed"/>
|
|
<node CREATED="1464212421708" ID="ID_151349875" MODIFIED="1464212429644" TEXT="prohibited, raise error"/>
|
|
<node CREATED="1455928216420" ID="ID_1382605808" MODIFIED="1464212390729" TEXT="reset to default">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1461964714068" ID="ID_537168917" MODIFIED="1463690748989" TEXT="mandatory fields raise error">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927396505" ID="ID_1179824183" MODIFIED="1533608413935" TEXT="matchSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455928268589" ID="ID_1175359759" MODIFIED="1461964779839" TEXT="ID comparison to field known by name"/>
|
|
</node>
|
|
<node CREATED="1455982947867" ID="ID_597958919" MODIFIED="1533608413935" TEXT="injectNew">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1455982969073" ID="ID_657399174" MODIFIED="1463675987940" TEXT="set known field's contents"/>
|
|
<node CREATED="1457047512175" ID="ID_1007532661" MODIFIED="1464212464658" TEXT="mandatory fields raise error">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1461964818054" ID="ID_432635855" MODIFIED="1461964825281" TEXT="unknown fields raise error"/>
|
|
</node>
|
|
<node CREATED="1455927413191" ID="ID_515347130" MODIFIED="1533608413935" TEXT="acceptSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1464212476461" ID="ID_934414787" MODIFIED="1464212481606" TEXT="NOP"/>
|
|
<node CREATED="1461964863217" ID="ID_1667143687" MODIFIED="1464212474879" TEXT="mark known field as mentioned">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928166683" ID="ID_440876181" MODIFIED="1533608413938" TEXT="accept_until">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1455928383765" ID="ID_1341082886" MODIFIED="1461965340133" TEXT="nicht implementierbar">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1457231714541" ID="ID_721485398" MODIFIED="1465428399592" TEXT="fraglich: muß vielleicht aus der Sprache entfernt werden">
|
|
<arrowlink COLOR="#592379" DESTINATION="ID_832194713" ENDARROW="Default" ENDINCLINATION="577;0;" ID="Arrow_ID_1785459194" STARTARROW="Default" STARTINCLINATION="1205;231;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1463675830732" ID="ID_1936468017" MODIFIED="1561827465536">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Einschränkung: <b>accept_until END</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1463675866200" ID="ID_836526909" MODIFIED="1575133333756" TEXT="ist implementierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nämlich indem alle Attribute als "berührt" und akzeptiert markiert werden.
|
|
</p>
|
|
<p>
|
|
Somit könnten sofort Zuweisungen als Nächstes passieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463675872239" ID="ID_357902233" MODIFIED="1463675882809" TEXT="ist sehr sinnvoll"/>
|
|
<node CREATED="1463675883853" ID="ID_1598959525" MODIFIED="1464212598924" TEXT="könnte sogar Standardfall sein">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1464212588886" ID="ID_1794610293" MODIFIED="1464212594754" TEXT="ist effektiv NOP">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455927413191" ID="ID_15287291" MODIFIED="1533608413939" TEXT="findSrc">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="closed"/>
|
|
<node CREATED="1461946965569" ID="ID_641654199" MODIFIED="1461963646230" TEXT="Umordnen wird nicht unterstützt"/>
|
|
<node CREATED="1461963648481" ID="ID_424736619" MODIFIED="1461963654996" TEXT="löst einen Logik-Fehler aus"/>
|
|
</node>
|
|
<node CREATED="1455928184504" ID="ID_7150585" MODIFIED="1533608413940" TEXT="assignElm">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1461963697714" ID="ID_1611504203" MODIFIED="1461963707499" TEXT="Setter aufrufen"/>
|
|
<node CREATED="1461963686556" ID="ID_1024151478" MODIFIED="1461963697214" TEXT="namentlich bekanntes Feld"/>
|
|
<node CREATED="1461963708449" ID="ID_1297402022" MODIFIED="1461963718804" TEXT="nicht bekannte Felder lösen Fehler aus"/>
|
|
</node>
|
|
<node CREATED="1455928189695" ID="ID_802620360" MODIFIED="1533608413941" TEXT="mutateChild">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1461963754651" ID="ID_74917900" MODIFIED="1461963776115">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
analog wie <b>assignElm</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461963748604" ID="ID_15098291" MODIFIED="1461963753895" TEXT="namentlich bekanntes Feld"/>
|
|
<node CREATED="1461963777440" ID="ID_1640944406" MODIFIED="1461963787443" TEXT="aber nicht Setter, sondern Mutator bauen"/>
|
|
</node>
|
|
<node CREATED="1464113688645" ID="ID_1176289974" MODIFIED="1533608413942" STYLE="fork" TEXT="completeScope">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1464113727192" ID="ID_1067616469" MODIFIED="1464113954773" TEXT="hier NOP implementiert"/>
|
|
<node CREATED="1464113740005" ID="ID_142294253" MODIFIED="1464114004153">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, es findet <b>keine Verifikation</b> statt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1455928193863" ID="ID_623558191" MODIFIED="1533608413943" TEXT="CTOR">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1461946885292" ID="ID_1815209308" MODIFIED="1461965407132" TEXT="mark all known fields as not yet mentioned"/>
|
|
<node COLOR="#e5500c" CREATED="1461946693701" ID="ID_1970580003" MODIFIED="1461965425322" STYLE="fork" TEXT="meta-Operation">
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461946112906" HGAP="14" ID="ID_1014423358" MODIFIED="1512926192037" VSHIFT="21">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zu bindende
|
|
</p>
|
|
<p>
|
|
<font size="4">Operationen</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1458175991795" ID="ID_1060725077" MODIFIED="1533608413943" TEXT="fest eingebaut...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458175942866" ID="ID_243703127" MODIFIED="1561827465536" TEXT="match">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177113846" ID="ID_1805676364" MODIFIED="1461966728693" TEXT="prüft ID-Name der Spec gegen Feldname des Zieles"/>
|
|
</node>
|
|
<node CREATED="1458176002762" ID="ID_1807951993" MODIFIED="1561827465537" TEXT="selector">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177605869" ID="ID_1366865034" MODIFIED="1461966119517" TEXT="ein default-Selector ist automatisch stets konfiguriert"/>
|
|
<node CREATED="1461966120082" ID="ID_1815206712" MODIFIED="1461966665670" TEXT="default ist Prüfen, ob die Spec ein Attribut bezeichnet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175991795" ID="ID_568449972" MODIFIED="1533608413946" TEXT="optional...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458176008025" ID="ID_1898233888" MODIFIED="1561827465537" TEXT="setter">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177697657" ID="ID_1919536488" MODIFIED="1458177953095" TEXT="erlaubt Zuweisung"/>
|
|
<node CREATED="1458177712798" ID="ID_711029038" MODIFIED="1458177953095" TEXT="setzt Auswahl per match voraus"/>
|
|
<node CREATED="1458177735635" FOLDED="true" ID="ID_965106517" MODIFIED="1561827483835" TEXT="Ersatz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1458177738499" ID="ID_1141876143" MODIFIED="1458177953095" TEXT="keiner"/>
|
|
<node CREATED="1458177741155" ID="ID_512515009" MODIFIED="1458177953095" TEXT="dann gibt's eben keine Zuweisung"/>
|
|
<node CREATED="1458177749233" ID="ID_709608820" MODIFIED="1458177953095" TEXT="auch nicht nötig bei sub-Scopes"/>
|
|
<node CREATED="1458177803730" ID="ID_176238190" MODIFIED="1458177953095" TEXT="auch nicht nötig bei immutable values"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176018087" ID="ID_1939286828" MODIFIED="1561827465538" TEXT="mutator">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1458177821712" ID="ID_776830345" MODIFIED="1458177953095" TEXT="baut einen sub-Mutator für einen nested scope"/>
|
|
<node CREATED="1458177851988" ID="ID_726523372" MODIFIED="1458177953095" TEXT="setzt Auswahl per match voraus"/>
|
|
<node CREATED="1458177857939" FOLDED="true" ID="ID_556346121" MODIFIED="1561827483835" TEXT="Ersatz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1458177861162" ID="ID_889666207" MODIFIED="1458177953095" TEXT="keiner"/>
|
|
<node CREATED="1458177863506" ID="ID_99047676" MODIFIED="1463690716478" TEXT="dann gibts eben keine Behandlung von nested scopes"/>
|
|
<node CREATED="1458177874760" ID="ID_947844223" MODIFIED="1458177953095" TEXT="auch nicht nötig bei primitive values"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463687547746" ID="ID_1901457184" MODIFIED="1561827465539" TEXT="defaulter">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1463687553569" ID="ID_9295162" MODIFIED="1463687602782" TEXT="veranlaßt Rückkehr zum default-Zustand"/>
|
|
<node CREATED="1463687629319" ID="ID_143858987" MODIFIED="1463687644409" TEXT="erfordert explizite Unterstützung durch das Zielobjekt"/>
|
|
<node CREATED="1463687644973" ID="ID_1450965693" MODIFIED="1575133334303" TEXT="fragwürdig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sieht nach Ober-engineering aus,
|
|
</p>
|
|
<p>
|
|
zumal das erhebliche Statefulness bewirkt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1463687649812" FOLDED="true" ID="ID_223867304" MODIFIED="1561827483836" TEXT="Ersatz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1463687668218" ID="ID_1355941236" MODIFIED="1463687670469" TEXT="keiner"/>
|
|
<node CREATED="1463687672649" ID="ID_1680005619" MODIFIED="1463687689779" TEXT="dann kann eben nur gebunden werden"/>
|
|
<node CREATED="1463687865175" ID="ID_462333966" MODIFIED="1463687869987" TEXT="normalerweise verzichtbar"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458175960615" ID="ID_324885" MODIFIED="1561827465540" TEXT="ctor">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1461966391478" ID="ID_235916217" MODIFIED="1461966404134" TEXT="wird dem Setter vorgeschaltet"/>
|
|
<node CREATED="1458177315803" ID="ID_1514272147" MODIFIED="1458177953094" TEXT="konstruiert aus der Spec ein neues Element"/>
|
|
<node CREATED="1461966815950" ID="ID_382468761" MODIFIED="1461966831208" TEXT="notwendig bei Attribut-Werten, die tatsächlich Objekte sind"/>
|
|
<node CREATED="1458177335632" ID="ID_1162845397" MODIFIED="1458177953094" TEXT="muß typischerweise die Interna des Zieles kennen"/>
|
|
<node CREATED="1458177347622" FOLDED="true" ID="ID_751382358" MODIFIED="1561827483836" TEXT="Ersatz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1458177489444" ID="ID_1075338030" MODIFIED="1461966901007">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unterstelle Ziel als <i>konstruierbar</i> aus Payload
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463691200369" ID="ID_424486867" MODIFIED="1575133334436" TEXT="überflüssiges Konzept">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da effektiv bereits der Setter diese Funktionalität enthalten kann und muß,
|
|
</p>
|
|
<p>
|
|
denn der Setter nimmt eine GenNode
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458176048564" HGAP="-11" ID="ID_1832020270" MODIFIED="1512926192045" TEXT="Variationen" VSHIFT="4">
|
|
<node CREATED="1464117242535" ID="ID_1516044777" MODIFIED="1512926192045" TEXT="Binden auf eine klassische struct">
|
|
<node CREATED="1464117391859" ID="ID_1067159129" MODIFIED="1464117396430" TEXT="Setter weisen einfach zu"/>
|
|
<node CREATED="1464117397026" ID="ID_2633866" MODIFIED="1464117404773" TEXT="bereits die Neuanlage muß alles populieren"/>
|
|
</node>
|
|
<node CREATED="1464117250262" ID="ID_1940768897" MODIFIED="1512926192046" TEXT="Binden auf ein Objekt mit Initialisierungs-Semantik">
|
|
<node CREATED="1464117412896" ID="ID_203383408" MODIFIED="1464117450662" TEXT="Erzeugungs-Diff muß mit den Anforderungen des Konstruktors harmonieren"/>
|
|
<node CREATED="1464117487974" ID="ID_1233071043" MODIFIED="1464117499776" TEXT="Rückkehr zum Default wird nicht unterstützt / abgebildet"/>
|
|
</node>
|
|
<node CREATED="1464117317517" ID="ID_680707594" MODIFIED="1512926192046" TEXT="Binden auf "konzeptionelle" Properties">
|
|
<node CREATED="1464117513722" ID="ID_272177291" MODIFIED="1464117537611" TEXT="der "Key" ist nur eine ID, um speziellen Zugriffsmechanismus auszulösen"/>
|
|
<node CREATED="1464117553885" ID="ID_116286814" MODIFIED="1464117567271" TEXT="u.U ist man überhaupt nur an sub-Mutation interessiert"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458178113697" FOLDED="true" HGAP="61" ID="ID_1703314461" MODIFIED="1576203843959" TEXT="Design-Schlußfolgerungen" VSHIFT="48">
|
|
<node CREATED="1463687362843" HGAP="116" ID="ID_500584513" MODIFIED="1561827465553" TEXT="Eingrenzung" VSHIFT="-28">
|
|
<node CREATED="1463687373889" ID="ID_90253723" MODIFIED="1512926192049" TEXT="Art von Attributen">
|
|
<node CREATED="1463687402462" ID="ID_1494575064" MODIFIED="1533608413953" TEXT="Objekt-Feld">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1463689795357" ID="ID_75375725" MODIFIED="1463689801592" TEXT="kann nur zugewiesen werden"/>
|
|
<node CREATED="1463689912853" ID="ID_18475641" MODIFIED="1561827465554">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>injectNew</b> tolerieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1463690238314" ID="ID_644067355" MODIFIED="1575133334661" TEXT="eigentlich redundant">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....man könnte genausogut auch beim ersten Mal zuweisen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463690487032" ID="ID_348837680" MODIFIED="1575133334684" TEXT="Aber: isomorph zu GenNode">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn die Diff-Anwendung auf GenNode unterstützt Zuweisung
|
|
</p>
|
|
<p>
|
|
ausschließlich bei schon existierenden Elementen. Demnach muß dort auch jedes Attribut
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
entweder schon mit dem Konstruktor mit gegeben worden sein
|
|
</li>
|
|
<li>
|
|
oder vorher einmal explizit eingefügt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463687408597" ID="ID_1363008589" MODIFIED="1533608413954" TEXT="optional Property">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1463688083594" ID="ID_11895941" MODIFIED="1463688087910" TEXT="fragwürdiger Nutzen"/>
|
|
<node CREATED="1463688088457" ID="ID_406507446" MODIFIED="1463688100116" TEXT="mutet "theoretisch" an"/>
|
|
<node CREATED="1463688147802" ID="ID_490338350" MODIFIED="1561827465554" TEXT="Alternative">
|
|
<node CREATED="1463688157472" ID="ID_489631928" MODIFIED="1463688173746" TEXT="auf "mindere defaults" setzen"/>
|
|
<node CREATED="1463688215752" ID="ID_1086442520" MODIFIED="1463688230896" TEXT="kann man einfach mitlaufen lassen"/>
|
|
<node CREATED="1463688184269" ID="ID_60958115" MODIFIED="1463688193863" TEXT="immer mögliche Degradierung des Konzepts"/>
|
|
<node CREATED="1463688232550" FOLDED="true" ID="ID_1915653142" MODIFIED="1561827483836" TEXT="fehlende Funktionalität ersetzbar">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1463688247980" ID="ID_105443751" MODIFIED="1463688253639" TEXT="durch komplettes Neukonstruieren"/>
|
|
<node CREATED="1463688254251" ID="ID_1822426402" MODIFIED="1463688262902" TEXT="durch eine explizite Reset-Methode"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463687451791" ID="ID_1708498507" MODIFIED="1533608413956" TEXT="Attribut-Map">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1463687461925" ID="ID_1513625124" MODIFIED="1463687496231" TEXT="hier ausgeschlossen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1475506967550" ID="ID_1994979880" MODIFIED="1576203653282" TEXT="kann auf Basis des Collection-Binding emuliert werden">
|
|
<arrowlink COLOR="#9f96d9" DESTINATION="ID_453712930" ENDARROW="Default" ENDINCLINATION="478;123;" ID="Arrow_ID_1448345273" STARTARROW="None" STARTINCLINATION="479;26;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1463687484338" FOLDED="true" ID="ID_1430772851" MODIFIED="1576201413269" TEXT="könnte für GenNode relevant sein">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1576201374385" ID="ID_1783873229" MODIFIED="1576201388980" TEXT="nein war nicht notwendig"/>
|
|
<node CREATED="1576201389839" ID="ID_367063389" MODIFIED="1576201411474" TEXT="hab dort direkt mit zwei Collections gearbeitet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und die Keys der Attribute stecken in der GenNode selber!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576201416347" ID="ID_311569009" MODIFIED="1576201424054" TEXT="könnte nützlich sein für Tests">
|
|
<node CREATED="1576201427058" ID="ID_1739941135" MODIFIED="1576204086360" TEXT="MockElm">
|
|
<arrowlink COLOR="#9f719e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="170;-624;" ID="Arrow_ID_23523127" STARTARROW="None" STARTINCLINATION="875;242;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463691267608" ID="ID_659149145" MODIFIED="1512926192052" TEXT="Typisierung">
|
|
<node CREATED="1463691273431" ID="ID_366034077" MODIFIED="1463691276947" TEXT="pro Attribut"/>
|
|
<node CREATED="1463691277726" ID="ID_143796822" MODIFIED="1533608413957" TEXT="implizit">
|
|
<node CREATED="1463691290845" ID="ID_1709842697" MODIFIED="1464226408020" TEXT="das Setter-lambda nimmt einen Wert"/>
|
|
<node CREATED="1464226412567" ID="ID_98271808" MODIFIED="1561827465555" TEXT="der Wert-Typ muß einer der GenNode-Payload-Typen sein">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1464227158027" ID="ID_1268661637" MODIFIED="1464227176058" TEXT="TODO: dies zur compile-Zeit prüfen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463691359988" ID="ID_1757946882" MODIFIED="1464226506135" TEXT="der Setter muß jedwede weitere Konvertierung in andere Typen selber machen"/>
|
|
<node CREATED="1464226461041" ID="ID_17502992" MODIFIED="1464226487843" TEXT="die Implementierung greift auf den passenden GenNode-Payload zu"/>
|
|
<node CREATED="1463691372258" ID="ID_1258654359" MODIFIED="1463691550094" TEXT="alle Typkonvertierungs-Fragen auf client abgewälzt"/>
|
|
<node CREATED="1463691552514" ID="ID_1080486847" MODIFIED="1575133334971" TEXT="das ist gut so">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir vermeiden dadurch Komplexität.
|
|
</p>
|
|
<p>
|
|
Der gesendete Diff muß einfach passen!
|
|
</p>
|
|
<p>
|
|
Genau deshalb haben wir auch in GenNode verschiedene Varianten des gleichen Grundtyps,
|
|
</p>
|
|
<p>
|
|
damit wir nicht in die ganzen Ungewissheiten der widening conversions laufen!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463691680849" ID="ID_694873075" MODIFIED="1512926192054" TEXT="Striktheit">
|
|
<node CREATED="1463691716821" ID="ID_533693199" MODIFIED="1463691724243" TEXT="soweit einfach zu gewährleisten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1463691725515" ID="ID_1992867150" MODIFIED="1463691741484" TEXT="d.h. soweit nicht zusätzlicher State notwendig ist"/>
|
|
<node CREATED="1463691767421" ID="ID_245127286" MODIFIED="1463691780901" TEXT="Flexibilität muß stets praktisch gerechtfertigt sein">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463691793010" ID="ID_1913675552" MODIFIED="1512926192056" TEXT="Fälle">
|
|
<node CREATED="1463691796825" ID="ID_826581062" MODIFIED="1575133335055" TEXT="Setter">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. der Attributwert hat Wertsemantik und wird einfach zugewiesen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463691804696" ID="ID_1828509710" MODIFIED="1575133335070" TEXT="Mutator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. der Attributwert ist ein Objekt und damit ein nested Scope
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463691807824" ID="ID_1263942224" MODIFIED="1463691814860" TEXT="keine Mischformen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1463692054415" ID="ID_41980996" MODIFIED="1533608413958">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: <i>immutable values</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1463692505987" ID="ID_391357034" MODIFIED="1463692515040" TEXT="wirklich ein Problem?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1463692519993" ID="ID_909159783" MODIFIED="1463692550512" TEXT="Diff handelt ohnehin nur von veränderbaren Dingen"/>
|
|
<node CREATED="1463692663853" ID="ID_721907669" MODIFIED="1561827465555" TEXT="Aber: wie ändert man die Länge eins Clips im UI?">
|
|
<node CREATED="1463695438538" ID="ID_1254169267" MODIFIED="1463695450620" TEXT="indem man sich auf ein Präsentations-Grid bezieht"/>
|
|
<node CREATED="1463695454504" ID="ID_1309064983" MODIFIED="1463695469602" TEXT="und folglich nur Grid-Punkt-Koordinaten ändert"/>
|
|
<node CREATED="1463695472134" ID="ID_887292467" MODIFIED="1463695494714" TEXT="die eigentlichen Time-Entitäten leben in der Session, nicht im UI">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463695573392" ID="ID_160957596" MODIFIED="1561827465556" TEXT="im Übrigen: Problem des client-Codes">
|
|
<node CREATED="1463695588814" ID="ID_584993993" MODIFIED="1463695605096" TEXT="man kann einen time::Mutator erzeugen"/>
|
|
<node CREATED="1463695605708" ID="ID_1510075145" MODIFIED="1463695620401" TEXT="es gibt vorgefertigte EmbeddedMutators">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1463695633144" ID="ID_967555989" MODIFIED="1463695657196">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das alles passiert dann <i>im</i> Lambda
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463695640231" ID="ID_102452255" MODIFIED="1463695645090" TEXT="und ist somit nicht unser Problem"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463849505993" HGAP="42" ID="ID_1449079591" MODIFIED="1533608413963" VSHIFT="25">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dilemma: <i>defaultable fields</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1463849536789" ID="ID_1111494683" MODIFIED="1561827465556" TEXT="ich möchte sie unterstützen">
|
|
<node CREATED="1463849545196" ID="ID_1803662045" MODIFIED="1463849547316" TEXT="warum">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463849556474" ID="ID_1880489788" MODIFIED="1575133335311" TEXT="Unterstützung muß konsistent sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....mit der ETD,
|
|
</p>
|
|
<p>
|
|
bzw der Anwendung des selben Diffs auf eine GenNode-Struktur.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Konsequenz: wenn ein feld <i>defaulted</i> war, und nun explizit gesetzt wird,
|
|
</p>
|
|
<p>
|
|
muß dies als INS geschehen, denn eine Zuweisung an nicht aufgeführtes Element ist verboten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463849716869" ID="ID_178223886" MODIFIED="1463849742347" TEXT="in der Bindung auf ein Objekt habe ich aber keine Attribut-Menge">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1463849761127" ID="ID_360434579" MODIFIED="1463849778956">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
folglich ein Problem,
|
|
</p>
|
|
<p>
|
|
zu erkennen, wenn wir fertig sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1463849986345" ID="ID_1998073123" MODIFIED="1561827465557" TEXT="genauer...">
|
|
<node CREATED="1463850017285" ID="ID_550997337" MODIFIED="1463850033879" TEXT="wenn ein feld zwar gebunden ist"/>
|
|
<node CREATED="1463850034699" ID="ID_1498215556" MODIFIED="1463850053756" TEXT="aber bisher keinen Wert bekommen hat"/>
|
|
<node CREATED="1463850060359" ID="ID_1911362794" MODIFIED="1463850081800" TEXT="dann darf der Diff es auch nicht per pick aufführen"/>
|
|
<node CREATED="1463850086044" ID="ID_709383845" MODIFIED="1463850099574" TEXT="wenn dann alle mandatory fields behandelt sind"/>
|
|
<node CREATED="1463850100634" ID="ID_1773433984" MODIFIED="1575133335440" TEXT="glauben wir, wir sind noch nicht fertig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....weil das defaultable field noch nicht vom Diff berührt wurde.
|
|
</p>
|
|
<p>
|
|
Aber es ist kein optional field, d.h. wir haben keine Flag, die es als "defaulted" kennzeichnet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463850138853" ID="ID_679588836" MODIFIED="1561827465558" TEXT="also ist das Grundproblem">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1463850144180" ID="ID_1873291301" MODIFIED="1463850157454" TEXT="daß der TreeMutator global stateless ist"/>
|
|
<node CREATED="1463850163257" ID="ID_824612635" MODIFIED="1463850171716" TEXT="denn er wird immer wieder neu konstruiert"/>
|
|
<node CREATED="1463850280082" ID="ID_947931218" MODIFIED="1463850294324">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösung: <b>alles immer explizit</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463934907474" ID="ID_813075700" MODIFIED="1561827465559" TEXT="Auswege">
|
|
<node CREATED="1463934969522" FOLDED="true" ID="ID_1350271693" MODIFIED="1561827483836" TEXT="keine optional fields">
|
|
<node COLOR="#a0345c" CREATED="1463937048979" ID="ID_897669733" MODIFIED="1463937120794" TEXT="widerspricht den Anforderungen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463935105351" FOLDED="true" ID="ID_452667918" MODIFIED="1561827483836" TEXT="Protokoll-Auflagen">
|
|
<node CREATED="1463935116670" ID="ID_446798186" MODIFIED="1463935125304" TEXT="nach dem ersten Durchgang muß alles gebunden sein"/>
|
|
<node CREATED="1463935126461" ID="ID_1872628226" MODIFIED="1463935247552" TEXT="wenn ungebundene optionals, stets Abschließen mit "after END""/>
|
|
<node COLOR="#a0345c" CREATED="1463937146214" ID="ID_235743901" MODIFIED="1463937452255" TEXT="attraktiv, aber unehrlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
diese Lösung war zunächst mein Favorit.
|
|
</p>
|
|
<p>
|
|
Sie erscheint sehr elegant, weil man im TreeMutator <i>überhaupt nichts</i> dafür tun muß.
|
|
</p>
|
|
<p>
|
|
Und die Zusatz-Forderung, daß dann eben das Diff richtig gesendet werden muß,
|
|
</p>
|
|
<p>
|
|
erscheint "geschenkt", da wir ohnehin zunächst einmal die Diffs explizit im Code erzeugen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Aber, nach längerer Überlegung wurde mir der Ansatz mehr und mehr zweifelhaft.
|
|
</p>
|
|
<p>
|
|
Das ist die Art von Verkoppelungen, hier die implizite Annahme einer bestimmten Implementierung,
|
|
</p>
|
|
<p>
|
|
die ein System unerklärbar und schwer wartbar machen. Das ist die Art von "Features",
|
|
</p>
|
|
<p>
|
|
für die man sich nach einiger Zeit entschuldigen muß.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und noch schlimmer: eigentlich läuft dieser Ansatz darauf hinaus, die Konsistenzprüfung
|
|
</p>
|
|
<p>
|
|
am Ende zu deaktivieren. Nur wir machen das nicht explizit, sondern durch die Hintertür.
|
|
</p>
|
|
<p>
|
|
Also dann besser klar und ehrlich!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463934995110" FOLDED="true" ID="ID_1861082499" MODIFIED="1561827483836" TEXT="dem Mutator sagen, was optional ist">
|
|
<node CREATED="1463935368308" ID="ID_246550021" MODIFIED="1463935375919" TEXT="was grundsätzlich optional sein kann"/>
|
|
<node CREATED="1463935377123" ID="ID_965278928" MODIFIED="1463935387005" TEXT="was aktuell nicht gebunden ist"/>
|
|
<node COLOR="#a0345c" CREATED="1463937178689" ID="ID_1202653468" MODIFIED="1463937550363" TEXT="Over-Engineering / Lösung eines nicht vorhandenen Problems">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn unter dem Strich würden wir hiermit volle Unterstützung für opitonale Attribute einführen,
|
|
</p>
|
|
<p>
|
|
also eine Attribut-Semantik auf eine Feld-Semantik draufpflanzen.
|
|
</p>
|
|
<p>
|
|
Aber in der vorausgegangenen Analyse habe ich mich schon davon überzeugt,
|
|
</p>
|
|
<p>
|
|
daß wir keine Attribut-Semantik brauchen. Und wenn doch, dann bietet das Diff-System
|
|
</p>
|
|
<p>
|
|
immer noch die Möglichkeit, die Attribute explizit als Sammlung darzustellen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1463935030953" ID="ID_1231044846" MODIFIED="1463938073583">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf die <i>empty</i>-Prüfung am Ende verzichten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#f36478" DESTINATION="ID_644127921" ENDARROW="Default" ENDINCLINATION="181;0;" ID="Arrow_ID_1868541511" STARTARROW="None" STARTINCLINATION="181;0;"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1463937883299" HGAP="85" ID="ID_8371094" MODIFIED="1533608413968" TEXT="Konsequenzen" VSHIFT="26">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1463937922318" ID="ID_795883612" MODIFIED="1561827465561" TEXT="isEmpty">
|
|
<node CREATED="1463937972255" ID="ID_644127921" MODIFIED="1575133335596" TEXT="muß umdefiniert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn in den meisten, wichtigsten Fällen get es um einen non-empty-check,
|
|
</p>
|
|
<p>
|
|
bevor ein anderes Verifikations-Prädikat angewendet wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#f36478" DESTINATION="ID_644127921" ENDARROW="Default" ENDINCLINATION="181;0;" ID="Arrow_ID_1868541511" SOURCE="ID_1231044846" STARTARROW="None" STARTINCLINATION="181;0;"/>
|
|
</node>
|
|
<node CREATED="1463937980222" ID="ID_932494564" MODIFIED="1463937986216" TEXT="kann nicht mehr negativ geprüft werden"/>
|
|
<node CREATED="1463937988180" ID="ID_653804102" MODIFIED="1463938000454" TEXT="das gilt leider für alle Bindings"/>
|
|
<node CREATED="1464212233893" ID="ID_823232649" MODIFIED="1464212254420" TEXT="umdrehen in: hasSrc">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1463938033527" FOLDED="true" ID="ID_697212736" MODIFIED="1561827483836" TEXT="neue Primitive: completeScope">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1464113590258" ID="ID_1258294190" MODIFIED="1464113600260" TEXT="auch ein hook für Aufräum-Arbeiten"/>
|
|
<node CREATED="1464113600897" ID="ID_671689357" MODIFIED="1464113642335" TEXT="return true -- wenn alles sauber ist"/>
|
|
<node CREATED="1464113642899" ID="ID_1915175788" MODIFIED="1464113648966" TEXT="kann NOP implementiert werden"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464114047781" ID="ID_1325307049" MODIFIED="1561827465561" TEXT="reduzierte Verifikation">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1464114078672" ID="ID_1492664671" MODIFIED="1464114085171" TEXT="nicht bekannte Felder werden erkannt"/>
|
|
<node CREATED="1464114086111" ID="ID_592980670" MODIFIED="1464114139188" TEXT="der Versuch von Umordnungen wird erkannt"/>
|
|
<node COLOR="#990000" CREATED="1464114156574" ID="ID_270104965" MODIFIED="1464114190655" TEXT="fehlende Angaben werden nicht bemerkt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461897111747" HGAP="79" ID="ID_802377541" MODIFIED="1512926192064" TEXT="Ein Attribut oder viele Attribute" VSHIFT="17">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1463696053440" ID="ID_1754643119" MODIFIED="1464226693401" TEXT="Standardfall: eine kleine Zahl von Attributen ">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1463696031715" ID="ID_1260056252" MODIFIED="1464226781810" TEXT=""ein Attribut" ist aber der natürliche Basisfall für die Implementierung"/>
|
|
<node CREATED="1463695809296" ID="ID_1828617017" MODIFIED="1464226736308" TEXT="problematisch sind Selektor und (ignorierte) Reihenfolge">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464226806914" HGAP="25" ID="ID_1600614692" MODIFIED="1512926192065" TEXT="Selector" VSHIFT="5">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1464226813953" ID="ID_489744078" MODIFIED="1464226834307" TEXT="fest verdrahtet: istAttribut"/>
|
|
<node CREATED="1464226834831" ID="ID_1398159123" MODIFIED="1464226848617" TEXT="Verzicht auf einen konfigurierbaren Selector"/>
|
|
<node CREATED="1464226849277" ID="ID_1083142087" MODIFIED="1464226870862" TEXT="im Zweifelsfall: anderen »onion-Layer« verwenden"/>
|
|
<node CREATED="1464226871930" ID="ID_1656706742" MODIFIED="1464226897116" TEXT="gut zur Reduktion der Komplexität">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1461894614295" ID="ID_665631895" MODIFIED="1512926192065" TEXT="Attribut-Glieder">
|
|
<node CREATED="1461894619054" ID="ID_1204916244" MODIFIED="1512926192066" TEXT="implementieren die API-Primitive">
|
|
<node CREATED="1461894676063" ID="ID_1957652861" MODIFIED="1461894678714" TEXT="durch Aktion"/>
|
|
<node CREATED="1461894679190" ID="ID_1193521445" MODIFIED="1461894683857" TEXT="durch Ignorieren"/>
|
|
<node CREATED="1461894684326" ID="ID_182706257" MODIFIED="1461894692888" TEXT="als Fehler"/>
|
|
</node>
|
|
<node CREATED="1461894634029" ID="ID_634211646" MODIFIED="1464226938524" TEXT="fügen sich natürlich durch Layering zusammen"/>
|
|
<node CREATED="1461894666248" ID="ID_1466917621" MODIFIED="1464226987286" TEXT="Setter / Mutator durch Template-Spezialisierung"/>
|
|
<node CREATED="1464226992090" ID="ID_567861080" MODIFIED="1512926192066" TEXT="lineare Suche">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1464227021205" ID="ID_1227031045" MODIFIED="1464227032960" TEXT="akzeptabel für < 30 Attribute"/>
|
|
<node CREATED="1464227042771" ID="ID_581148359" MODIFIED="1575133335969" TEXT="vermeidet heap-basierte Collection">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
jedwede "bessere" Implementierung muß zwingend einen Container verwenden,
|
|
</p>
|
|
<p>
|
|
der dann die Lambdas für die einzelnen Setter auf den Heap legt.
|
|
</p>
|
|
<p>
|
|
Das ist hier tatsächlich viel schlechter, als das bischen lineare Suche
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1464227213180" FOLDED="true" HGAP="29" ID="ID_1322038165" MODIFIED="1576200469487" TEXT="Implementierung" VSHIFT="66">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1464227218795" ID="ID_240211297" MODIFIED="1575133336008" TEXT="ist grundsätzlich "schon da"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....durch meinen allerersten Draft,
|
|
</p>
|
|
<p>
|
|
für den ich damals gezwungen war, die GenNode zu erfinden :)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1464227273572" ID="ID_641114043" MODIFIED="1465428151809" TEXT="TODO: alten Testfall anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1464227285562" ID="ID_1467378259" MODIFIED="1465428159480" TEXT="TODO: Setter aus erstem Entwurf vom TreeMutator-API entfernen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464227227610" ID="ID_1283798929" MODIFIED="1464227235981" TEXT="aber: alle Primitive durchimplementieren"/>
|
|
<node COLOR="#338800" CREATED="1464386998240" ID="ID_145703376" MODIFIED="1512926192069" TEXT="key: EntryID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1464396284551" ID="ID_1820812766" MODIFIED="1512926192069" TEXT="Problem: sanitise">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1464396756424" ID="ID_292993552" MODIFIED="1464397132659" TEXT="nur US-ASCII">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1464396761967" ID="ID_1853390961" MODIFIED="1464397146966" TEXT="erweiterte Zeichen bedingen Locale">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1464396769974" ID="ID_1765409740" MODIFIED="1533608413970" TEXT="und welche dann??">
|
|
<node CREATED="1464396835581" ID="ID_880270228" MODIFIED="1464396859658" TEXT="System-Locale: Recipe for Desaster"/>
|
|
<node CREATED="1464396793123" ID="ID_84577480" MODIFIED="1464396815972" TEXT="en_US.UTF-8"/>
|
|
<node CREATED="1464396816696" ID="ID_1549234272" MODIFIED="1464396866584" TEXT="Einschränkung nicht sinnvoll zu begründen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464396320922" ID="ID_557201534" MODIFIED="1512926192070" TEXT="GenNode umgeht das (bewußt)">
|
|
<node CREATED="1464396885391" ID="ID_1826102565" MODIFIED="1464397164031" TEXT="Begründung: interne Schnittstelle">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1464396899252" ID="ID_238800946" MODIFIED="1464396964843" TEXT="verwendet bereits valide Symbole">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1464396908371" ID="ID_714542679" MODIFIED="1464397170109" TEXT="vermeidet den Performance overhead">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464397008078" ID="ID_1318792158" MODIFIED="1464397019505" TEXT="soll sich symmetrisch verhalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1464397020996" ID="ID_1539077842" MODIFIED="1512926192070" TEXT="Lösung: Variante für EntryID">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1464397032747" ID="ID_52447284" MODIFIED="1575133336250" TEXT="für interne Schnittstellen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gleiches Argument...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1464397039834" ID="ID_842182814" MODIFIED="1575133336266" TEXT="verwendet Symbol-Datentyp">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit unterstellen wir, daß später eine Symbol-Tabelle aufgebaut wird.
|
|
</p>
|
|
<p>
|
|
Dann kann man sich immer noch überlegen, ob man dann <i>an dieser Stelle</i> bereinigt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464387004423" ID="ID_1665317497" MODIFIED="1512926192071" TEXT="Fehlerbehandlung">
|
|
<node CREATED="1464387034539" ID="ID_368572405" MODIFIED="1512926192071" TEXT="injectNew">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1464387043146" ID="ID_1626945131" MODIFIED="1465045655821" TEXT="API erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1464387046769" ID="ID_572522334" MODIFIED="1465045658691" TEXT="Rückgabewert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1464387055632" ID="ID_1950008212" MODIFIED="1465045661504" TEXT="andere Layer fragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464387071669" ID="ID_1015524397" MODIFIED="1512926192072" TEXT="skip">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1464387092091" ID="ID_1520028053" MODIFIED="1464387095959" TEXT="hat kein Argument"/>
|
|
<node CREATED="1464387096498" ID="ID_1251857254" MODIFIED="1464387158085" TEXT="kann daher Selektor nicht ausführen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1464387102850" ID="ID_1482608502" MODIFIED="1464387148396" TEXT="Fehlererkennung nicht möglich">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464386771270" ID="ID_166516904" MODIFIED="1512926192072" TEXT="setter vs mutator">
|
|
<node CREATED="1464386870265" ID="ID_1508130332" MODIFIED="1464387168773" TEXT="Metaprogrammierung"/>
|
|
<node CREATED="1464386878983" ID="ID_1309713526" MODIFIED="1464386887354" TEXT="Code selber muß es implizit wissen"/>
|
|
<node CREATED="1464386904676" ID="ID_1123923779" MODIFIED="1512926192073" TEXT="entweder-oder">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1464386910099" ID="ID_1644956745" MODIFIED="1464386913750" TEXT="nicht notwendig"/>
|
|
<node CREATED="1464386929745" ID="ID_1569654621" MODIFIED="1464386936708" TEXT="es greift der Layer, der es kann"/>
|
|
</node>
|
|
<node CREATED="1464483482949" HGAP="32" ID="ID_1655303588" MODIFIED="1512926192073" TEXT="Code-Struktur" VSHIFT="15">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1464483497524" ID="ID_1510305109" MODIFIED="1464483503639" TEXT="Basisklasse + Overlay"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1464483504155" ID="ID_1310567997" MODIFIED="1533608413971" TEXT="unschön und verwirrend">
|
|
<node CREATED="1464483533863" ID="ID_1330926314" MODIFIED="1464483617082" TEXT="mehrfach geschachtelte Typdefinitionen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1464483544429" ID="ID_1556868157" MODIFIED="1575133336535" TEXT="Problem mit der EntryID">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in einem Fall kann man sie aus der Closure abgreifen
|
|
</p>
|
|
<p>
|
|
im anderen Fall muß es doch der Client leisten.
|
|
</p>
|
|
<p>
|
|
Keine klare Linie
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1464483601318" ID="ID_244819234" MODIFIED="1464483610226" TEXT="gibt es überhaupt eine Alternative">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1465041597680" ID="ID_379389753" MODIFIED="1561827465568" TEXT="Abwägung">
|
|
<node CREATED="1465040677452" ID="ID_1570943594" MODIFIED="1575133336577" TEXT="OK: Klassen sind geschnitten nach Belang">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, es gibt nur minimale, themantische Überlappung.
|
|
</p>
|
|
<p>
|
|
Also ist die Verwendung von Vererbung hier sogar die <i>beste</i> Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1465040780654" ID="ID_1719566689" MODIFIED="1465040812722">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Geschachtelte Typdefs lassen sich vermeiden:
|
|
</p>
|
|
<p>
|
|
BareEntryID speichern!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1465040890735" ID="ID_530818537" MODIFIED="1575133336607" TEXT="API für die ID ist ein Dilemma">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, wie rum man es auch auflöst, wird die Lösung auf einer Seite schlechter
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wenn wir für den Payload-Typ einen Typ-Parameter nehmen, blähen wir den Standard-Fall (Setter) auf
|
|
</li>
|
|
<li>
|
|
andererseits <i>ist es unbstreitbar einfach so,</i> daß für den Mutator-Builder die Typisierung komplett implizit ist, das muß die Closure mit sich selbst ausmachen, einfach indem in der Closure ein geschachtelter TreeMutator konstruiert wird, der eben mit diesem impliziten Kind-Typ umgehen kann.
|
|
</li>
|
|
<li>
|
|
wenn wir stattdessen nur einen Key-String speichern, wird zum Einen die Match-Prüfung aufwendiger (Stringvergleich statt Vergleich von Hashes), und außerdem wird ein Typ-Mismatch nicht mehr auf der Ebene der Verb-Anwendung entdeckt und entsprechend gekennzeichnet, sondern wir hoffen, daß es dann innerhalb der Closure zu einem Fehlzugriff auf die Payload der GenNode kommt. Noch schlimmer im Mutator-Fall, da sind wir dann schon im geschachtelten Scope und hoffen, daß dann der eingeschachtelte Mutator irgendwo auf Widerspruch läuft.
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1465041611663" ID="ID_1520147808" MODIFIED="1575133336640" TEXT="man kann auf DSL-Ebene mehrere Alternativen anbieten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...gedacht für verschiedene UseCases.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Fall 1: String-Key und der Typ muß irgendwie implizit/explizit gegeben sein
|
|
</li>
|
|
<li>
|
|
Fall2: GenNodeID
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1465139405203" ID="ID_208234192" MODIFIED="1575133336658" TEXT="...hey, der Typ ist implizit klar! es ist immer Rec">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die offensichtlichsten Dinge übersieht man nur zu leicht!!!!!
|
|
</p>
|
|
<p>
|
|
Da es ein nested scope ist, ist es immer ein Objekt,
|
|
</p>
|
|
<p>
|
|
also repräsentiert als Rec<GenNode>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1457232746179" FOLDED="true" ID="ID_35428480" MODIFIED="1576200552588" TEXT="Rec<GenNode>" VSHIFT="11">
|
|
<icon BUILTIN="full-4"/>
|
|
<node COLOR="#435e98" CREATED="1464305377785" ID="ID_1029321620" MODIFIED="1576200521001" TEXT="Vorüberlegungen">
|
|
<node CREATED="1464305417066" ID="ID_227151593" MODIFIED="1512926192077" TEXT="wünschenswert">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1464305708891" ID="ID_273948396" MODIFIED="1512926192077" TEXT="Vorteile">
|
|
<node CREATED="1464305431944" ID="ID_1510210328" MODIFIED="1464305641440" TEXT="den RecordContentMutator loswerden"/>
|
|
<node CREATED="1464305660018" ID="ID_33964570" MODIFIED="1464305687458" TEXT="die speziellen Regeln für Attribute / Kinder loswerden"/>
|
|
</node>
|
|
<node CREATED="1464305712115" ID="ID_937724979" MODIFIED="1512926192078" TEXT="Nachteile">
|
|
<node CREATED="1464305722209" ID="ID_815912844" MODIFIED="1464305733108" TEXT="man braucht immer einen TreeMutator"/>
|
|
<node CREATED="1464305735032" ID="ID_146394449" MODIFIED="1464305745786" TEXT="das ist sehr komplexer Code"/>
|
|
<node CREATED="1464305756189" ID="ID_239782768" MODIFIED="1464305766735" TEXT="zusätzliche Indirektion / VTable"/>
|
|
<node CREATED="1464305800207" ID="ID_1466205270" MODIFIED="1464305818736" TEXT="das "Backdoor" in Record::Mutator bleibt bestehen"/>
|
|
</node>
|
|
<node CREATED="1464305842833" ID="ID_1675290116" MODIFIED="1525124215201" TEXT="Abwägung">
|
|
<node CREATED="1464305847001" ID="ID_674702374" MODIFIED="1533608413973" TEXT="Aufwand">
|
|
<node CREATED="1464305850440" ID="ID_1548441801" MODIFIED="1561827465572" TEXT="dedizierte Impl">
|
|
<node CREATED="1464305871806" ID="ID_202305183" MODIFIED="1464305874249" TEXT="ein Stack"/>
|
|
<node CREATED="1464306044598" FOLDED="true" ID="ID_905327861" MODIFIED="1561827483836" TEXT="pro Stackframe">
|
|
<node CREATED="1464305896754" ID="ID_1490549138" MODIFIED="1464305908965" TEXT="ref Rec::Mutator"/>
|
|
<node CREATED="1464305910520" FOLDED="true" ID="ID_1267020121" MODIFIED="1561827482931" TEXT="Puffer: RecordContentMutator">
|
|
<node CREATED="1464305921943" ID="ID_884726801" MODIFIED="1464305927370" TEXT="Vector Attribute"/>
|
|
<node CREATED="1464305927910" ID="ID_1753475894" MODIFIED="1464305933817" TEXT="Vector Kinder"/>
|
|
<node CREATED="1464305989422" ID="ID_312208418" MODIFIED="1464305994825" TEXT="ein vector::iterator"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1464305854040" ID="ID_1249348832" MODIFIED="1561827465573" TEXT="per TreeMutator">
|
|
<node CREATED="1464305876237" ID="ID_1159160542" MODIFIED="1464305878376" TEXT="ein Stack"/>
|
|
<node CREATED="1464306061588" FOLDED="true" ID="ID_746468831" MODIFIED="1561827483836" TEXT="pro Stackframe">
|
|
<node CREATED="1472781610135" FOLDED="true" ID="ID_784986236" MODIFIED="1561827482931">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>zwei </i>Bindings
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1472781728046" ID="ID_642515736" MODIFIED="1472781744825" TEXT="ref Quell-Vector"/>
|
|
<node CREATED="1472781629036" ID="ID_1770081141" MODIFIED="1472781751975" TEXT="Puffer: Vector GenNode"/>
|
|
<node CREATED="1472781648571" ID="ID_129841438" MODIFIED="1472781677753" TEXT="ein zugehöriger Iterator"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472781868035" HGAP="40" ID="ID_1179886087" MODIFIED="1533608413976" TEXT="Unterschied minimal" VSHIFT="-3">
|
|
<node CREATED="1472781885352" ID="ID_563320689" MODIFIED="1472781888836" TEXT="zwei Iteratoren"/>
|
|
<node CREATED="1472781889328" ID="ID_852723828" MODIFIED="1472781899051" TEXT="zwei Quell-Referenzen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472653531806" HGAP="76" ID="ID_1315184227" MODIFIED="1512926192083" TEXT="Ansatz" VSHIFT="-10">
|
|
<node CREATED="1472653541019" ID="ID_961055257" MODIFIED="1472653569512">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>zwei</i> Collection-Bindings
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1472653548905" ID="ID_259592710" MODIFIED="1472653553124" TEXT="speziell konfiguriert"/>
|
|
<node CREATED="1472654905416" ID="ID_1967321401" MODIFIED="1472654910067" TEXT="minimaler Code"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1464305382975" FOLDED="true" ID="ID_692712808" MODIFIED="1576200534494" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1457742036967" ID="ID_1625216231" MODIFIED="1512926192084" TEXT="Attribute">
|
|
<node CREATED="1472781560508" ID="ID_1860994485" MODIFIED="1472781584718" TEXT="Selector: isNamed"/>
|
|
<node CREATED="1472930964666" ID="ID_737827437" MODIFIED="1473014470867" TEXT="Behandlung für Typ-Feld"/>
|
|
</node>
|
|
<node CREATED="1457742040782" ID="ID_1865296889" MODIFIED="1457742042442" TEXT="Kinder"/>
|
|
<node CREATED="1472781922380" ID="ID_26493762" MODIFIED="1512926192085" TEXT="Problem: rekursiver Mutator">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1472781942185" ID="ID_438122395" MODIFIED="1472781946644" TEXT="rein code-technisches Problem"/>
|
|
<node CREATED="1472781957063" ID="ID_1039824965" MODIFIED="1472781964177" TEXT="durch forward-decl aufzulösen"/>
|
|
<node CREATED="1472781977156" ID="ID_1725507816" MODIFIED="1472782008196" TEXT="erfordert Umbau der Code-Struktur">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472930979111" ID="ID_1556242161" MODIFIED="1512926192086" TEXT="Problem: Typ-Feld">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1472931031568" ID="ID_1654000393" MODIFIED="1512926192087" TEXT="Kompromiß in GenNode">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1472931061612" ID="ID_603006916" MODIFIED="1472931066111" TEXT="halbherziges Design"/>
|
|
<node CREATED="1472931066635" ID="ID_1880164855" MODIFIED="1472931074166" TEXT="wollte nicht wirklich Metadaten einführen"/>
|
|
<node CREATED="1472931074754" ID="ID_660840872" MODIFIED="1472931083789" TEXT="hab's daher dann fest verdrahtet"/>
|
|
<node CREATED="1472931084281" ID="ID_1848053126" MODIFIED="1472931095987" TEXT="erlaube "Abkürzung" über das Typ-Attribut"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1472931096647" ID="ID_1241833509" MODIFIED="1575133337240" TEXT="aber nicht wirklich konsequent...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...diese Abkürzung ist nur auf den Konstruktur aufgepflanzt,
|
|
</p>
|
|
<p>
|
|
nicht aber in der eigentlichen Implementierung verankert.
|
|
</p>
|
|
<p>
|
|
Das wollte ich nicht, weil ich längerfristig doch davon ausgehe,
|
|
</p>
|
|
<p>
|
|
daß es einfach einen Metadaten-Scope gibt
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Die Inkonsequenz nun ist, daß im Rec::Mutator keine Magie dafür vorgesehen ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472931195618" ID="ID_1254454459" MODIFIED="1512926192087" TEXT="aber Meta-Attribut für Diff">
|
|
<node CREATED="1472931234165" ID="ID_1010565523" MODIFIED="1472931239279" TEXT="geht nicht anders"/>
|
|
<node CREATED="1472931241027" ID="ID_1886048314" MODIFIED="1472931247263" TEXT="direkte Folge des Objekt-Modells"/>
|
|
<node CREATED="1472931391998" ID="ID_1851028882" MODIFIED="1533608413977" TEXT="betrifft">
|
|
<node CREATED="1472931395526" ID="ID_147828188" MODIFIED="1472931403393" TEXT="ins(type = X)"/>
|
|
<node CREATED="1472931404525" ID="ID_727467625" MODIFIED="1561827465582" TEXT="set(type = X)">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1472931416323" ID="ID_780639854" MODIFIED="1472931434577" TEXT="AUA: bisher übersehen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472931275575" ID="ID_36604643" MODIFIED="1512926192088" TEXT="Collection-Binding">
|
|
<node CREATED="1472931287229" ID="ID_1748994811" MODIFIED="1472931308630" TEXT="klinkt sich unterhalb vom Mutator ein"/>
|
|
<node CREATED="1472931309122" ID="ID_669812273" MODIFIED="1472931324740" TEXT="umgeht den Mutator"/>
|
|
<node CREATED="1472931326512" ID="ID_1698822987" MODIFIED="1472931332867" TEXT="arbeitet direkt auf den Collections"/>
|
|
<node CREATED="1472931333975" ID="ID_1945169133" MODIFIED="1472931342433" TEXT="reicht Werte unbetrachtet 1:1 durch"/>
|
|
</node>
|
|
<node CREATED="1472931711315" ID="ID_1325514083" MODIFIED="1512926192089" TEXT="Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1472931716482" ID="ID_1029866083" MODIFIED="1575133337450" TEXT="Lambdas nicht ausreichend">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...mit den Lambdas kann ich nur die Sicht auf die Werte steuern,
|
|
</p>
|
|
<p>
|
|
nicht aber das eigentliche Verhalten des Bindings.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Denn die Lambdas haben keinen Zugriff auf die Ziel-Datenstruktur!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1472931806958" ID="ID_1424193694" MODIFIED="1472931822190" TEXT="müßte Binding-Operationen anpassen">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1472931829467" ID="ID_1855554360" MODIFIED="1533608413978" STYLE="fork" TEXT="Dekorator">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1472934618917" ID="ID_1788521857" MODIFIED="1472934744607" TEXT="legt sich um den äußeren Collection-Binding-Layer"/>
|
|
<node CREATED="1472934635426" ID="ID_1872796326" MODIFIED="1472934744607" TEXT="greift bei der injectNew und assignElm-Operation ein"/>
|
|
<node CREATED="1472934671013" ID="ID_900235786" MODIFIED="1472934744607" TEXT="braucht Zugang zum Rec::Mutator">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1472934695226" ID="ID_53406841" MODIFIED="1472934744607" TEXT="Code wird schwer lesbar"/>
|
|
<node CREATED="1472934710032" ID="ID_1169855604" MODIFIED="1561827465582" TEXT="umformulieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1473014547678" ID="ID_1416366234" MODIFIED="1473014763323" TEXT="geht nur bedingt">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1473014552677" ID="ID_198496738" MODIFIED="1575133337582" TEXT="Problem ist der Builder">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wir wollen mehrfach geschichtete TreeMutator-Subklassen,
|
|
</p>
|
|
<p>
|
|
aber tatsächlich liefert jeder DSL-Aufruf einen Builder<TreeMutator<...>>.
|
|
</p>
|
|
<p>
|
|
Die normalen DSL-Aufrufe sind eben genau so gestrickt, daß jeweils der oberste Builder entfernt wird,
|
|
</p>
|
|
<p>
|
|
ein neuer Layer darübergebaut und das Ganze wieder in einen Builder eingewickelt wird.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dadurch ist es schwer bis unmöglich (wg. den Lambdas), den resultierenden Typ anzuschreiben.
|
|
</p>
|
|
<p>
|
|
Daher bin ich zwingend auf Wrapper-Funktionen angewiesen, die diesen resultierenden Typ
|
|
</p>
|
|
<p>
|
|
vom konkreten Aufruf wieder "abgreifen". Ich kann daher nicht die DSL-Notation verwenden,
|
|
</p>
|
|
<p>
|
|
um den Dekorator für die Behandlung des Typ-Feldes einzubringen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472782025318" ID="ID_806642349" MODIFIED="1512926192091" TEXT="Standard-Lambdas für GenNode">
|
|
<node CREATED="1472782055217" ID="ID_748812918" MODIFIED="1472782069243" TEXT="Selector -> ID-Vergleich"/>
|
|
<node CREATED="1472782069784" ID="ID_1481800599" MODIFIED="1472782075874" TEXT="Constructor -> copy"/>
|
|
<node CREATED="1472782077062" ID="ID_105976983" MODIFIED="1472782092512" TEXT="Setter -> assign DataCap"/>
|
|
<node CREATED="1472782093956" ID="ID_1112310070" MODIFIED="1472782120696">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Mut -> <font color="#e43e2a">Rekursion</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472830089042" ID="ID_680894810" MODIFIED="1512926192092" TEXT="until after Ref::ATTRIBS">
|
|
<node CREATED="1472830107591" ID="ID_1855713162" MODIFIED="1472830118609" TEXT="muß Semantik im TreeMutator API korrigieren"/>
|
|
<node CREATED="1472830131284" ID="ID_362004035" MODIFIED="1472830153132" TEXT="Problem: nur die Implementierung weiß, was ein "Attribut" ist"/>
|
|
<node CREATED="1472830122757" ID="ID_127070842" MODIFIED="1472830129487" TEXT="brauche Unterstützung vom Selector"/>
|
|
<node CREATED="1472830164119" ID="ID_894543850" MODIFIED="1512926192093" TEXT="Lösungsansatz">
|
|
<node CREATED="1472830177221" ID="ID_1697807817" MODIFIED="1472830181729" TEXT="wie Ref::END"/>
|
|
<node CREATED="1472830182101" ID="ID_698099374" MODIFIED="1472830195511" TEXT="aber nur einige Layer reagieren darauf"/>
|
|
<node CREATED="1472830199203" ID="ID_321429589" MODIFIED="1533608413978" TEXT="default-return muß true sein">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1472830226455" ID="ID_416259906" MODIFIED="1472830232658" TEXT="aber natürlich nur wenn leer..."/>
|
|
<node CREATED="1472830286462" ID="ID_105472568" MODIFIED="1472830298035" TEXT="Einsicht: END und ATTRIBS können nicht scheitern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1472830304844" ID="ID_1240058977" MODIFIED="1472840380057" TEXT="...es geht nur um das Layer-Chaining"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#4a273f" CREATED="1461882151581" HGAP="29" ID="ID_316724242" MODIFIED="1512926192094" TEXT="Selector integrieren" VSHIFT="23">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1461967533959" ID="ID_1695271883" MODIFIED="1468761946715" TEXT="korrekte logische Verkettung"/>
|
|
<node CREATED="1461967541166" ID="ID_1781788406" MODIFIED="1468761946715" TEXT="muß von jeder Primitive unterstützt werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1461967571042" ID="ID_1117096619" MODIFIED="1512926192095">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Problem</b><font color="#4e094b">: partielle Ordnung</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1461967744747" ID="ID_1780100456" MODIFIED="1468761946715" TEXT="Diff setzt totale Ordnung voraus"/>
|
|
<node CREATED="1461967765080" ID="ID_1598311122" MODIFIED="1468761946715" TEXT="verletzt durch »onion-layer«"/>
|
|
<node CREATED="1461967839110" ID="ID_1596717420" MODIFIED="1512926192095" TEXT="Relevanz">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1461967850797" ID="ID_1675158405" MODIFIED="1468761946715" TEXT="bei Einzelschritt irrelevant"/>
|
|
<node CREATED="1461967876521" ID="ID_744310541" MODIFIED="1512926192096" TEXT="zwingend bei "AFTER"-Verb">
|
|
<node CREATED="1461967962814" ID="ID_517095615" MODIFIED="1575133337967" TEXT="weil das Zwischenschritte überspringt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt,
|
|
</p>
|
|
<p>
|
|
das AFTER-Verb wird übersetzt in ein skip_until,
|
|
</p>
|
|
<p>
|
|
und das läuft dann entweder in jedem Layer
|
|
</p>
|
|
<p>
|
|
oder nur in dem Layer, der auf die Spec paßt.
|
|
</p>
|
|
<p>
|
|
In jedem Fall gerät dadurch die relative Verzahnung der Elemente untereinander aus dem Takt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1461967992042" ID="ID_315533174" MODIFIED="1468761946715" TEXT="nur ein Ausweg..."/>
|
|
<node CREATED="1461968004720" ID="ID_201527265" MODIFIED="1575133337998" TEXT="Ordnung der onion-layer verbindlich machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt also, es wird stets der zuerst gebundene Layer komplett durchgespult,
|
|
</p>
|
|
<p>
|
|
gefolgt dann von dem nächsten Layer.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Die Konsequenz ist, daß es keine Mischung der Typen geben kann.
|
|
</p>
|
|
<p>
|
|
Es müssen immer zwingend alle Elemente eines Typs von einem Layer behandelt werden
|
|
</p>
|
|
<p>
|
|
und diese Elemente müssen geschlossen hintereinander in der Reihenfolge liegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465428839332" ID="ID_655341963" MODIFIED="1561827465587" TEXT="Diff-Anwendung" VSHIFT="36">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1465428850946" FOLDED="true" MODIFIED="1611218290572">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf Basis des neu geschaffenen <b>TreeMutator</b>s
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1465664755169" ID="ID_1006974987" MODIFIED="1561827465591" TEXT="Modus der Anwendung">
|
|
<node CREATED="1465664762944" ID="ID_1572264709" MODIFIED="1465665479208" TEXT="DiffApplicator<TreeMutator>">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1465664777398" ID="ID_1214269061" MODIFIED="1575133338075" TEXT="Automatismen sind denkbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....man könnte später geeignete Automatismen schaffen,
|
|
</p>
|
|
<p>
|
|
die sich diesen TreeMutator beschaffen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
indem erkannt wird, daß das eigentliche Zielobjekt ein bestimmtes API bietet
|
|
</li>
|
|
<li>
|
|
indem andere relevante Eigenschaften des Zielobjekts erkannt werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#994062" DESTINATION="ID_254742738" ENDARROW="Default" ENDINCLINATION="1028;0;" ID="Arrow_ID_62544040" STARTARROW="None" STARTINCLINATION="978;42;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1465665483456" FOLDED="true" ID="ID_1302308143" MODIFIED="1576200010672" TEXT="Problem: konkreter Mutator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das so häufig in C++ auftretende Problem:
|
|
</p>
|
|
<p>
|
|
wie baue und verwalte ich eine konkrete Implementierung,
|
|
</p>
|
|
<p>
|
|
ohne gleich ein ganzes Management-Framework einführen zu müssen.
|
|
</p>
|
|
<p>
|
|
Letzten Endes lief  das auch in diesem Fall auf inline-Storage hinaus...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1465665492727" ID="ID_871587416" MODIFIED="1465665500210" TEXT="muß vom Target gebaut werden"/>
|
|
<node CREATED="1465665500830" ID="ID_575550821" MODIFIED="1465665561681" TEXT="Typ nicht bekannt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1465665511580" ID="ID_1245550673" MODIFIED="1465665556325" TEXT="soll auf Stack top-Level ">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1465665579587" ID="ID_1399616554" MODIFIED="1525124215211" TEXT="problematisch">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1465665594969" ID="ID_274492161" MODIFIED="1533608413979" TEXT="unbekannte Größe">
|
|
<node CREATED="1465665884698" ID="ID_1454370216" MODIFIED="1465665893757" TEXT="default-Buffergöße vorlegen"/>
|
|
<node CREATED="1465665894273" ID="ID_704262320" MODIFIED="1465665901124" TEXT="Größe proben und anpassen"/>
|
|
<node CREATED="1465665901640" ID="ID_67642439" MODIFIED="1465665920298" TEXT="Größe für "bekannte" Targets statisch hinterlegen"/>
|
|
<node CREATED="1465852237233" HGAP="27" ID="ID_483230622" MODIFIED="1561827465592" TEXT="Beschluß" VSHIFT="12">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1465852248487" ID="ID_758697883" MODIFIED="1465852255154" TEXT="zunächst die einfachste Lösung"/>
|
|
<node CREATED="1465852255694" ID="ID_877813979" MODIFIED="1472122166677" TEXT="statisch (fest) festlegen"/>
|
|
<node CREATED="1465852268252" ID="ID_190196051" MODIFIED="1465852274743" TEXT="ggfs. noch nach Zieltyp differenziert"/>
|
|
<node CREATED="1465852275859" ID="ID_61230636" MODIFIED="1465852288510" TEXT="dynamisch / Lernen als Möglichkeit vorsehen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465665614990" ID="ID_1119567524" MODIFIED="1533608413980" TEXT="verwirrendes API">
|
|
<node CREATED="1465665980686" ID="ID_1492023749" MODIFIED="1465665991232" TEXT="Anwendung sollte selbstevident sein"/>
|
|
<node CREATED="1465666009690" ID="ID_1649443825" MODIFIED="1561827465592" TEXT="Typ-Signatur sollte den Weg weisen">
|
|
<node CREATED="1465674483754" ID="ID_618303620" MODIFIED="1465674558135" TEXT="sehe nur eine Lösung">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1465674488874" ID="ID_1053641252" MODIFIED="1465674563848" TEXT="Mutator-Builder-Funktion">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1465674529460" ID="ID_1090489809" MODIFIED="1465674571112" TEXT="pflanzt in ein gegebenes Buff-Handle">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465665993012" ID="ID_267337231" MODIFIED="1465666003750" TEXT="keine komplexen "Riten""/>
|
|
<node CREATED="1465666524573" HGAP="30" ID="ID_18958581" MODIFIED="1561827465592" TEXT="Schlußfolgerung" VSHIFT="18">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1465666541419" ID="ID_787956112" MODIFIED="1465666552293" TEXT="entweder ein festes Interface"/>
|
|
<node CREATED="1465666552842" ID="ID_1360512685" MODIFIED="1465666574594" TEXT="oder über Metaprogrammierung / Spezialisierung"/>
|
|
<node CREATED="1468761997202" FOLDED="true" ID="ID_206940182" MODIFIED="1611219082511" TEXT="kombinierte Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1468762009304" ID="ID_170152384" MODIFIED="1611219253284" TEXT="Interface DiffMutable">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#435e98" CREATED="1611219255178" ID="ID_790740828" MODIFIED="1611221058698" TEXT="dies entwickelt sich zum Standardfall...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...zumindest im GUI, wo parktisch alle Empfänger auch ein Tangible (Widget oder Controller) sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1611221009482" ID="ID_1797198606" MODIFIED="1611226329184" TEXT="exponiert builder-Methode">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und genau diese virtuelle Builder-Methode ist üblicherweise der Ort, wo mit einer DSL und über Lambdas das Mapping auf die internen Strukturen des DiffMutable hergestellt wird; deshalb kann auch DiffMutable selber ein sehr schlankes Interface sein; der resultierende TreeMutator ist dann eine für den jeweiligen konkreten Typ aus Bausteinen generierte Hilfsklasse
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611226844354" ID="ID_252206662" MODIFIED="1611227312132" TEXT="oft in einer Collection...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dort per smart-Ptr.<br />Für diesen Fall kann die Verdrahtung weitgehend automatisch konfiguiert werden, und man muß eigentlich nur noch den Konstruktor-Aufruf explizit (per Lambda) in das TreeMuator-Binding integrieren. Wenn es mehrere »onion layer« gibt, muß allerdings auch noch ein »Selector« definiert werden, um zu steuern, wo genau dieses Binding angewendet wird, und wo sonst auf einen anderen Layer delegiert wird, z.B. für explizit gebundene Objekt-Attribute.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#1ebca6" DESTINATION="ID_489519336" ENDARROW="Default" ENDINCLINATION="689;-28;" ID="Arrow_ID_1973768518" STARTARROW="None" STARTINCLINATION="490;52;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1468762031701" FOLDED="true" ID="ID_1455212830" MODIFIED="1561827482931" TEXT="Meta-Adapter">
|
|
<linktarget COLOR="#503382" DESTINATION="ID_1455212830" ENDARROW="Default" ENDINCLINATION="32;58;" ID="Arrow_ID_1591967504" SOURCE="ID_993360353" STARTARROW="None" STARTINCLINATION="222;18;"/>
|
|
<node CREATED="1468762052858" ID="ID_1870920189" MODIFIED="1468762066764" TEXT="synthetisiert dieses Interface"/>
|
|
<node CREATED="1468762067383" ID="ID_1801995068" MODIFIED="1468762075059" TEXT="erkennt passende Methoden"/>
|
|
<node CREATED="1468762075671" ID="ID_1201929549" MODIFIED="1611219223899" TEXT="Problem: Storage">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1468762092660" ID="ID_1968257665" MODIFIED="1468762097264" TEXT="Adapter oder Lambda"/>
|
|
<node CREATED="1468762097684" ID="ID_438037423" MODIFIED="1468762107374" TEXT="muß länger leben als der Adapter"/>
|
|
<node CREATED="1468762118913" ID="ID_900380797" MODIFIED="1468762128867" TEXT="Lösung: Wert / Reftyp per Spezialisierung"/>
|
|
<node CREATED="1468762138318" ID="ID_897808839" MODIFIED="1472219338878" TEXT="Restrisiko bleibt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....daß ein unbedarfter client diesen Trick übershieht
|
|
</p>
|
|
<p>
|
|
und daher den Rückgabewert wegwirft.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Argument: we soweit einsteigt, die Metaprogramming-Lösung zu nutzen,
|
|
</p>
|
|
<p>
|
|
sollte auch intelligent genug sein, die API-Doc zu lesen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Standard == Interface DiffMutable implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1469121877371" FOLDED="true" HGAP="38" ID="ID_1614796496" MODIFIED="1561827469159" TEXT="freie Funktion" VSHIFT="16">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1469121882782" ID="ID_695291968" MODIFIED="1469121933463" TEXT="keine Spezialisierung notwendig">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1469121890060" ID="ID_743882721" MODIFIED="1469121930007">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Client soll direkt <b>mutatorBinding</b> bieten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1469544027620" HGAP="38" ID="ID_125815178" MODIFIED="1533608413984" TEXT="Storage-Probleme" VSHIFT="11">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1469544055624" ID="ID_1154293782" MODIFIED="1561827465596" TEXT="Beobachtung: Template-bloat">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1469544072709" ID="ID_1774421000" MODIFIED="1469544083016" TEXT="Ursache: wir generieren die Klasse jedesmal neu"/>
|
|
<node CREATED="1469544084220" ID="ID_1256237924" MODIFIED="1469544104909" TEXT="...obwohl keinerlei Bezug zum Target-Typ vorliegt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1469544123271" ID="ID_1177495661" MODIFIED="1469544133675" TEXT="Funktionalität ist zu 90% generisch">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1469544171176" ID="ID_993360353" MODIFIED="1469544253263">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nicht</i> generisch: <b><font color="#923977">mutatorBinding</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#503382" DESTINATION="ID_1455212830" ENDARROW="Default" ENDINCLINATION="32;58;" ID="Arrow_ID_1591967504" STARTARROW="None" STARTINCLINATION="222;18;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1469544264955" HGAP="35" ID="ID_1303383911" MODIFIED="1561827465596" VSHIFT="16">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösungsversuch: <b>extern template</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1469544293574" ID="ID_543205456" MODIFIED="1469544318455" TEXT="Template bereits in Lumiera-Lib vor-generieren">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1469544337408" ID="ID_155206283" MODIFIED="1469544349252" TEXT="nur ctor ist nochmals ge-Templated">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1469544323331" FOLDED="true" ID="ID_1187319781" MODIFIED="1561827483836" TEXT="flexibler Teil verbleibt in ctor">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1469544368180" ID="ID_782870983" MODIFIED="1469544377687" TEXT="hier kann das mutatorBinding stattfinden"/>
|
|
<node CREATED="1469544385882" ID="ID_1613566026" MODIFIED="1469544397396" TEXT="...in Abhängigkeit vom konkreten Zieltyp"/>
|
|
<node CREATED="1469544400544" ID="ID_601582921" MODIFIED="1469544413058" TEXT="Resultat ist ein TreeMutator im internen Puffer"/>
|
|
</node>
|
|
<node CREATED="1469544471294" FOLDED="true" ID="ID_274473608" MODIFIED="1561827483837" TEXT="Problem-1: Puffer-Größe">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1469544519439" ID="ID_1593158621" MODIFIED="1469544535057" TEXT="Plan: Heuristik + Traits"/>
|
|
<node CREATED="1469544536309" ID="ID_1666794304" MODIFIED="1469544546951" TEXT="hängt von konkretem Zieltyp ab"/>
|
|
<node CREATED="1469544547731" ID="ID_1790199261" MODIFIED="1469544596453" TEXT="kann nicht im generischen Teil stecken">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1469544575808" ID="ID_1467987209" MODIFIED="1469544599880" TEXT="Problem: vom generischen Teil ansprechen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1469544601444" ID="ID_235522874" MODIFIED="1469544616515" TEXT="Lösung: weitere Indirektion">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1469544618738" ID="ID_1808730903" MODIFIED="1472122283229" TEXT="vertretbar, da nur beim Scope-Wechsel....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...im Klartext: diesen Zugriff von der generischen Implementierung
|
|
</p>
|
|
<p>
|
|
auf den eingebauten Stack-Mechanismus benötigen wir nur...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
einmal zu Beginn, bei der Konstruktion
|
|
</li>
|
|
<li>
|
|
wenn wir in einen geschachtelten Scope eintreten
|
|
</li>
|
|
<li>
|
|
wenn wir einen Solchen verlassen
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Zwar sind indirekte Calls aufwendiger, aber letzten Endes auch wieder nicht soooo aufwendig,
|
|
</p>
|
|
<p>
|
|
daß sie uns im gegebenen Kontext umbringen...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1469544496907" FOLDED="true" ID="ID_1217165446" MODIFIED="1561827483837" TEXT="Problem-2: re-Initialisierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1469544831244" ID="ID_1325104278" MODIFIED="1469544838662" TEXT="bestehendes Protokoll">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1469544839795" ID="ID_193708850" MODIFIED="1469544858420" TEXT="Diff-Applikator kan beliebige Folge von Diffs akzeptieren"/>
|
|
<node CREATED="1469544859392" ID="ID_1737941680" MODIFIED="1469544964778">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>intern:</i> eingebaute <b>initDiffApplication()</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wird automatisch vor Konsumieren eines Diff aufgerufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1469544965890" ID="ID_386723562" MODIFIED="1469545023179">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>Widerspruch:</i> TreeMutator ist <b>Wegwerf</b>-Objekt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node COLOR="#f61b01" CREATED="1469545033584" ID="ID_442523056" MODIFIED="1469545058652" TEXT="Abbruch">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1469545080826" HGAP="41" ID="ID_775671732" MODIFIED="1561827465600" VSHIFT="17">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lösungsversuch: <b>doppelte Hülle</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1469545168798" FOLDED="true" ID="ID_370635458" MODIFIED="1561827483837" TEXT="Architektur">
|
|
<node CREATED="1469545173893" ID="ID_814298904" MODIFIED="1469545190599" TEXT="opaque: Kern == TreeMutator"/>
|
|
<node CREATED="1469545191899" ID="ID_397109000" MODIFIED="1469545206853" TEXT="generisch: TreeMutator-Bindung"/>
|
|
<node CREATED="1469545208440" ID="ID_244347713" MODIFIED="1469545246870" TEXT="dediziert: Typ-Adapter"/>
|
|
</node>
|
|
<node CREATED="1469545401582" FOLDED="true" ID="ID_721753756" MODIFIED="1561827483837" TEXT="konkrete Folgen...">
|
|
<node CREATED="1469545417579" ID="ID_1940199475" MODIFIED="1469545427486" TEXT="alle virtuellen Methoden im generischen Teil"/>
|
|
<node CREATED="1469545428289" FOLDED="true" ID="ID_1499107269" MODIFIED="1561827482932" TEXT="generischer Teil verwendet nur Interfaces">
|
|
<node CREATED="1469545452406" ID="ID_190085940" MODIFIED="1469545455778" TEXT="TreeMutator"/>
|
|
<node CREATED="1469545456549" ID="ID_300958644" MODIFIED="1469545459401" TEXT="ScopeManager"/>
|
|
</node>
|
|
<node CREATED="1469545522445" FOLDED="true" ID="ID_1403539911" MODIFIED="1561827482932" TEXT="ScopeManager">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1469545526380" ID="ID_1121286637" MODIFIED="1469545535550" TEXT="Imp. wird per Zieltyp generiert"/>
|
|
<node CREATED="1469545536139" ID="ID_53324473" MODIFIED="1469545543750" TEXT="lebt in opaquem Buffer"/>
|
|
<node CREATED="1469545546209" ID="ID_347304855" MODIFIED="1469545561067" TEXT="enthält Stack,"/>
|
|
<node CREATED="1469545562151" ID="ID_1493051731" MODIFIED="1469545568130" TEXT="mit passender Puffergröße"/>
|
|
</node>
|
|
<node CREATED="1469545592171" FOLDED="true" ID="ID_606899967" MODIFIED="1561827482932" TEXT="dedizierter Applikator">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1469545598922" ID="ID_999031051" MODIFIED="1469545609733" TEXT="hällt Referenz auf Zielobjekt"/>
|
|
<node CREATED="1469545611177" ID="ID_1578280004" MODIFIED="1469545670672">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann daher <b>TreeMutator</b> konstruieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1469545641644" ID="ID_719025162" MODIFIED="1469545662506">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und zwar per <b>mutatorBinding</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1469545691349" ID="ID_1537085784" MODIFIED="1469545705980">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
implementiert somit <b>initDiffApplication()</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1469545778873" FOLDED="true" HGAP="37" ID="ID_1238563884" MODIFIED="1561827483837" VSHIFT="53">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TODO: <font color="#010101">Namensgebung</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#7c4b8e" DESTINATION="ID_1238563884" ENDARROW="Default" ENDINCLINATION="-438;877;" ID="Arrow_ID_701265417" SOURCE="ID_1433722735" STARTARROW="Default" STARTINCLINATION="2134;135;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1469545959160" ID="ID_1653202468" MODIFIED="1469545961076" TEXT="DiffApplicationStrategy<DiffMutable>"/>
|
|
<node CREATED="1469545962192" ID="ID_363293414" MODIFIED="1469545971051" TEXT="feste explizite Spezialisierung"/>
|
|
<node CREATED="1469545972470" ID="ID_1576991625" MODIFIED="1469545983800" TEXT="in non-Template-Basisklasse verwandeln"/>
|
|
<node CREATED="1469545990956" ID="ID_516103477" MODIFIED="1469546010389" TEXT="oder zumindest in Trait-Template + enable_if"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465855369239" ID="ID_832033113" MODIFIED="1525124215221" STYLE="fork" TEXT="Architektur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1465855402346" ID="ID_76313075" MODIFIED="1512926192122" TEXT="Grundgedanke">
|
|
<node CREATED="1465855407129" ID="ID_840507910" MODIFIED="1472219324297" TEXT="Trennung von DiffInterpreter und TreeMutator"/>
|
|
<node CREATED="1465855418880" ID="ID_1224291834" MODIFIED="1472219324297" TEXT="ersterer wird auf Basis von letzterem implementiert"/>
|
|
<node CREATED="1465855507380" ID="ID_794764888" MODIFIED="1472219324297">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TreeMutator-<i>Binding</i> muß opaque bleiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1465855561877" ID="ID_23704873" MODIFIED="1512926192123">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Buffer-Größen-Management <i>vorsehen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1465855596992" ID="ID_805593649" MODIFIED="1472219324298" TEXT="passiert im Scope des Ctors"/>
|
|
<node CREATED="1465855605879" ID="ID_730704715" MODIFIED="1472219324298" TEXT="bzw. im Scope des MUT-Verbs"/>
|
|
<node CREATED="1465855641898" ID="ID_1440271595" MODIFIED="1575133338771" TEXT="Heuristik + Versuch&Irrtum">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
ein sinnvoller Startwert wird heuristisch vorgegeben
|
|
</li>
|
|
<li>
|
|
wenn die Allokation scheitert, die Exception fangen und die tatsächlich benötigte Größe merken
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1465855653265" ID="ID_440676779" MODIFIED="1472219324298" TEXT="konfigurieren und lernen"/>
|
|
</node>
|
|
<node CREATED="1465855576187" ID="ID_1868954632" MODIFIED="1472219324298" TEXT="zunächst jedoch primitiv implementieren"/>
|
|
</node>
|
|
<node CREATED="1465856069657" ID="ID_1337282940" MODIFIED="1512926192123" TEXT="Struktur">
|
|
<node CREATED="1465856074888" ID="ID_835346056" MODIFIED="1472219324298" TEXT="TreeMutator == PImpl"/>
|
|
<node CREATED="1465856092638" ID="ID_1061297702" MODIFIED="1472219324298" TEXT="BufferManager : opaque aber inline"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465864106739" ID="ID_254742738" MODIFIED="1575133338859" TEXT="Zugang zum Mutator-Binding">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt:
|
|
</p>
|
|
<p>
|
|
gegeben ein syntaktisch sinnvoller top-level-Aufruf ("wende das Diff an")
|
|
</p>
|
|
<p>
|
|
-- wie bzw. von wem bekommen wir dann ein Binding, das einen passenden TreeMutator konstruiert?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#994062" DESTINATION="ID_254742738" ENDARROW="Default" ENDINCLINATION="1028;0;" ID="Arrow_ID_62544040" SOURCE="ID_1214269061" STARTARROW="None" STARTINCLINATION="978;42;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1465864167187" ID="ID_1014149687" MODIFIED="1465864171974" TEXT="Aufruf: freie Funktion"/>
|
|
<node CREATED="1465864172514" ID="ID_1938000921" MODIFIED="1465864180668" TEXT="delegiert auf Template"/>
|
|
<node CREATED="1465864181193" ID="ID_1416910409" MODIFIED="1465864192611" TEXT="explizite / regelbasierte Spezialisierung"/>
|
|
<node CREATED="1465864193607" ID="ID_1086360419" MODIFIED="1512926192124" TEXT="Problem: Storage für die Closure">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1465864217628" ID="ID_868183917" MODIFIED="1465864228510" TEXT="typischerweise sind alles transiente Objekte"/>
|
|
<node CREATED="1465864229170" ID="ID_442975692" MODIFIED="1465864240501" TEXT="also muß die Closure als Wert-Objekt rausgegeben werden"/>
|
|
<node CREATED="1472495487478" ID="ID_1246712083" MODIFIED="1512926192125" TEXT="Lösung...">
|
|
<node CREATED="1472495496574" ID="ID_1728009713" MODIFIED="1472495510056" TEXT="auto typed return value"/>
|
|
<node CREATED="1472495510531" ID="ID_39881553" MODIFIED="1472495513703" TEXT="keep in local scope"/>
|
|
<node CREATED="1472495514203" ID="ID_1953453853" MODIFIED="1472495529197" TEXT="tightly integrate into ctor of DiffAplicator"/>
|
|
</node>
|
|
<node CREATED="1465864247152" ID="ID_369875178" MODIFIED="1512926192125" TEXT="gesucht: elegantes API">
|
|
<node CREATED="1472494557762" ID="ID_1362626195" MODIFIED="1472494575309" TEXT="DiffAplicator<TargetTyp>">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1472494413960" ID="ID_1029844890" MODIFIED="1472494571740" TEXT="Erweiterungspunkt für ADL..."/>
|
|
<node CREATED="1472494432219" ID="ID_410727246" MODIFIED="1472494446981" TEXT="...wird vom ctor des Diff-Applikators verwendet"/>
|
|
<node CREATED="1472494466926" ID="ID_1047421260" MODIFIED="1472494484296" TEXT="...und der wiederum greift nur"/>
|
|
<node CREATED="1472494485388" ID="ID_470796053" MODIFIED="1472494501141" TEXT="...wenn TreeDiffTraits definiert sind"/>
|
|
<node CREATED="1472494501778" ID="ID_1970090360" MODIFIED="1472494506323" TEXT="not too bad">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1465860736044" ID="ID_554117057" MODIFIED="1561827465611" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1472121965308" ID="ID_762131895" MODIFIED="1472121974646" TEXT="Verb delegiert an Mutator-Primitive"/>
|
|
<node CREATED="1472121976018" ID="ID_1667890765" MODIFIED="1472121995995" TEXT="Fehlerbehandlung anhand Rückgabewert dieser"/>
|
|
<node CREATED="1472122015157" ID="ID_507093208" MODIFIED="1472122038334" TEXT="sinnvolle interne Fehler-Funktionen aufbauen"/>
|
|
<node CREATED="1472141026525" ID="ID_215668060" MODIFIED="1512926192127" TEXT="Scope-Wechsel">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1472172154624" FOLDED="true" ID="ID_916630849" MODIFIED="1512926192127" TEXT="Zugang zum erzeugten Mutator....">
|
|
<node CREATED="1472172310187" ID="ID_487326937" MODIFIED="1575133339222" TEXT="via buffer-Handle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erscheint mir die am wenigsten überraschende Lösung.
|
|
</p>
|
|
<p>
|
|
und zwar per handle.get()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1472172348526" ID="ID_1189257051" MODIFIED="1533608413996" TEXT="mögliche Alternativen">
|
|
<node CREATED="1472172364204" ID="ID_1693509282" MODIFIED="1575133339255" TEXT="Closure gibt TreeMutator& zurück">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erscheint mir fehleranfällig und irreführend für den Nutzer der Schnittstelle.
|
|
</p>
|
|
<p>
|
|
Denn er muß zwar das Objekt in das Handle platzieren, dann aber auch noch einen Pointer zurückgeben,
|
|
</p>
|
|
<p>
|
|
der dann auch noch NULL sein kann, zum Signalisieren von Fehlern.
|
|
</p>
|
|
<p>
|
|
Ich empfinde das als schlechten Stil
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1472172467934" ID="ID_1540495826" MODIFIED="1575133339270" TEXT="ScopeManager-Interface erweitern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
naja, das wäre billig, aber auch wieder beliebig.
|
|
</p>
|
|
<p>
|
|
Es macht keinen Sinn vom API-Design her, sondern man müßte es halt machen,
|
|
</p>
|
|
<p>
|
|
weil die Implementierung den Zeiger auf den geschachtelen sub-Mutator umsetzen muß.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472172586703" ID="ID_1282826388" MODIFIED="1512926192128" TEXT="prüfen">
|
|
<node CREATED="1472172593710" ID="ID_539813118" MODIFIED="1472172608024" TEXT="geschachtelter Scope muß beim Verlassen komplett abgearbeitet sein"/>
|
|
<node CREATED="1472172608636" ID="ID_904329399" MODIFIED="1472172634020" TEXT="wir steigen niemals über den root-Scope hinaus auf"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1472172651974" FOLDED="true" ID="ID_717242686" MODIFIED="1611218246329" TEXT="ins-Problem beim Mutieren von Attributen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1472172658349" ID="ID_279579205" MODIFIED="1472172806077">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Diff-Sprache verlangt,
|
|
</p>
|
|
<p>
|
|
daß vor dem Öffnen des geschachtelten Scopes
|
|
</p>
|
|
<p>
|
|
dieser zumindest einmal per ins "angelegt" wurde.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1472172711846" ID="ID_67509104" MODIFIED="1472172809794" TEXT="wir haben es hier mit objektwertigen Attributen zu tun">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1472172723853" ID="ID_397776543" MODIFIED="1472172732503" TEXT="das ist ein sonderbarer Grenzfall">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1611218058623" ID="ID_948845594" MODIFIED="1611218075752" TEXT="Attribute tendieren zur Wertsemantik"/>
|
|
<node CREATED="1611218104017" ID="ID_1247405117" MODIFIED="1611218113067" TEXT="Attribute kann man eigentlich auch nicht umordnen"/>
|
|
<node CREATED="1611218115055" ID="ID_1628532981" MODIFIED="1611218183029" TEXT="Objekte können zudem Ctor-Constraints haben"/>
|
|
</node>
|
|
<node CREATED="1472172733307" ID="ID_1698922494" MODIFIED="1611217973598" TEXT="Attribute werden normalerweise fest in der Objekt-Impl erzeugt"/>
|
|
<node CREATED="1472172754136" ID="ID_205435085" MODIFIED="1472172765458" TEXT="ein INS hat dann nichts sinnvolles zu tun"/>
|
|
<node COLOR="#435e98" CREATED="1472172772494" ID="ID_842638924" MODIFIED="1472172795138" TEXT="default-Implementierung absorbiert das INS stillschweigend">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611218339864" FOLDED="true" ID="ID_341242193" MODIFIED="1611402354322" TEXT="Abkürzung für rekursives Standard-Binding">
|
|
<linktarget COLOR="#64b2d0" DESTINATION="ID_341242193" ENDARROW="Default" ENDINCLINATION="-1947;126;" ID="Arrow_ID_1779456185" SOURCE="ID_1626706964" STARTARROW="None" STARTINCLINATION="1123;53;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611227233973" ID="ID_489519336" MODIFIED="1611227312132" TEXT="für den häufigsten Fall: STL-Collection von Smart-Ptr auf DiffMutable">
|
|
<linktarget COLOR="#1ebca6" DESTINATION="ID_489519336" ENDARROW="Default" ENDINCLINATION="689;-28;" ID="Arrow_ID_1973768518" SOURCE="ID_252206662" STARTARROW="None" STARTINCLINATION="490;52;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611227337956" ID="ID_284850401" MODIFIED="1611227346387" TEXT="wird per MetaPrädikat erkannt">
|
|
<node CREATED="1611227487011" ID="ID_1701933719" MODIFIED="1611227500783" TEXT="wenn die Elemente entweder selber direkt DiffMutable sind"/>
|
|
<node CREATED="1611227501552" ID="ID_752689541" MODIFIED="1611227529633" TEXT="oder alternativ ein (smart)Pointer/Wrapper auf ein DiffMutable"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611261538911" ID="ID_498748918" MODIFIED="1611402319966" TEXT="Standard-Imlementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611261602057" ID="ID_160823769" MODIFIED="1611261614523" TEXT="inzwischen hat sich ein Standard-Schema etabliert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611261556183" ID="ID_236586609" MODIFIED="1611402310840" TEXT="Frage: warum machen wir einen ID-Match?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1611261593546" ID="ID_1666826303" MODIFIED="1611261791971" TEXT="typischerweise prüfen wir zu Beginn, ob das zu mutierende Sub-Element auch matcht"/>
|
|
<node CREATED="1611261792751" ID="ID_1188415737" MODIFIED="1611261815910" TEXT="man könnte hierfür den »Matcher« des Collection-Bindings verwenden"/>
|
|
<node CREATED="1611261840272" ID="ID_922368010" MODIFIED="1611261871424" TEXT="mehr noch: wie kommt es zu diesem Match-Guard?">
|
|
<node CREATED="1611261874508" ID="ID_1431589128" MODIFIED="1611261892215" TEXT="das Standard-Schema hat sich per Copy-n-Paste entwickelt">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611261893793" ID="ID_1503357970" MODIFIED="1611261910755" TEXT="könnte durchaus sein, daß dieser Schritt redundant ist"/>
|
|
<node CREATED="1611270254702" ID="ID_781667464" MODIFIED="1611271568520" TEXT="und genau so ist es">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das ist verständlich aus der Historie: Zunächst einmal war der TreeMutator gedacht als ein Interface, das der client des Diff-Frameworks zu implementieren hat. Nachdem ich diese Übung aber drei mal gemacht hatte, war mir klar, daß dies zu viel verlangt ist. Denn der TreeMutator ist notwendigerweise stark an den Implementierungs-Ansatz im Diff-Framework gebunden. Das heißt, man kann dieses Interface nur implementieren, wenn man diese interne Funktionsweise verstanden hat. Und das Diff-Framework würde seinen Zweck verfehlen, wenn der Nutzer dieses Wissen haben müßte. Also habe ich über den TreeMutator ein Baukastensystem errichtet, welches über Lambdas in den Anwendungskontext gebunden wird.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
In einem zweiten Anlauf habe ich schließlich die schon bestehenden, explizitien Implementierungen des TreeMutator-Interfaces allesamt "eingefangen" und durch ein Meshup aus dem Bauskastensystem ersetzt. Daher gibt es jetzt nur noch eine einzige valide Implementierung, nämlich die im Baukasen. Und das soll auch so bleiben.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Daher ist es zulässig, sich diese Implementierung anzuschauen: in der Tat geht nämlich dort jedem Aufruf des Mutators ein Suchvorgang voraus, und dieser endet immer mit einer erfolgreichen Anwendung des Matchers. Daher ist es grundsätzlich nicht notwendig, den ID-Match nochmal zu prüfen, bevor man in die rekursive Mutation einsteigt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wie kommt nun aber dieser explizit ausprogrammierte ID-Match in die Standard-Implementierung? Die Antwort ist, letztlich aus Verlegenheit. Denn zunächst einmal hatte ich für den Unit-Test alles für ein sehr spezielles Setup ausprogrammiert. Das ist auch gut so, denn dieses Setup deckt auch Grenzfälle mit ab. Also im Besonderen auch Bindings, die sich sehr speziell in Implementierungsstrukturen einklinken, und eben grade nicht direkt an ein DiffMutable-Subobjekt delegieren. Und diese Offenheit ist der essentielle Grund, warum ich auf ein Diff-Framework setze, und nicht auf ein Datenmodell mit festen Interfaces. Diese Offenheit bedingt aber auch, daß man dem Client die letztendliche Übersetzung der IDs überlassen muß. Für die rekursive Kind-Mutation muß der Client sich ggfs ein internes Implementierungs-Objekt anhand der gegebenen ID heraussuchen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Im einfachen Standardfall jedoch ist das nicht notwendig, denn in diesem häufigsten Standardfall haben wir mehr oder weniger direkt das Objekt aus der Collection in der Hand, auf welches dann der rekursive Mutator angewendet werden soll. Also stand ich beim ersten Schreiben einer Implementierung für diesen einfachen Standardfall vor dem Paradoxon, daß die Funktion einen ID-Parameter bekommt, den man anscheinend hier gar nicht braucht. Und, ohne diese Zusammenhänge damals zu verstehen, habe ich dann aus Verlegenheit noch eine Zeile Code eingebaut, die "was Sinnvolles mit dieser ID macht", denn es war ja zunächst auch erst mal ein Proof-of-Concept (und zu diesem Zeitpunkt gab es noch zwei weitere, alternative Implementierungen des TreeMutator-Interfaces). Letztlich hat sich dann dieses "anstandshalber" eingebaute Zeile, eben genau der ID-match, welcher mithin "etwas Sinnvolles" mit der ID macht, per Copy-n-Paste in alle konkreten Implementierungen fortgepflanzt. Wiewohl dieser Schritt im Stand der gegenwärtigen Implementierung stets redundant ist.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1611271855692" ID="ID_1449093831" MODIFIED="1611271873489" TEXT="Fazit: der Match-Guard kann aus allen Implementierungen entfernt werden">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1611271971948" ID="ID_1541118749" MODIFIED="1611271982750" TEXT="der ID-Parameter wird normalerweise nicht gebraucht"/>
|
|
<node CREATED="1611271983506" ID="ID_1671925205" MODIFIED="1611272055176" TEXT="er ist nur für Grenzfälle gedacht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...falls die clientseitige Datenstruktur einen Index verwendet, um per ID die eigentliche Zieldatenstruktur zu betreten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611402003818" ID="ID_1246335581" MODIFIED="1611402016011" TEXT="den ID-Matcher ebenfalls generieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611402016970" ID="ID_1067306968" MODIFIED="1611402027948" TEXT="wir brauchen zwar keinen ID-Match beim Erzeugen des Mutators"/>
|
|
<node CREATED="1611402028489" ID="ID_809714103" MODIFIED="1611402068427" TEXT="aber der ID-basierte Matcher ist ebenfalls generisch, und sollte automatisch generiert werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1611402077673" ID="ID_361760144" MODIFIED="1611402210308" TEXT="Problem: Zugang zur Target-Objekt-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1611402092625" ID="ID_19089272" MODIFIED="1611402150879" TEXT="könnte man in DiffMutable-Interface aufnehmen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1611402121148" ID="ID_1241594472" MODIFIED="1611402129847" TEXT="Vorsicht: DiffMutable ist opitonal"/>
|
|
<node CREATED="1611402130459" ID="ID_899835141" MODIFIED="1611402146172" TEXT="man müßte dann trotzdem noch Duck-Typing verwenden"/>
|
|
</node>
|
|
<node CREATED="1611402151832" ID="ID_1518275784" MODIFIED="1611402160776" TEXT="Duck-Typing verwenden">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1611402162870" ID="ID_697592973" MODIFIED="1611402180642">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erwarte eine Funktion <b>getID()</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611402182252" ID="ID_12989992" MODIFIED="1611402197061" TEXT="und deren Resultat muß per == vergleichbar sein"/>
|
|
<node CREATED="1611402199145" ID="ID_317509193" MODIFIED="1611402204788" TEXT="...mit einer GenNode::ID"/>
|
|
</node>
|
|
<node CREATED="1611402212151" ID="ID_543092941" MODIFIED="1611402232768" TEXT="wenn dies gegeben ist, dann kann man auch den »Matcher« generieren">
|
|
<node CREATED="1611402234140" ID="ID_1471601030" MODIFIED="1611402244652" TEXT="für stage::model::Tangible stets gegeben">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1611402245626" ID="ID_1721371942" MODIFIED="1611402285886" TEXT="sonst: Exception werfen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. man muß dann halt doch noch den Matcher explizit in der DSL konfigurieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1465860740971" ID="ID_1905457534" MODIFIED="1512926192131" TEXT="Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1472122365079" ID="ID_781825543" MODIFIED="1512926192131" TEXT="Aussagekräftiges Beispiel-Diff">
|
|
<node CREATED="1472122379548" ID="ID_1273829051" MODIFIED="1472122384864" TEXT="sollte alle Features vorführen"/>
|
|
<node CREATED="1472122385380" ID="ID_537172522" MODIFIED="1472122391943" TEXT="sollte wichtige Grenzfälle aktivieren"/>
|
|
<node CREATED="1472122394387" ID="ID_1852750941" MODIFIED="1472122409477" TEXT="sollte keine sinnlosen Operationen verlangen"/>
|
|
</node>
|
|
<node CREATED="1472122416040" ID="ID_1497249607" MODIFIED="1575133339504" TEXT="Analog zu den Primitiven in TreeDiffBinding_test">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das ist ein Versuch, den Code für den Leser verständlich zu halten.
|
|
</p>
|
|
<p>
|
|
Die Idee ist, daß es einen high-level Unit-Test gibt, der die gesamte Diff-Anwendung durchspielt
|
|
</p>
|
|
<p>
|
|
und dazu passend einen low-level Unit-Test, der analog die gleichen Operationen macht,
|
|
</p>
|
|
<p>
|
|
allerdings direkt auf dem TreeDiff-Interface durch Aufruf der passenden Primitiv-Operaionen.
|
|
</p>
|
|
<p>
|
|
Letztere müssen für jede Art von "onion-layer" (konkretes Binding) erneut implementiert
|
|
</p>
|
|
<p>
|
|
und daher auch jeweils eigens per Unit-Test abgedeckt werden.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1472122581698" ID="ID_646408964" MODIFIED="1575133339521" TEXT="sehr komplexes Binding auf privaten Datentyp">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist hier sinnvoll. Das Binding sollte komplexer sein,
|
|
</p>
|
|
<p>
|
|
als in der Praxis auftretende Bindings. Warum? Weil letztere immer etwas einseitg sind
|
|
</p>
|
|
<p>
|
|
und damit Abkürzungen im Code-Pfad ausnützen. Die Gefahr schlummert aber im Zusammenspiel
|
|
</p>
|
|
<p>
|
|
der konkreten Bindings mit mehreren "onion layers"!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465428871136" ID="ID_1530542113" MODIFIED="1512926192131" TEXT="integration mehrerer Bindungs-Layer">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1469918339329" ID="ID_1268899355" MODIFIED="1576204739930" TEXT="geplant: DiffVirtualisedApplication_test">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1469918356432" ID="ID_402479849" MODIFIED="1469918363427" TEXT="Selector korrekt integrieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1465428882150" ID="ID_1713615701" MODIFIED="1512926192132" TEXT="komplexer Integrationstest"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1458850101524" HGAP="-22" ID="ID_233819266" MODIFIED="1512926192133" TEXT="TODO" VSHIFT="29">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1458850122091" ID="ID_558028717" MODIFIED="1512926192134" TEXT="Collection-Binding: bessere Fehlermeldungen">
|
|
<node CREATED="1458850141920" ID="ID_1678218183" MODIFIED="1575133339634" TEXT="bei Signatur-Mismatch">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es ist sehr verwirrend, welche Signatur denn nun die Lambdas haben müssen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1678218183" ENDARROW="Default" ENDINCLINATION="176;0;" ID="Arrow_ID_1136171372" SOURCE="ID_65072201" STARTARROW="None" STARTINCLINATION="176;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1458850154575" ID="ID_1092417051" MODIFIED="1575133339650" TEXT="wenn der Default-Matcher greift">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es kann keinen Default-Matcher geben....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458850212503" ID="ID_1633140516" MODIFIED="1472498583464" TEXT="Signaturen für Lambdas dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1465860661877" ID="ID_1725052487" MODIFIED="1472498127725" TEXT="Builder-API für Attribut-Binding dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1465860672852" ID="ID_1572924206" MODIFIED="1512926192134" TEXT="Variante zum Attribut-Binding, wobei die Attribut-ID als GenNode::ID gegeben ist">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1472498724880" ID="ID_1915142911" MODIFIED="1472498733392" TEXT="für später">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1472498734359" ID="ID_1700021018" MODIFIED="1472498742262" TEXT="brauchen wir das wirklich">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1460847222865" ID="ID_1183333475" MODIFIED="1575133339750" TEXT="abstrakte operationale Semantik der Diff-Anwendung dokumentieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sonst wird niemand Lambdas bereitstellen können, oder gar Diff-Nachrichten erzeugen.
|
|
</p>
|
|
<p>
|
|
Das ist nun kein spezielles Problem der gewählten Implementierungs-Technik, sondern rührt daher,
|
|
</p>
|
|
<p>
|
|
daß der Client hier eigentlich ein Protokoll implementieren muß.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1458850263688" ID="ID_1575858667" MODIFIED="1512926192135" TEXT="Zusammenführen">
|
|
<node CREATED="1458850294083" ID="ID_1035255319" MODIFIED="1458850302901" TEXT="der normale GenNode-Applikator"/>
|
|
<node CREATED="1458850282285" ID="ID_315551572" MODIFIED="1512926192135" TEXT="Prüfen ob sinnvoll">
|
|
<node CREATED="1458850328775" ID="ID_640982298" MODIFIED="1458850333475" TEXT="Indirektionen"/>
|
|
<node CREATED="1458850334110" ID="ID_1172428601" MODIFIED="1458850338898" TEXT="Speicherbedarf"/>
|
|
<node CREATED="1458850339413" ID="ID_317541225" MODIFIED="1458850359702" TEXT="Aufwand bei der Verwendung"/>
|
|
</node>
|
|
<node CREATED="1458850306506" ID="ID_1166040145" MODIFIED="1458850323212" TEXT="durch Binding für Tree-Applikator ersetzen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1461968295826" ID="ID_832194713" MODIFIED="1512926192135" TEXT="prüfen: soll das »AFTER«-Verb aus der Sprache entfernt werden">
|
|
<linktarget COLOR="#592379" DESTINATION="ID_832194713" ENDARROW="Default" ENDINCLINATION="577;0;" ID="Arrow_ID_1785459194" SOURCE="ID_721485398" STARTARROW="Default" STARTINCLINATION="1205;231;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1461968428712" ID="ID_1763138890" MODIFIED="1461968442674" TEXT="es ist nützlich für handgeschriegbene Diffs"/>
|
|
<node CREATED="1461968443334" ID="ID_269699254" MODIFIED="1461968454521" TEXT="es verträgt sich nicht mit gemischten Kindern"/>
|
|
<node CREATED="1465428190234" ID="ID_1562546651" MODIFIED="1512926192136" TEXT="Kompromiß">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1562546651" ENDARROW="Default" ENDINCLINATION="-27;14;" ID="Arrow_ID_477931579" SOURCE="ID_1962067597" STARTARROW="None" STARTINCLINATION="139;3;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1465428196730" ID="ID_1910351001" MODIFIED="1465428204548" TEXT="belassen"/>
|
|
<node CREATED="1465428205352" ID="ID_28950544" MODIFIED="1465428215635" TEXT="akzeptieren, daß es nicht immer anwendbar ist"/>
|
|
<node CREATED="1465428216271" ID="ID_814487938" MODIFIED="1465428234145" TEXT="die generische Variante "after Ref::END" ist sehr gut"/>
|
|
<node CREATED="1465428236860" ID="ID_866203929" MODIFIED="1465428248614" TEXT="speziell Attribut-Binding unterstützt zur generische Variante"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1469545751885" ID="ID_1433722735" MODIFIED="1469545906061" TEXT="Namensgebung für generisches Mutator-Binding">
|
|
<arrowlink COLOR="#7c4b8e" DESTINATION="ID_1238563884" ENDARROW="Default" ENDINCLINATION="-438;877;" ID="Arrow_ID_701265417" STARTARROW="Default" STARTINCLINATION="2134;135;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1472216217388" HGAP="21" ID="ID_1534804117" MODIFIED="1512926192136" TEXT="Semantik der Diff-Sprache" VSHIFT="5">
|
|
<node CREATED="1472216261102" ID="ID_1793923006" MODIFIED="1472216264937" TEXT="sinnvoll definiert"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1472216265486" ID="ID_936601452" MODIFIED="1512926192137" TEXT="später re-evaluieren (Ticket #996)">
|
|
<node CREATED="1472216306208" ID="ID_1962067597" MODIFIED="1512926192137" TEXT="AFTER">
|
|
<arrowlink DESTINATION="ID_1562546651" ENDARROW="Default" ENDINCLINATION="-27;14;" ID="Arrow_ID_477931579" STARTARROW="None" STARTINCLINATION="139;3;"/>
|
|
<node CREATED="1473040688153" ID="ID_1832205907" MODIFIED="1473040722530" TEXT="bleibt vorerst erhalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1473040705207" ID="ID_1976880201" MODIFIED="1473040710378" TEXT="kann sinnvoll implementiert werden"/>
|
|
<node CREATED="1473040711582" ID="ID_1725936766" MODIFIED="1473040717859" TEXT="ist sehr nützlich">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472219973288" ID="ID_827760350" MODIFIED="1512926192139" TEXT="Ref::THIS">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1472220009699" ID="ID_668003504" MODIFIED="1472220054293">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>wenn überhaupt, </i>dann im Matcher im Binding-Layer implementieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1473040485789" ID="ID_1455054542" MODIFIED="1575133340122" TEXT="nein: führt zu verworrener Implementierung bzw. ist unmöglich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir haben nun mehrere Layer,
|
|
</p>
|
|
<p>
|
|
und der Selector kann einfach anhand von Ref::THIS keine sinnvolle Entscheidung treffen.
|
|
</p>
|
|
<p>
|
|
Daher versuchen dann alle Layer dieses Element zu behandeln, oder gar keiner
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und da der Selector <i>nur die Spec anschauen darf, </i>läßt sich das auch nachher nicht mehr korrigieren
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Daher habe ich mich <b>entschlossen, dieses Sprachkonstrukt zu entfernen</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1473040662653" ID="ID_618762286" MODIFIED="1473040680738">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>entfernt</b>, da schlechtes Design
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1472216312295" ID="ID_1775308081" MODIFIED="1512926192140" TEXT="Ref::CHILD">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1472219981838" ID="ID_574042505" MODIFIED="1472219987506" TEXT="was genau soll das sein??"/>
|
|
<node CREATED="1472219987983" ID="ID_1555757607" MODIFIED="1472219997032" TEXT="was ist der Unterschied zu Ref::THIS"/>
|
|
<node CREATED="1472219998405" ID="ID_581974405" MODIFIED="1472220005255" TEXT="funktioniert das überhaupt noch??"/>
|
|
<node CREATED="1473040662653" ID="ID_1276623149" MODIFIED="1473040680738">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>entfernt</b>, da schlechtes Design
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458850387823" HGAP="19" ID="ID_425389577" MODIFIED="1512926192141" TEXT="allgemein" VSHIFT="13">
|
|
<node CREATED="1458850397158" ID="ID_824208782" MODIFIED="1512926192141" TEXT="GenNode">
|
|
<node CREATED="1458850406396" ID="ID_1751784080" MODIFIED="1512926192141" TEXT="string-Repräsentation der Payload">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1473352291785" ID="ID_1072989957" MODIFIED="1473352300715" TEXT="vorerst nicht benötigt"/>
|
|
<node CREATED="1473352306190" ID="ID_1614247363" MODIFIED="1473352310810" TEXT="wäre besser daß nicht"/>
|
|
<node CREATED="1473352312206" ID="ID_182553929" MODIFIED="1473352316377" TEXT="Entscheidung vertagt"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1458850422587" ID="ID_687485992" MODIFIED="1458851592866" TEXT="Metafunktion für mögliche Payload">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1458850437017" ID="ID_374347760" MODIFIED="1512926192142" TEXT="Planting-Handle">
|
|
<node CREATED="1458850456134" ID="ID_1314676676" MODIFIED="1575133340337" TEXT="Zwischenschicht einziehen im TreeMutator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anscheinend nicht notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1458850463389" ID="ID_1264284471" MODIFIED="1473352257250" TEXT="Generische Impl herauslösen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1458850471228" ID="ID_1582586681" MODIFIED="1473352333631" TEXT="Unit-Test hierfür">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576203266079" HGAP="-33" ID="ID_814331726" MODIFIED="1576203320920" TEXT="Probleme" VSHIFT="81">
|
|
<edge COLOR="#a35858" STYLE="linear"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576203334745" ID="ID_469932361" MODIFIED="1576203344231" TEXT="STL Collection-Binding">
|
|
<node COLOR="#435e98" CREATED="1576203346447" ID="ID_233848651" MODIFIED="1576281488712" TEXT=""wackelig" für manche Typen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1576203375592" ID="ID_1979742309" MODIFIED="1576203381993" TEXT="std::Map">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576203383258" ID="ID_854221294" MODIFIED="1576204502727" STYLE="fork" TEXT="eigentlich ein Widerspruch">
|
|
<arrowlink COLOR="#b85f4e" DESTINATION="ID_1285123321" ENDARROW="Default" ENDINCLINATION="-735;0;" ID="Arrow_ID_1644325647" STARTARROW="None" STARTINCLINATION="-651;70;"/>
|
|
</node>
|
|
<node CREATED="1576203390673" ID="ID_1579012788" MODIFIED="1576203404067" TEXT="praktisch aber bequem"/>
|
|
<node CREATED="1576203728291" ID="ID_42201574" MODIFIED="1576203790175" TEXT="code-teschnisch problematisch">
|
|
<arrowlink COLOR="#e69f98" DESTINATION="ID_1611724080" ENDARROW="Default" ENDINCLINATION="-741;702;" ID="Arrow_ID_1638749746" STARTARROW="None" STARTINCLINATION="1526;117;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1576203459624" ID="ID_789920101" MODIFIED="1576204104302" TEXT="»Attribut-Map« in MockElm">
|
|
<arrowlink COLOR="#c48c7d" DESTINATION="ID_275833424" ENDARROW="Default" ENDINCLINATION="-975;32;" ID="Arrow_ID_454192352" STARTARROW="None" STARTINCLINATION="937;102;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1576281451040" ID="ID_256253463" MODIFIED="1576281485757" TEXT="führe ContainerTraits ein">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1576281457704" ID="ID_1923676658" MODIFIED="1576281466799" TEXT="organisiere den Zugriff über wenige Primitive"/>
|
|
<node CREATED="1576281467534" ID="ID_141840018" MODIFIED="1576281475848" TEXT="recentElmRawIter"/>
|
|
<node CREATED="1576281477030" ID="ID_1772245201" MODIFIED="1576281484407" TEXT="emplace-Operation"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582387518143" FOLDED="true" ID="ID_1511785718" MODIFIED="1582402573961" TEXT="Aufspiel-Fehler beim 2.Timeline-Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582387575560" ID="ID_1823810514" MODIFIED="1582387638910" TEXT="Reihenfolge egal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es ist wohl nicht ein spezieller Diff. Es tritt sogar auf, wenn man zweimal den gleichen Diff schickt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582393056148" ID="ID_229440778" MODIFIED="1582393060752" TEXT="Beobachtungen">
|
|
<node CREATED="1582393085696" ID="ID_1075791214" MODIFIED="1582393107401" TEXT="DiffApplicationStrategie::completeDiffApplication()">
|
|
<node CREATED="1582393112229" ID="ID_1475137884" MODIFIED="1582393122112" TEXT="ruft treeMutator_-> completeScope"/>
|
|
</node>
|
|
<node CREATED="1582393123699" ID="ID_1039117196" MODIFIED="1582393142133" TEXT="treeMutator_ ist ein ChildCollectionMutator"/>
|
|
<node CREATED="1582393142889" ID="ID_1845205771" MODIFIED="1582393160850" TEXT="beim 2.Mal ist noch ein Element im contentBuffer">
|
|
<node CREATED="1582393170325" ID="ID_1722906303" MODIFIED="1582393180658" TEXT="und zwar ein TimelineGui"/>
|
|
<node CREATED="1582393189518" ID="ID_1633116205" MODIFIED="1582394694300" TEXT="HA! das weitere Element im anderen Tab?">
|
|
<arrowlink COLOR="#d51f26" DESTINATION="ID_679335170" ENDARROW="Default" ENDINCLINATION="78;0;" ID="Arrow_ID_1157526655" STARTARROW="None" STARTINCLINATION="51;30;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1582393210408" ID="ID_1214546082" MODIFIED="1582402538776" TEXT="wenn diese Hypothese stimmt, dann wäre das gesendete Diff falsch">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582394658942" ID="ID_679335170" MODIFIED="1582394694300" TEXT="so isses">
|
|
<linktarget COLOR="#d51f26" DESTINATION="ID_679335170" ENDARROW="Default" ENDINCLINATION="78;0;" ID="Arrow_ID_1157526655" SOURCE="ID_1633116205" STARTARROW="None" STARTINCLINATION="51;30;"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1582394706704" ID="ID_1236044094" MODIFIED="1582394709051" TEXT="siehe DummySessionConnection::fabricateSeq1"/>
|
|
<node CREATED="1582394712392" ID="ID_1029818508" MODIFIED="1582394730872" TEXT="der Diff fängt ganz naiv an mit "ins(timeline)""/>
|
|
<node CREATED="1582394734004" ID="ID_587085406" MODIFIED="1582394749618" TEXT="es fehlt ein after(Ref::END)">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582402556417" ID="ID_1819542704" MODIFIED="1582402568155" TEXT="kaum macht ma's richtig, schon funktioniert's">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502452581379" FOLDED="true" HGAP="3" ID="ID_1651893758" MODIFIED="1576281567403" TEXT="Darstellung" VSHIFT="31">
|
|
<linktarget COLOR="#afb1bd" DESTINATION="ID_1651893758" ENDARROW="Default" ENDINCLINATION="-1257;0;" ID="Arrow_ID_1786455458" SOURCE="ID_1500100371" STARTARROW="None" STARTINCLINATION="1858;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502452597604" ID="ID_172363215" MODIFIED="1512926192454" TEXT="MutationMessage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502454531772" ID="ID_445867436" MODIFIED="1502454536184" TEXT="abstrakter Iterator"/>
|
|
<node CREATED="1502454536636" ID="ID_643452930" MODIFIED="1502454542390" TEXT="opaque generation context"/>
|
|
<node CREATED="1502499523442" ID="ID_1849662627" MODIFIED="1502499532441" TEXT="verwaltet diesen per shared_ptr">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1502499556422" ID="ID_914381104" MODIFIED="1502499574412" TEXT="convenience- builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1502452625232" ID="ID_328973433" MODIFIED="1512926192456" TEXT="Diagnose">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502454361347" ID="ID_1601614353" MODIFIED="1502550968543" TEXT="toString">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1502454303107" ID="ID_712801862" MODIFIED="1575133360185" TEXT="Problem: Pull-Prinzip">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Diff ist eine abstrakte Quelle,
|
|
</p>
|
|
<p>
|
|
die nur einmal verbraucht werden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502454341085" ID="ID_1620101988" MODIFIED="1502454351680" TEXT="Lösung: Adapter mit Snapshot"/>
|
|
<node CREATED="1502454374017" ID="ID_355618162" MODIFIED="1502454376725" TEXT="Konsequenz">
|
|
<node CREATED="1502454377713" ID="ID_1122938295" MODIFIED="1502454386323" TEXT="normaler Diff bleibt opaque"/>
|
|
<node CREATED="1502454387047" ID="ID_1949389197" MODIFIED="1502454395770" TEXT="Dekorator für Tests">
|
|
<node CREATED="1502454398686" ID="ID_1736428769" MODIFIED="1502454409496" TEXT="Anforderung: drop-in"/>
|
|
<node CREATED="1502454410012" ID="ID_364935696" MODIFIED="1575133360305" TEXT="durch Allokations-Kette lösen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dekorator-Prinzip.
|
|
</p>
|
|
<p>
|
|
Paßt hier, da IterSource genau dieses Vorgehen nahelegt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1502550828691" ID="ID_382976334" MODIFIED="1575133360325" TEXT="fest eingebaut">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
MutationMessage::updateDiagnostics()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1502550853144" ID="ID_1494004239" MODIFIED="1502550857267" TEXT="Snapshot"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1502550876621" ID="ID_146736971" MODIFIED="1502550911076" TEXT="operationale Semantik">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1502550912144" ID="ID_1989059056" MODIFIED="1502550917571" TEXT="Seiteneffekt"/>
|
|
<node CREATED="1502550918087" ID="ID_1305779780" MODIFIED="1502550932761" TEXT="DiffGenerator wird gepullt"/>
|
|
<node CREATED="1502550933253" ID="ID_1994991409" MODIFIED="1575133360409" TEXT="immer nur Rest-Sequenz sichtabar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...diejenige, die zum Zeitpunkt des updateDiagnostics() noch anstand
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1502454451191" ID="ID_1968344683" MODIFIED="1502454502337" TEXT="pretty-print">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1502454475268" ID="ID_1399873401" MODIFIED="1502454479199" TEXT="für Systemdiagnose"/>
|
|
<node CREATED="1502454479907" ID="ID_234469818" MODIFIED="1502454491525" TEXT="lesbare Formattierung"/>
|
|
<node CREATED="1502454492162" ID="ID_983774503" MODIFIED="1502454496237" TEXT="auf später vertagt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1460934597764" HGAP="223" ID="ID_1014666775" MODIFIED="1576202239196" TEXT="Review" VSHIFT="32">
|
|
<font NAME="SansSerif" SIZE="15"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1460934670043" ID="ID_1299827687" MODIFIED="1518487921095" TEXT="später zu überprüfen">
|
|
<node CREATED="1460934686017" ID="ID_900313780" MODIFIED="1518487921095" TEXT="Klarheit"/>
|
|
<node CREATED="1460934698430" ID="ID_1527149180" MODIFIED="1518487921095" TEXT="praktischer Kontext"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1460934704022" ID="ID_369718039" MODIFIED="1518487921095" TEXT="fragwürdig">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1460934726315" ID="ID_865694069" MODIFIED="1518487921095" TEXT="Immutabilität">
|
|
<node CREATED="1460934748064" ID="ID_321786426" MODIFIED="1518487921095" TEXT="keine klare Linie"/>
|
|
<node CREATED="1460934753440" ID="ID_44139402" MODIFIED="1518487921095" TEXT="einerseits ja, feste Datenwerte"/>
|
|
<node CREATED="1460934764830" ID="ID_594837209" MODIFIED="1518487921095" TEXT="dann aber doch Assignment"/>
|
|
<node CREATED="1460934771253" ID="ID_1299180901" MODIFIED="1518487921095" TEXT="und ein Gemurkse bei den Records"/>
|
|
</node>
|
|
<node CREATED="1460934785067" ID="ID_945933568" MODIFIED="1518487921095" TEXT="Abkürzungen in der Sprache">
|
|
<node CREATED="1460934793738" ID="ID_1602968303" MODIFIED="1518487921095" TEXT="Ref::CHILD"/>
|
|
<node CREATED="1460934799137" ID="ID_1189559717" MODIFIED="1518487921095" TEXT="Ref::THIS"/>
|
|
<node CREATED="1460934802385" ID="ID_961490107" MODIFIED="1518487921095" TEXT="Ref::ATTRIBS"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1443740543812" HGAP="17" ID="ID_1766169268" MODIFIED="1518487921095" TEXT="Tests" VSHIFT="20">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1443740549220" ID="ID_167459949" MODIFIED="1518487921095" TEXT="List-Diff">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443740554315" ID="ID_1970336632" MODIFIED="1518487921095" TEXT="Anwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1443740556587" ID="ID_1725890953" MODIFIED="1518487921095" TEXT="Erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443740566042" FOLDED="true" ID="ID_632827470" MODIFIED="1576204707968" TEXT="Baum-Diff">
|
|
<icon BUILTIN="prepare"/>
|
|
<node CREATED="1443740576744" ID="ID_335386387" MODIFIED="1525124215410" TEXT="Anwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443741563019" HGAP="-20" ID="ID_1944319966" MODIFIED="1512926192458" TEXT="Demo-Beispiel" VSHIFT="8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1443741578993" ID="ID_318844233" MODIFIED="1443741582069" TEXT="INIT"/>
|
|
<node CREATED="1443741591616" ID="ID_1102292452" MODIFIED="1443741607633" TEXT="INS + MUT _THIS_"/>
|
|
<node CREATED="1443741620052" ID="ID_1065499540" MODIFIED="1443741633054" TEXT="MOD"/>
|
|
<node CREATED="1443741736636" ID="ID_1110914687" MODIFIED="1443741738320" TEXT="PERM"/>
|
|
<node CREATED="1443741711120" ID="ID_1289424857" MODIFIED="1443741714651" TEXT="Rekursion"/>
|
|
</node>
|
|
<node CREATED="1443740607172" HGAP="21" ID="ID_1836453078" MODIFIED="1512926192458" TEXT="INIT" VSHIFT="14">
|
|
<node CREATED="1443740625649" ID="ID_1466659920" MODIFIED="1443740670333" TEXT="Attribute + Kinder"/>
|
|
<node CREATED="1443740621098" ID="ID_987166264" MODIFIED="1443740625134" TEXT="nur Kinder"/>
|
|
<node CREATED="1443740615699" ID="ID_93430092" MODIFIED="1443740679948" TEXT="Attribute"/>
|
|
</node>
|
|
<node CREATED="1443741317885" ID="ID_1933201882" MODIFIED="1512926192458" TEXT="NAV">
|
|
<node CREATED="1443741324236" ID="ID_1812765289" MODIFIED="1512926192459" TEXT="PICK">
|
|
<node CREATED="1443741332691" ID="ID_1059350985" MODIFIED="1443741335518" TEXT="Attribut"/>
|
|
<node CREATED="1443741337786" ID="ID_70415473" MODIFIED="1443741342997" TEXT="letztes Attribut"/>
|
|
<node CREATED="1443741507347" ID="ID_1882468426" MODIFIED="1443741513958" TEXT="nicht vorhandenes"/>
|
|
<node CREATED="1444349824563" ID="ID_572700596" MODIFIED="1444349836702" TEXT="anonym: Ref::CHILD"/>
|
|
</node>
|
|
<node CREATED="1443741349576" ID="ID_1257145184" MODIFIED="1512926192460" TEXT="AFTER">
|
|
<node CREATED="1443741365526" ID="ID_1412112386" MODIFIED="1443741372089" TEXT="Attribut"/>
|
|
<node CREATED="1443741373013" ID="ID_1922596569" MODIFIED="1512926192460" TEXT="letztes Attribut">
|
|
<node CREATED="1443741379924" ID="ID_1574470178" MODIFIED="1443741382960" TEXT="Attribut anfügen"/>
|
|
<node CREATED="1443741383579" ID="ID_69718214" MODIFIED="1443741387039" TEXT="Kind anfügen"/>
|
|
</node>
|
|
<node CREATED="1443741399145" ID="ID_625711902" MODIFIED="1443741409900" TEXT="Kind"/>
|
|
<node CREATED="1443741519689" ID="ID_1627922512" MODIFIED="1443741523076" TEXT="nicht vorhandenes"/>
|
|
<node CREATED="1443742264333" ID="ID_1331320583" MODIFIED="1443742268596" TEXT="_END_">
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
<node CREATED="1443741448683" ID="ID_1149106472" MODIFIED="1443741456637" TEXT="Frage: wrap erlauben">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443740818144" ID="ID_1606823522" MODIFIED="1512926192460" TEXT="INS">
|
|
<node CREATED="1443740822151" ID="ID_1509080074" MODIFIED="1512926192461" TEXT="Attribut">
|
|
<node CREATED="1443740849731" ID="ID_1736662710" MODIFIED="1443740851743" TEXT="vorne"/>
|
|
<node CREATED="1443740852219" ID="ID_546949723" MODIFIED="1443740853615" TEXT="hinten"/>
|
|
<node CREATED="1443740854491" ID="ID_730025656" MODIFIED="1443740858070" TEXT="Duplikat"/>
|
|
<node CREATED="1443740862570" ID="ID_899234602" MODIFIED="1443740866621" TEXT="Typ-Attribut"/>
|
|
<node CREATED="1443740918266" ID="ID_1583583367" MODIFIED="1443740923149" TEXT="Attribut in Kind-Zone"/>
|
|
</node>
|
|
<node CREATED="1443740870057" ID="ID_1029684307" MODIFIED="1512926192461" TEXT="Kind">
|
|
<node CREATED="1443740874416" ID="ID_1507242638" MODIFIED="1443740884674" TEXT="nach dem letzten Attribut"/>
|
|
<node CREATED="1443740885287" ID="ID_839165655" MODIFIED="1443740909455" TEXT="im Scope"/>
|
|
<node CREATED="1443740967099" ID="ID_1771095243" MODIFIED="1443740976438" TEXT="noch in der Attribut-Zone"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443740986217" ID="ID_1868954463" MODIFIED="1512926192462" TEXT="DEL">
|
|
<node CREATED="1443740988710" ID="ID_1745624753" MODIFIED="1512926192462" TEXT="Attribut">
|
|
<node CREATED="1443740997760" ID="ID_1984040083" MODIFIED="1443741004867" TEXT="normal"/>
|
|
<node CREATED="1443741005718" ID="ID_1595612872" MODIFIED="1443741014489" TEXT="in falscher Ordnung"/>
|
|
<node CREATED="1443741015221" ID="ID_587604738" MODIFIED="1443741030671" TEXT="Duplikat"/>
|
|
</node>
|
|
<node CREATED="1443741060111" ID="ID_1609626537" MODIFIED="1512926192462" TEXT="Kind">
|
|
<node CREATED="1443741062863" ID="ID_1087964841" MODIFIED="1443741072913" TEXT="normal"/>
|
|
<node CREATED="1443741074333" ID="ID_625561892" MODIFIED="1443741087863" TEXT="noch in der Attribut-Zone"/>
|
|
<node CREATED="1443741088619" ID="ID_290604972" MODIFIED="1443741095374" TEXT="in falscher Ordnung"/>
|
|
</node>
|
|
<node CREATED="1443741637530" ID="ID_397839136" MODIFIED="1443741640949" TEXT="Teilbaum"/>
|
|
</node>
|
|
<node CREATED="1443741106905" ID="ID_1001938821" MODIFIED="1512926192463" TEXT="PERM">
|
|
<node CREATED="1443741110392" ID="ID_513982563" MODIFIED="1443741112764" TEXT="Attribut"/>
|
|
<node CREATED="1443741113584" ID="ID_1631505651" MODIFIED="1512926192463" TEXT="Kind">
|
|
<node CREATED="1443741137141" ID="ID_300777204" MODIFIED="1443741140008" TEXT="normal"/>
|
|
<node CREATED="1443741140596" ID="ID_1663721251" MODIFIED="1443741147135" TEXT="mitten in Attribut-Zone"/>
|
|
<node CREATED="1443741147491" ID="ID_1992350599" MODIFIED="1443741152822" TEXT="am Ende der Attribut-Zone"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1443741163385" ID="ID_1770431599" MODIFIED="1512926192463" TEXT="MUT">
|
|
<node CREATED="1443741167465" ID="ID_1585288084" MODIFIED="1512926192464" TEXT="Objekt by-name">
|
|
<node CREATED="1443741182559" ID="ID_1263613083" MODIFIED="1443741185922" TEXT="Attribut"/>
|
|
<node CREATED="1443741186486" ID="ID_1416713573" MODIFIED="1443741188010" TEXT="Kind"/>
|
|
<node CREATED="1443741654263" ID="ID_68796444" MODIFIED="1443741686295" TEXT="Teilbaum umordnen"/>
|
|
</node>
|
|
<node CREATED="1443741189590" ID="ID_407606511" MODIFIED="1512926192464" TEXT="Objekt _THIS_">
|
|
<node CREATED="1443741204516" ID="ID_899173442" MODIFIED="1443741207247" TEXT="nach INS"/>
|
|
<node CREATED="1443741212547" ID="ID_979817893" MODIFIED="1443741225989" TEXT="nach PICK"/>
|
|
<node CREATED="1443741226673" ID="ID_1242761745" MODIFIED="1443741229165" TEXT="nach AFTER"/>
|
|
<node CREATED="1443741229984" ID="ID_926730195" MODIFIED="1443741233636" TEXT="nach FIND"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1460753406868" HGAP="-18" ID="ID_289459316" MODIFIED="1502593581651" TEXT="Spezialfälle" VSHIFT="25">
|
|
<node COLOR="#338800" CREATED="1460753417178" ID="ID_1333254858" MODIFIED="1512926192465" TEXT="native bindings">
|
|
<linktarget COLOR="#639ad5" DESTINATION="ID_1333254858" ENDARROW="Default" ENDINCLINATION="1091;0;" ID="Arrow_ID_1011836019" SOURCE="ID_10780308" STARTARROW="None" STARTINCLINATION="1150;185;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1460753433312" ID="ID_94456036" MODIFIED="1502593626008" TEXT="Binden an Collection von Primitiven">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1460753444735" ID="ID_1100731476" MODIFIED="1502593621731" TEXT="Binden an Collection von intelligenten Spezialtypen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1460753460940" ID="ID_677690723" MODIFIED="1502593616768" TEXT="Komposit aus Attribut-Bindung und Kinder-Collection-Bindung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448063880238" ID="ID_159570161" MODIFIED="1557498707235" TEXT="Zyklus">
|
|
<node CREATED="1448063893293" ID="ID_1135705575" MODIFIED="1557498707235" TEXT="initial"/>
|
|
<node CREATED="1448063896300" ID="ID_1403759288" MODIFIED="1557498707235" TEXT="Zuordnung"/>
|
|
<node CREATED="1448063902387" ID="ID_1822852634" MODIFIED="1557498707235" TEXT="Aktion"/>
|
|
<node CREATED="1448063908243" ID="ID_474614648" MODIFIED="1557498707235" TEXT="Update"/>
|
|
<node CREATED="1448063913618" ID="ID_1967302094" MODIFIED="1557498707235" TEXT="Ende"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448314834155" ID="ID_1725514536" MODIFIED="1557498707235" POSITION="right" TEXT="Integral">
|
|
<node CREATED="1448315011484" ID="ID_867104544" MODIFIED="1557498707235" TEXT="generisch">
|
|
<node CREATED="1448315015107" FOLDED="true" ID="ID_1900900399" MODIFIED="1561827465884" TEXT="JSON">
|
|
<node CREATED="1448315031553" ID="ID_1177387568" MODIFIED="1518487921095" TEXT="parser">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1448315067524" ID="ID_430746611" MODIFIED="1561827465890" TEXT="Libs">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1448315070908" ID="ID_1328571674" MODIFIED="1518487921095" TEXT="JSON-C">
|
|
<node CREATED="1448318526124" ID="ID_737325795" MODIFIED="1518487921095" TEXT="einfach"/>
|
|
<node CREATED="1448318531644" ID="ID_745699377" MODIFIED="1518487921095" TEXT="robust"/>
|
|
<node CREATED="1448318534203" ID="ID_1415146809" MODIFIED="1518487921095" TEXT="grottig"/>
|
|
</node>
|
|
<node CREATED="1448316910322" ID="ID_677006595" MODIFIED="1518487921095" TEXT="JsonCpp">
|
|
<node CREATED="1448318540363" ID="ID_269049852" MODIFIED="1518487921095" TEXT="sehr weit verbreitet"/>
|
|
<node CREATED="1448318569151" ID="ID_239373731" MODIFIED="1518487921095">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>schmerzloses </i>C++ API
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448318701621" ID="ID_1339095142" MODIFIED="1518487921095" TEXT="unterstützt Builder für Integration in den Parse-Vorgang"/>
|
|
<node CREATED="1448318726098" ID="ID_1386753436" MODIFIED="1518487921095" TEXT="unterstützt Kommentarte (non-Standard)"/>
|
|
<node CREATED="1448318671009" ID="ID_1620559470" MODIFIED="1518487921095" TEXT="kann als eine große CPP-Datei eingebunden werden"/>
|
|
<node CREATED="1448319454226" ID="ID_108762123" MODIFIED="1518487921095">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Performance: guter Schnitt (etw. besser als boost spirit)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448320352804" ID="ID_1738484079" MODIFIED="1518487921095" TEXT="MIT"/>
|
|
</node>
|
|
<node CREATED="1448316923520" ID="ID_1207744350" MODIFIED="1518487921095" TEXT="rapidjson">
|
|
<node CREATED="1448320356547" ID="ID_18433884" MODIFIED="1518487921095" TEXT="MIT / teils BSD"/>
|
|
<node CREATED="1448320418619" ID="ID_972456274" MODIFIED="1518487921095" TEXT="gilt als schnell und effizient"/>
|
|
<node CREATED="1448320428906" ID="ID_279600641" MODIFIED="1518487921095">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hat ein DOM-API <i>und</i> ein SAX-artiges API
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1448320473828" ID="ID_681519615" MODIFIED="1576282357974" TEXT="header-only, self-contained, keine Abhängigkeiten!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt: <b>nicht einmal</b> abhängig von der STL
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448320555049" ID="ID_1836540415" MODIFIED="1518487921095" TEXT="erweiterter Unicode-Support, incl. recoding beim Parsen"/>
|
|
<node CREATED="1448321567452" ID="ID_933252727" MODIFIED="1576282357974" TEXT="kann auch in-situ parsen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie gson
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448320545523" ID="ID_298176210" MODIFIED="1518487921095" TEXT="vollständig, incl Ersetzungen"/>
|
|
<node CREATED="1448321598848" ID="ID_1151875949" MODIFIED="1518487921095" TEXT="eigener Block-Allokator, ersetzbar"/>
|
|
</node>
|
|
<node CREATED="1448318965627" ID="ID_453761706" MODIFIED="1576282357973" TEXT="vjson / gason">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vjson war Google Code;
|
|
</p>
|
|
<p>
|
|
nach dem Umzug auf Github heißt es gason
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1448319925356" ID="ID_1589130421" MODIFIED="1576282357973" TEXT="angeblich ziemlich schnell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
lt. eigenen Benchmakrs deutlich schneller als rapidjson, welches eigentlich immer als der "schnelle" JSON-Parser gilt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448319936915" ID="ID_1093677957" MODIFIED="1518487921095" TEXT="C++, aber ehr C-artiges API"/>
|
|
<node CREATED="1448319955328" ID="ID_534293846" MODIFIED="1518487921095" TEXT="type-tag, switch-on-type"/>
|
|
<node CREATED="1448319963711" ID="ID_1858072437" MODIFIED="1576282357972" TEXT="Parser ist destruktiv">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. das Parsen schreibt den Eingabepuffer um, und Strings bleiben einfach liegen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448319973830" ID="ID_1495739376" MODIFIED="1518487921096" TEXT="Werte werden in IEEE double NaN geboxt"/>
|
|
<node CREATED="1448320035173" ID="ID_226864203" MODIFIED="1518487921096" TEXT="eigener Block-Allokator"/>
|
|
<node CREATED="1448320365290" ID="ID_1044522194" MODIFIED="1518487921096" TEXT="MIT"/>
|
|
</node>
|
|
<node CREATED="1448315073819" ID="ID_280907535" MODIFIED="1518487921096" TEXT="boost spirit">
|
|
<node CREATED="1448316823037" ID="ID_726858418" MODIFIED="1518487921096" TEXT="reiner parser"/>
|
|
<node CREATED="1448321185310" ID="ID_180554028" MODIFIED="1518487921096" TEXT="kann direkt in Vector parsen"/>
|
|
<node CREATED="1448316826444" ID="ID_263014084" MODIFIED="1518487921096" TEXT="grammatik via metaprogrmming"/>
|
|
<node CREATED="1448316840474" ID="ID_1878535070" MODIFIED="1518487921096" TEXT="code bloat, vor allem in Debug-builds">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1448321146283" ID="ID_1257942632" MODIFIED="1576282357972" TEXT="Veröffentlichung undurchsichtig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kein Repo auffindbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448315077731" ID="ID_439331220" MODIFIED="1518487921096" TEXT="boost property-tree">
|
|
<node CREATED="1448316790553" ID="ID_1199102717" MODIFIED="1518487921096" TEXT="einfaches API"/>
|
|
<node CREATED="1448316796240" ID="ID_1402766358" MODIFIED="1518487921096" TEXT="parst in einen boost::property_tree"/>
|
|
<node CREATED="1448316803799" ID="ID_534763461" MODIFIED="1518487921096" TEXT="keine Typisierung">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448320959060" ID="ID_937046843" MODIFIED="1518487921096" TEXT="Entscheidung">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1448320963067" ID="ID_824752283" MODIFIED="1538870530138" TEXT="rapidjson">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1448320987776" ID="ID_545245790" MODIFIED="1518487921096" TEXT="Begründung...">
|
|
<node CREATED="1448321001518" ID="ID_671858484" MODIFIED="1518487921096">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich will nicht <i>noch ein</i> Objekt-System
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1448321022444" ID="ID_658035448" MODIFIED="1518487921096" TEXT="das SAX-API ist genau, was ich brauche"/>
|
|
<node CREATED="1448321063078" ID="ID_923664235" MODIFIED="1518487921096" TEXT="außerdem klein und schmerzlos"/>
|
|
<node CREATED="1448321614174" ID="ID_1319618589" MODIFIED="1518487921096" TEXT="schönes API, und ist schnell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448315063541" ID="ID_430049414" MODIFIED="1518487921096" TEXT="framework">
|
|
<node CREATED="1448321310054" ID="ID_180974747" MODIFIED="1518487921096" TEXT="Forderungen">
|
|
<node CREATED="1448321258189" ID="ID_1374008180" MODIFIED="1518487921096" TEXT="diff::Record als Container"/>
|
|
<node CREATED="1448321329691" ID="ID_982254628" MODIFIED="1518487921096" TEXT="Validierung beim Parsen"/>
|
|
<node CREATED="1448321280178" ID="ID_1241470226" MODIFIED="1518487921096" TEXT="Erweiterbarkeit auf Objekt-Serialisieierung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521843763852" FOLDED="true" ID="ID_1208981523" MODIFIED="1557498707235" TEXT="Microbenchmarks">
|
|
<node CREATED="1521843772026" ID="ID_1334641753" MODIFIED="1557498707235" TEXT="selber schreiben">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1521843783161" ID="ID_1151208744" MODIFIED="1557498707235" TEXT="mehrere Threads unterstützen"/>
|
|
<node COLOR="#338800" CREATED="1521843822020" ID="ID_1862348515" MODIFIED="1561827465891" TEXT="Library-Funktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1538870431318" ID="ID_1372513165" MODIFIED="1538870448900" TEXT="lib/test/microbenchmark.hpp"/>
|
|
<node CREATED="1521843838865" ID="ID_1649689781" MODIFIED="1521843944839" TEXT="bekommt eigentlichen Testcode als Lambda">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521843849712" ID="ID_579604510" MODIFIED="1521843940495" STYLE="fork" TEXT="verwendet std::chrono::duration<double>">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521843873173" ID="ID_952548619" MODIFIED="1521843938941" TEXT="mißt micro-Ticks"/>
|
|
<node CREATED="1521843880155" ID="ID_1245721460" MODIFIED="1521843938941" TEXT="Ergebnis fällt in Sekunden"/>
|
|
</node>
|
|
<node CREATED="1521843959433" ID="ID_133306105" MODIFIED="1576282357971" TEXT="verwendet Lumiera's Threading-Framework">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man hätte genausogut std::future und std::async verwenden können.
|
|
</p>
|
|
<p>
|
|
Vorteil von unseren Framework:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wir haben es schon, und wir werden es verwenden, wegen den Thradpools
|
|
</li>
|
|
<li>
|
|
man baut ein Objekt für einen Thread. Das ist explizit und sauber
|
|
</li>
|
|
<li>
|
|
wir haben eine eingebaute Barriere und können unseren Objekt-Monitor nutzen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521843907144" ID="ID_848033940" MODIFIED="1521843935500" TEXT="Ergebnis normieren auf einzelnen Aufruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521843926501" ID="ID_984510403" MODIFIED="1521843934725" TEXT="Ergebnis in Mirkosekunden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521844261439" ID="ID_1538240853" MODIFIED="1576282357970" TEXT="Korrektheit der Zeitangaben verifiziert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habe einen usleep(1000) getimed
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521844101045" ID="ID_1065212487" MODIFIED="1557498707235" TEXT="Erfahrungen">
|
|
<node CREATED="1521844121043" ID="ID_1041692639" MODIFIED="1561827465893" TEXT="Optimizer">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1521844504174" ID="ID_318676926" MODIFIED="1521844520954" TEXT="Optimierung per -O3 ist sehr deutlich meßbar">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521844130561" ID="ID_1541346658" MODIFIED="1521844139739" TEXT="übergebene Lambdas werden tatsächlich ge-inlined"/>
|
|
<node CREATED="1521844157909" ID="ID_1833250915" MODIFIED="1576282357970" TEXT="wenn wir in der Loop messen, messen wir die Aufrufe von chrono::system_clock mit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
daher messen wir die Loop als Ganzes.
|
|
</p>
|
|
<p>
|
|
Es gibt daher keine Möglichkeit, den Loop-Overhead selber zu messen.
|
|
</p>
|
|
<p>
|
|
Er sollte sich aber bei einer Wiederholung im Millionenbereich gut amortisieren
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Außerdem ist ja auch noch der Aufruf des Funktors mit im Spiel, wenngleich der auch typischerweise geinlined wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1521844236539" ID="ID_176799135" MODIFIED="1521844248411" TEXT="tatsächlich verifiziert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521844204015" ID="ID_188310893" MODIFIED="1521844251027" TEXT="Größenordnung 10 ns">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521844141248" ID="ID_328319936" MODIFIED="1521844156769" TEXT="wenn man nicht aufpaßt, wird die ganze Loop wegoptimiert"/>
|
|
<node CREATED="1521844306601" ID="ID_126627605" MODIFIED="1521844338425" TEXT="Beste Lösung">
|
|
<node CREATED="1521844339269" ID="ID_1885600326" MODIFIED="1521844361265">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
volatile Variable <i>außen,</i> im Aufrufkontext
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521844366944" ID="ID_1258575129" MODIFIED="1521844373484" TEXT="Zugriff via Closure und Referenz"/>
|
|
<node CREATED="1521844374503" ID="ID_1548234021" MODIFIED="1521844386090" TEXT="diese Variable mit Konstante vergleichen"/>
|
|
<node CREATED="1521844391605" ID="ID_1603234514" MODIFIED="1521844411462" TEXT="Lokale volatile Variable: Initialisierung kostet +5ns"/>
|
|
<node CREATED="1521844412602" ID="ID_1758142813" MODIFIED="1521844418949" TEXT="Inkrementieren kostet +10ns"/>
|
|
<node CREATED="1521844419657" ID="ID_1892679887" MODIFIED="1576282357969" TEXT="konkurrentes Inkrementieren auf globale Volatile: Faktor 100 !!!!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was sehr schön beweist,
|
|
</p>
|
|
<p>
|
|
daß x86_64 tatsächlich cache-kohärent ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535890757430" ID="ID_3793753" MODIFIED="1557498707235" TEXT="Iterator">
|
|
<node CREATED="1535890775651" ID="ID_333704322" MODIFIED="1573230435834" TEXT="Lumiera Forward Iterator">
|
|
<linktarget COLOR="#3f76e9" DESTINATION="ID_333704322" ENDARROW="Default" ENDINCLINATION="-542;0;" ID="Arrow_ID_1390962202" SOURCE="ID_1939609996" STARTARROW="None" STARTINCLINATION="183;24;"/>
|
|
<node CREATED="1535890788898" ID="ID_474606436" MODIFIED="1557498707235" TEXT="IterAdapter"/>
|
|
<node CREATED="1535891020739" ID="ID_7899831" MODIFIED="1557498707235" TEXT="IterStateWrapper">
|
|
<node CREATED="1535891026946" ID="ID_958757780" MODIFIED="1557498707235" TEXT="sehr wichtiges Konzept"/>
|
|
<node CREATED="1535891031609" ID="ID_1246882752" MODIFIED="1557498707236" TEXT="leider zwei Ausprägungen">
|
|
<node CREATED="1535891041376" ID="ID_1943507267" MODIFIED="1557498707236" TEXT="Core ist opaque (private)"/>
|
|
<node CREATED="1535891050566" ID="ID_89731232" MODIFIED="1557498707236" TEXT="von Core erben">
|
|
<node CREATED="1535895093066" ID="ID_1894277171" MODIFIED="1557498707236" TEXT="IterableDecorator"/>
|
|
<node CREATED="1535895095322" ID="ID_1368242997" MODIFIED="1557498707236" TEXT="gehört zu TreeExplorer"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535890793825" ID="ID_582282005" MODIFIED="1557498707236" TEXT="Itertool">
|
|
<node CREATED="1535893017063" ID="ID_859634605" MODIFIED="1557498707236" TEXT="zunächst naiv-direkt implementiert"/>
|
|
<node CREATED="1535893024102" ID="ID_1514691517" MODIFIED="1557498707236" TEXT="Sandwich-Design">
|
|
<node CREATED="1535893036132" ID="ID_827990682" MODIFIED="1557498707236" TEXT="nicht besonders schön"/>
|
|
<node CREATED="1535893041324" ID="ID_1175882215" MODIFIED="1557498707236" TEXT="aber soweit wartbar"/>
|
|
</node>
|
|
<node CREATED="1535893048363" ID="ID_794436728" MODIFIED="1557498707236" TEXT="Frage: ablösen durch Pipeline-Builder?">
|
|
<arrowlink COLOR="#afa9c1" DESTINATION="ID_114091640" ENDARROW="Default" ENDINCLINATION="-503;-426;" ID="Arrow_ID_956211493" STARTARROW="None" STARTINCLINATION="238;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535890810111" ID="ID_677938944" MODIFIED="1557498707236" TEXT="IterSource">
|
|
<node CREATED="1535890823613" ID="ID_1227701237" MODIFIED="1557498707236" TEXT="Lumiera Iterator als Abstraktion"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1535890830772" ID="ID_1558484735" MODIFIED="1557498707236" TEXT="bestehendes Design ist ungeschickt">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1535890890980" ID="ID_1370634828" MODIFIED="1557498707236" TEXT="unterstellt einen Pos-Pointer"/>
|
|
<node CREATED="1535890915576" ID="ID_8718412" MODIFIED="1557498707236" TEXT="Semantik der Abbruchbedingung ist verwirrend"/>
|
|
</node>
|
|
<node CREATED="1535890958987" ID="ID_71109348" MODIFIED="1557498707236" TEXT="alternatives Design">
|
|
<node CREATED="1535890965170" ID="ID_1363636315" MODIFIED="1557498707236" TEXT="was geht hier?">
|
|
<node CREATED="1535890972609" ID="ID_1586923063" MODIFIED="1557498707236" TEXT="wie state core?"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535891065189" ID="ID_1233342893" MODIFIED="1576282357969" TEXT="Iterator-Monade">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
seit längerer Zeit ein Thema,
|
|
</p>
|
|
<p>
|
|
für das ich verschiedene Lösungen ausprobiere
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
IterExplorer : erster Anlauf, etwas schief
|
|
</li>
|
|
<li>
|
|
TreeExplorer : Pipeline-Builder, vielversprechend
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#435e98" CREATED="1512925265295" HGAP="103" ID="ID_1502143527" MODIFIED="1538869212828" VSHIFT="-66">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Thema: <b>Monaden</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#80c6b3" DESTINATION="ID_1499495468" ENDARROW="Default" ENDINCLINATION="-1812;12745;" ID="Arrow_ID_673178727" STARTARROW="None" STARTINCLINATION="4133;-10665;"/>
|
|
<linktarget COLOR="#6c79a2" DESTINATION="ID_1502143527" ENDARROW="Default" ENDINCLINATION="-522;742;" ID="Arrow_ID_616092581" SOURCE="ID_513357674" STARTARROW="None" STARTINCLINATION="238;0;"/>
|
|
<icon BUILTIN="flag-blue"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1510446221317" HGAP="37" ID="ID_1955430588" MODIFIED="1535892751360" VSHIFT="-14">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sind Monaden
|
|
</p>
|
|
<p>
|
|
wirklich hilfreich?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#b26c7a" DESTINATION="ID_1955430588" ENDARROW="Default" ENDINCLINATION="-343;-748;" ID="Arrow_ID_920121069" SOURCE="ID_1590483406" STARTARROW="None" STARTINCLINATION="-38;43;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1510446351987" ID="ID_855693611" MODIFIED="1535892731992" TEXT="steile These">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1510446304314" ID="ID_1203762242" MODIFIED="1510446320689" TEXT="Zustand ist ein Phänomen der wirklichen Welt"/>
|
|
<node CREATED="1510446255552" ID="ID_46197323" MODIFIED="1510446264587" TEXT="funktionale Sprachen sind kaputt by design"/>
|
|
<node CREATED="1510446265767" ID="ID_1283184818" MODIFIED="1510446275105" TEXT="nur deshalb brauchts dort Monaden"/>
|
|
</node>
|
|
<node CREATED="1510446363306" ID="ID_505111674" MODIFIED="1535892582314" TEXT="trotzdem gerechtfertigt?">
|
|
<node CREATED="1510446371480" ID="ID_247739078" MODIFIED="1510446394065" TEXT="Klarheit"/>
|
|
<node CREATED="1510446394965" ID="ID_1458617201" MODIFIED="1510446398689" TEXT="Trennung"/>
|
|
</node>
|
|
<node CREATED="1681004167322" ID="ID_187683678" LINK="#ID_641232618" MODIFIED="1681004305936" TEXT="siehe ausgearbeitete theoretische Darstellung im TiddlyWiki">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
»AboutMonads« : das könnte mal eine Seite im Theorieteil werden ("more about...")
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1512927162098" HGAP="93" ID="ID_1774532014" MODIFIED="1561827465901" TEXT="Einsichten" VSHIFT="37">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512927175056" ID="ID_516152902" MODIFIED="1518487921098" TEXT="nicht das Gelbe vom Ei">
|
|
<node CREATED="1512927204460" ID="ID_1166808329" MODIFIED="1518487921098" TEXT="kein wirkliches Design-Pattern"/>
|
|
<node CREATED="1512927213962" ID="ID_1374430987" MODIFIED="1518487921098" TEXT="es fehlt die Nennkraft"/>
|
|
</node>
|
|
<node CREATED="1512927667023" ID="ID_67694617" MODIFIED="1518487921098" TEXT="Probleme">
|
|
<node CREATED="1512927676973" ID="ID_1019834257" MODIFIED="1518487921098" TEXT="Mondaden sind eine rein technische Lösung"/>
|
|
<node CREATED="1512927687844" ID="ID_1680797364" MODIFIED="1518487921098" TEXT="sie vereinigen Themen ohne innere Verwadtschaft"/>
|
|
<node CREATED="1512927766769" ID="ID_943419159" MODIFIED="1518487921098" TEXT="Zusammenspiel gebundener Funktionen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bindet die Betrachtung auf einen technischen Level,
|
|
</p>
|
|
<p>
|
|
und führt dazu, daß die Abstraktion undicht wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512927978133" ID="ID_1491853321" MODIFIED="1518487921098" TEXT="passen schlecht in C++">
|
|
<node CREATED="1512928064858" ID="ID_1221151193" MODIFIED="1518487921098" TEXT="entweder massiv Metaprogrammierung"/>
|
|
<node CREATED="1512928075920" ID="ID_491825441" MODIFIED="1518487921098" TEXT="oder man schafft ein runtime-Meta-System"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512928100557" ID="ID_767453821" MODIFIED="1518487921098" TEXT="nützlich">
|
|
<node CREATED="1512928114707" ID="ID_21920250" MODIFIED="1518487921098" TEXT="um Zustand auszukoppeln">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
genau der Umstand,
|
|
</p>
|
|
<p>
|
|
daß funktionale Sprachen von einer Zustands-Phobie getrieben sind,
|
|
</p>
|
|
<p>
|
|
macht Monaden nützlich, um inhärenten Zustand wegzuabstrahieren.
|
|
</p>
|
|
<p>
|
|
Das kann genutzt werden, um den Zustand einer Wechselwirkung
|
|
</p>
|
|
<p>
|
|
nach einer Seite der Glieder auszukoppeln.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512928357202" ID="ID_360277857" MODIFIED="1518487921098" TEXT="um Konfigurierbarkeit zu schaffen"/>
|
|
<node CREATED="1512928258312" ID="ID_1469652928" MODIFIED="1518487921098" TEXT="um technische Details zu entflechten"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1512928287812" ID="ID_212632305" MODIFIED="1535892918047" TEXT="Fazit">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1512928291555" ID="ID_1651357350" MODIFIED="1518487921098" TEXT="nur ein »Monaden-Motiv« nutzen"/>
|
|
<node CREATED="1512928301386" ID="ID_589389944" MODIFIED="1518487921098" TEXT="das Builder-Pattern in den Vordergrund stellen">
|
|
<node CREATED="1512928322567" ID="ID_462235185" MODIFIED="1518487921098" TEXT="Builder ist ein wirkliches Pattern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1680567921049" ID="ID_1270335704" MODIFIED="1680567930279" TEXT="Pipeline-Builder-Framework entwickelt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535891101400" ID="ID_673846521" MODIFIED="1535891107371" TEXT="IterExplorer">
|
|
<node CREATED="1535891108199" ID="ID_1302968576" MODIFIED="1535891111234" TEXT="erster Anlauf">
|
|
<node CREATED="1535891111919" ID="ID_1088778723" MODIFIED="1535891123604" TEXT="funktioniert">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1535891114310" ID="ID_799781858" MODIFIED="1535891120950" TEXT="ist häßlich">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1535891125877" ID="ID_131112709" MODIFIED="1535891129432" TEXT="nur einmal verwendet">
|
|
<node CREATED="1535891130164" ID="ID_1396398506" MODIFIED="1535891135892" TEXT="für das Job-Planning">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512925334501" ID="ID_409327286" MODIFIED="1573229967374" TEXT="IterExplorer-Design">
|
|
<linktarget COLOR="#625975" DESTINATION="ID_409327286" ENDARROW="Default" ENDINCLINATION="-843;1771;" ID="Arrow_ID_86323098" SOURCE="ID_185594200" STARTARROW="None" STARTINCLINATION="-493;-1123;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1512925397741" ID="ID_1352590559" MODIFIED="1518487921098" TEXT="Design">
|
|
<node CREATED="1512925342773" ID="ID_1304424851" MODIFIED="1518487921098" TEXT="unbefriedigend"/>
|
|
<node CREATED="1512925350379" ID="ID_21486020" MODIFIED="1518487921098" TEXT="zu offen und flexibel"/>
|
|
<node CREATED="1512925358954" ID="ID_27814827" MODIFIED="1518487921098" TEXT="keine leitende Kohärenz"/>
|
|
<node CREATED="1512925366562" ID="ID_581707193" MODIFIED="1518487921098" TEXT="daher wie ein Gestrüpp"/>
|
|
</node>
|
|
<node CREATED="1512925431577" ID="ID_1834933729" MODIFIED="1518487921098" TEXT="Iterator-Chain">
|
|
<node CREATED="1512925436224" ID="ID_573800195" MODIFIED="1518487921098" TEXT="nice to have">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gehört zu dem Themenkomplex "itertools"
|
|
</p>
|
|
<p>
|
|
Python hat das auch, Java neuerdings auch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512925438992" ID="ID_1273839582" MODIFIED="1518487921098" TEXT="bisher nicht verwendet"/>
|
|
</node>
|
|
<node CREATED="1512925491857" ID="ID_652705156" MODIFIED="1518487921098" TEXT="Depth-fist / breadth fist">
|
|
<node CREATED="1512925501216" ID="ID_1197407538" MODIFIED="1518487921098" TEXT="Programmier-Übung"/>
|
|
<node CREATED="1512925508183" ID="ID_1861334930" MODIFIED="1518487921098" TEXT="ohne innere Notwendigkeit"/>
|
|
<node CREATED="1512925519653" ID="ID_1558680477" MODIFIED="1518487921098" TEXT="nicht verwendet"/>
|
|
</node>
|
|
<node CREATED="1512925529484" ID="ID_1844773201" MODIFIED="1518487921098" TEXT="SelfIntegration">
|
|
<node CREATED="1512925547393" ID="ID_1866032394" MODIFIED="1518487921098" TEXT="Design-Sackgasse">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1512925769363" ID="ID_582578425" MODIFIED="1518487921098" TEXT="geht gegen die Natur der Dinge"/>
|
|
<node CREATED="1512925732065" ID="ID_1377165331" MODIFIED="1518487921098" TEXT="verwirrendes Extension-API">
|
|
<node CREATED="1512925805416" MODIFIED="1518487921098" TEXT="build(...).wrapping(...)"/>
|
|
<node CREATED="1512925817645" MODIFIED="1518487921098" TEXT="build(...).usingSequence(...)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512925552137" ID="ID_43735106" MODIFIED="1518487921098" TEXT="wollte den Stack vermeiden">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
<node CREATED="1512925568958" ID="ID_1805640819" MODIFIED="1518487921098" TEXT="was gar nicht geht"/>
|
|
<node CREATED="1512925574782" ID="ID_22338010" MODIFIED="1518487921098" TEXT="Idee Inline-stack">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1512925593195" ID="ID_1333973816" MODIFIED="1518487921098" TEXT="das wäre aber eine reine Komponente"/>
|
|
<node CREATED="1512925599402" ID="ID_551236508" MODIFIED="1518487921098" TEXT="Bauprinzip wie in UI-Coord">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen, es ist klar, wie man sowas machen kann.
|
|
</p>
|
|
<p>
|
|
Seinerzeit war mir das auch klar, aber ich wollte es nicht gleich ausprogrammieren.
|
|
</p>
|
|
<p>
|
|
Inzwischen kam dann das Thema UI-Coordinaten, und dort <i>habe</i> ich es ausprogrammiert,
|
|
</p>
|
|
<p>
|
|
und zwar direkt in die Low-Level-Schicht integriert, was nicht schlecht ist,
|
|
</p>
|
|
<p>
|
|
da eine Abstraktion hier sehr technisch werden würde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512925864774" ID="ID_1543264108" MODIFIED="1535891440192" TEXT="verwendet für JobPlanning">
|
|
<arrowlink COLOR="#5379b5" DESTINATION="ID_181262071" ENDARROW="Default" ENDINCLINATION="-150;-386;" ID="Arrow_ID_1786254694" STARTARROW="Default" STARTINCLINATION="-1298;0;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512925959074" ID="ID_30857289" MODIFIED="1518487921098" TEXT="TODO: ablösen durch IterTreeExplorer">
|
|
<arrowlink COLOR="#83dfc7" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-1109;3887;" ID="Arrow_ID_1645152965" STARTARROW="None" STARTINCLINATION="2051;-176;"/>
|
|
<arrowlink COLOR="#bf3473" DESTINATION="ID_896127270" ENDARROW="Default" ENDINCLINATION="-1310;-138;" ID="Arrow_ID_1052952035" STARTARROW="None" STARTINCLINATION="-424;31;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680568272530" ID="ID_265531291" LINK="https://issues.lumiera.org/ticket/1276" MODIFIED="1680569227880" TEXT="#1276: Wiederaufnahme des Themas im Rahmen von »PlaybackVerticalSlice«">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1680568313565" ID="ID_1547861521" MODIFIED="1680568337979" TEXT="Ziel: komplett ersetzen durch das neue TreeExplorer-Design">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535891140563" ID="ID_1503014369" MODIFIED="1535891144430" TEXT="TreeExplorer">
|
|
<node CREATED="1535891145922" ID="ID_1982906906" MODIFIED="1535891149925" TEXT="zweiter Anlauf">
|
|
<node CREATED="1535891150825" ID="ID_451523751" MODIFIED="1535891155914" TEXT="funktioniert">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1535891156816" ID="ID_679300718" MODIFIED="1535891164631" TEXT="ist komplex">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1535939100410" ID="ID_1893557511" MODIFIED="1535939107373" TEXT="aber von einer Art, die mir gefällt"/>
|
|
<node CREATED="1535939111640" ID="ID_1649632412" MODIFIED="1535939115932" TEXT="war bisher gut wartbar">
|
|
<node COLOR="#435e98" CREATED="1537050257419" FOLDED="true" HGAP="27" ID="ID_1397772054" MODIFIED="1573229603386" TEXT="naja...." VSHIFT="5">
|
|
<arrowlink DESTINATION="ID_913930564" ENDARROW="Default" ENDINCLINATION="-286;-25;" ID="Arrow_ID_1572610374" STARTARROW="None" STARTINCLINATION="-132;45;"/>
|
|
<node COLOR="#435e98" CREATED="1680568048455" ID="ID_1704957291" MODIFIED="1680568076524" TEXT="Komplexität der Typsignaturen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1680568063106" ID="ID_1678633435" MODIFIED="1680568073558" TEXT="Framework erfolgreich überarbeitet">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1514328717684" ID="ID_137835978" MODIFIED="1573229989029" TEXT="neuer Anlauf IterExplorer II">
|
|
<arrowlink COLOR="#8ad3a5" DESTINATION="ID_845080696" ENDARROW="Default" ENDINCLINATION="-230;134;" ID="Arrow_ID_253437970" STARTARROW="None" STARTINCLINATION="-387;0;"/>
|
|
<linktarget COLOR="#27998e" DESTINATION="ID_137835978" ENDARROW="Default" ENDINCLINATION="-521;-801;" ID="Arrow_ID_1873000120" SOURCE="ID_1860662881" STARTARROW="None" STARTINCLINATION="-1866;98;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1514328733272" ID="ID_1367581404" MODIFIED="1514328740811" TEXT="monadisierter Pipeline-Builder">
|
|
<node CREATED="1535891193740" ID="ID_114091640" MODIFIED="1535893082084" TEXT="Itertool-Funktionalität">
|
|
<linktarget COLOR="#afa9c1" DESTINATION="ID_114091640" ENDARROW="Default" ENDINCLINATION="-503;-426;" ID="Arrow_ID_956211493" SOURCE="ID_794436728" STARTARROW="None" STARTINCLINATION="238;0;"/>
|
|
<node CREATED="1535891222952" ID="ID_1544390501" MODIFIED="1535891230659" TEXT="Überschneidung / Redundanz">
|
|
<node CREATED="1535891232214" ID="ID_1564035277" MODIFIED="1535891244617" TEXT="komplett andere Implementierung"/>
|
|
<node CREATED="1535891245533" ID="ID_1869540879" MODIFIED="1535891251247" TEXT="konzeptionell aber gleich"/>
|
|
</node>
|
|
<node CREATED="1535891265106" ID="ID_483764241" MODIFIED="1535891275533" TEXT="hier aber: Integration mit "explore"-Funktion"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1514328741687" ID="ID_1056450433" MODIFIED="1514328755457" TEXT="expandChildren() auf dem Iterator-API auslösbar"/>
|
|
<node CREATED="1514328757725" ID="ID_1835412332" MODIFIED="1514328766544" TEXT="auch über Transformer und Abstraktionsbarrieren hinweg"/>
|
|
<node CREATED="1535892081117" ID="ID_931408275" MODIFIED="1535892109957" TEXT="wraped State-Core">
|
|
<node CREATED="1535892112560" ID="ID_1137060893" MODIFIED="1535892121547" TEXT="bewußt halboffen"/>
|
|
<node CREATED="1535892122487" ID="ID_1852433674" MODIFIED="1535892137985" TEXT="Kollaboration mit downstream intendiert"/>
|
|
<node CREATED="1535892146588" ID="ID_1173791220" MODIFIED="1535892158246" TEXT="Layerering als Konstruktions-Hilfsmittel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535892165753" ID="ID_463934766" MODIFIED="1535892395441" TEXT="konkret: expandable ChildIter bauen">
|
|
<arrowlink COLOR="#236375" DESTINATION="ID_596422747" ENDARROW="Default" ENDINCLINATION="-1080;23;" ID="Arrow_ID_1748772698" STARTARROW="None" STARTINCLINATION="-1002;-57;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535893109211" ID="ID_1112499323" MODIFIED="1535893117935" TEXT="Probleme mit dem IterSource-Interface">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536410175049" ID="ID_1439541143" MODIFIED="1536516072058" TEXT="Ergänzungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535894221015" FOLDED="true" ID="ID_977007729" MODIFIED="1573229640628" TEXT="Bug im Filter-Layer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535894239308" ID="ID_1809452702" MODIFIED="1535894251655" TEXT="Reihenfolge des Parent-Aufrufes in expandChildren()"/>
|
|
<node CREATED="1535894252195" ID="ID_373085595" MODIFIED="1535894291490" TEXT="kommt mir komisch vor; pullFilter() sollte doch danach kommen"/>
|
|
<node CREATED="1535894301413" ID="ID_1630859517" MODIFIED="1535894376961" TEXT="sieht nach copy-n-paste aus">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...von der entsprechenden Methode im Transformer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1535894292222" ID="ID_1328694952" MODIFIED="1535894370745" TEXT="vermutlich im Test übersehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...hatte die Notwendigkeit hierfür seinerzeit während der Tests entdeckt,
|
|
</p>
|
|
<p>
|
|
und im Unit-Test nur für die Kombination Transformer + Explorer abgedeckt....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535894385009" ID="ID_1130325761" MODIFIED="1535898198283" TEXT="Testfall schreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535893707036" FOLDED="true" ID="ID_650057716" MODIFIED="1573229642317" TEXT="Aufgabe: Filter erweiterbar machen">
|
|
<linktarget COLOR="#62909b" DESTINATION="ID_650057716" ENDARROW="Default" ENDINCLINATION="99;93;" ID="Arrow_ID_1700598512" SOURCE="ID_257876647" STARTARROW="None" STARTINCLINATION="-240;-19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535893718194" ID="ID_177803317" MODIFIED="1535893743691" TEXT="analog zum Filter in den Itertools"/>
|
|
<node CREATED="1535893752174" ID="ID_27030007" MODIFIED="1535893777011" TEXT="ggfs diesen dort ablösen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sofern längerfristig Itertools durch TreeExplorer abgelöst werden könnte
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535903530421" ID="ID_326687543" MODIFIED="1535932193036" TEXT="Aua">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1535903536820" ID="ID_34512098" MODIFIED="1535903541919" TEXT="das wird komplex..."/>
|
|
<node CREATED="1535903542556" ID="ID_945730027" MODIFIED="1535903551375" TEXT="der Filter-Layer ist hochgradig generisch"/>
|
|
<node CREATED="1535904105560" ID="ID_1683260823" MODIFIED="1535904127224" TEXT="muß auch das Chain-Argument durch die Funktor-Traits schleusen"/>
|
|
<node CREATED="1535904128524" ID="ID_1305515398" MODIFIED="1535904140074" TEXT="Code wird grausam">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
<node CREATED="1535904143098" ID="ID_62668261" MODIFIED="1535904152669" TEXT="funktioniert, aber gewaltig aufgebläht"/>
|
|
<node CREATED="1535904153353" ID="ID_1229789568" MODIFIED="1535904403272" TEXT="ganz nah am Segfault vorbei">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das hängt an einem hauchdünnen Faden,
|
|
</p>
|
|
<p>
|
|
und ist subtil bis zum geht nicht mehr....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wenn man das Lambda einfach per [=] schreibt, und das Feld this->predicate_ verwendet,
|
|
</p>
|
|
<p>
|
|
dann wird this gecaptured (und das ist effektiv per Referenz). Wenn ich dann den
|
|
</p>
|
|
<p>
|
|
konstruierten Funktor an this->predicate_ zuweise, haben wir eine Endlos-Rekursion.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Lösung: man muß im lokalen Frame eine Referenz auf this->predicate definieren und binden.
|
|
</p>
|
|
<p>
|
|
Diese wird dann per Value gecaptured, was die gewünschte Kopie bewirkt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535904168943" ID="ID_1486081044" MODIFIED="1535904249188" TEXT="eine unnötige Kopie">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...muß den Chain-Funktor aus dem Template-Argument erzeugen,
|
|
</p>
|
|
<p>
|
|
und ihn dann in die per-Value-Closure des erzeugten neuen Lambda binden (=Kopie).
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Erst ab C++17 kann man Lambda-Captures pre move machen
|
|
</p>
|
|
<p>
|
|
(und auch dafür ist die Syntax grausam)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535904461720" ID="ID_1122890797" MODIFIED="1561827465910" TEXT="will ich das wirklich.....?">
|
|
<node CREATED="1535904470670" ID="ID_1319028134" MODIFIED="1535904516890" TEXT="natürlich nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es soll bloß einfach funktionieren!!!!!!!!!!!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1535906366785" ID="ID_772195469" MODIFIED="1535906388442" TEXT="Komplexität entsteht aus der Flexibilität der Argumente">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535904517824" ID="ID_495813123" MODIFIED="1535904857801" TEXT="stattdessen Itertools-Filter verwenden?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
keine gute Idee.
|
|
</p>
|
|
<p>
|
|
Dann verwenden wir im einen Funktor-Framework eine Filter-Komponente
|
|
</p>
|
|
<p>
|
|
aus dem anderen Framework, obwohl es direkt hier auch eine Filter-Komponente gäbe.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Außerdem habe ich immer noch die Hoffnung, irgendwann mal
|
|
</p>
|
|
<p>
|
|
die Itertools komplett durch den TreeExplorer ablösen zu können
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535906261464" ID="ID_792586244" MODIFIED="1535909947735" TEXT="Auswege">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1535906265911" ID="ID_949648101" MODIFIED="1561827465911" TEXT="speziellen Filter-Layer nur hierfür">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535906327782" ID="ID_1362040513" MODIFIED="1535906334769" TEXT="letztlich nur Code-Kosmetik"/>
|
|
<node CREATED="1535909106704" ID="ID_1965298489" MODIFIED="1535909115714" TEXT="würde aber sehr speziellen Fall markieren"/>
|
|
<node CREATED="1535909145091" ID="ID_1036104765" MODIFIED="1535909185418">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Name: <b>mutableFilter</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535906283948" ID="ID_1882070577" MODIFIED="1561827465912" TEXT="Chain-Filter-Bau in HIlfsfunktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535906394646" ID="ID_1941257576" MODIFIED="1535906399057" TEXT="wünschenswert"/>
|
|
<node CREATED="1535906399621" ID="ID_1167561151" MODIFIED="1535906407632" TEXT="nicht klar, ob überhaupt möglich"/>
|
|
<node CREATED="1535909021163" ID="ID_1877231025" MODIFIED="1535909030226" TEXT="geschachtelte generische Lambdas verwenden">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1535909041497" ID="ID_1207755293" MODIFIED="1535909052069" TEXT="AUA³">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1535909192572" ID="ID_1654371024" MODIFIED="1535909197055" TEXT="aber es geht...."/>
|
|
<node COLOR="#338800" CREATED="1535909967725" ID="ID_163021784" MODIFIED="1535912743392" TEXT="im Debugger verifizieren!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...sieht gut aus.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Folgendes habe ich gesehen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
zu Beginn zeigt das eingebettete Funktor-Objekt auf eine Position auf dem Stack
|
|
</li>
|
|
<li>
|
|
beim Aufrufen der andFilter()-Funktion werden diverse Funktoren kopiert,<br />wobei nacheinander die (zu erwartenden) Argumente als Quelle auftauchen<br />
|
|
</li>
|
|
<li>
|
|
danach hat sich der Funktor geändert: er zeigt nun auf eine Position auf dem Heap<br />
|
|
</li>
|
|
<li>
|
|
der bisherige Funktor wurde mit der Closure des zusammengesetzten Funktors kollabiert (hat gleiche Addresse)<br />
|
|
</li>
|
|
<li>
|
|
der Chain-Funktor hat eine Closure bekommen, die ebenfalls Heap-alloziert ist.<br />das deutet darauf hin, daß das capturen per copy funktioniert hat<br />
|
|
</li>
|
|
<li>
|
|
Beim Aufruf steppen wir nacheinander erst in den kombinierten Funktor,<br />und von dort wie erwartet in die beiden Lambdas.
|
|
</li>
|
|
<li>
|
|
<br />
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535919506060" ID="ID_1859852045" MODIFIED="1561827465912" TEXT="heterogene Prädikat-Typen">
|
|
<arrowlink COLOR="#616f95" DESTINATION="ID_1587572708" ENDARROW="Default" ENDINCLINATION="49;-142;" ID="Arrow_ID_346491515" STARTARROW="None" STARTINCLINATION="-143;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535919540560" ID="ID_1538734134" MODIFIED="1535932049581" TEXT="geht nicht?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1535919549942" ID="ID_790617987" MODIFIED="1535919754360" TEXT="das zu Beginn verwendete Filter-Prädikat legt den Typ fest">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...für das dort hineingereichte Funktor-Objekt wird der Argument-Accessor ausgewählt (Metaprogrammierung).
|
|
</p>
|
|
<p>
|
|
Er ist dann im Typ des Wrappers == _Traits::Functor codiert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wir können zwar den im Wrapper enthaltenen Funktor neu zuweisen (in gewissen Grenzen),
|
|
</p>
|
|
<p>
|
|
aber er wird stets den zu Beginn gewählten Argument-Accessor nehmen.
|
|
</p>
|
|
<p>
|
|
Typischerweise wird dieser ja sogar beim Aufruf des getemplateteten Funtions-Operators geInlined
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535919835337" ID="ID_1492056572" MODIFIED="1536409243145" TEXT="Ausweg: doppelt wrappen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536367874016" ID="ID_109911994" MODIFIED="1536516037376" TEXT="Filter deaktivierbar machen">
|
|
<linktarget COLOR="#67ac9b" DESTINATION="ID_109911994" ENDARROW="Default" ENDINCLINATION="1326;0;" ID="Arrow_ID_1556921295" SOURCE="ID_649387933" STARTARROW="None" STARTINCLINATION="142;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535899873112" ID="ID_81164806" MODIFIED="1535932139639" TEXT="Unit-Test (replizieren)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535913527837" ID="ID_756446305" MODIFIED="1535913542932" TEXT="anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535913531701" ID="ID_1872325076" MODIFIED="1535932138102" TEXT="andere Fälle auch covern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536410408473" ID="ID_1812410133" MODIFIED="1536515975946" TEXT="Filter deaktivieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536367899301" ID="ID_1128977501" MODIFIED="1561827465913" TEXT="Neuzuweisung kompatibler Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536367916619" ID="ID_411753478" MODIFIED="1536367919774" TEXT="geht das?"/>
|
|
<node CREATED="1536367921474" ID="ID_849620368" MODIFIED="1536367938773" TEXT="nur Signatur-Typ auf MutableFilter ">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1536368287265" ID="ID_29049674" MODIFIED="1536368351977">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Problem: std::function <b>in</b> FilterPredicate
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1536368354288" ID="ID_1161186805" MODIFIED="1536368384597" TEXT="muß die richtige "Kategorie" haben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
entweder Val -> bool oder Iter -> bool
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536499475717" ID="ID_1987289240" MODIFIED="1536499534632" TEXT="Nach Refactoring TreeExplorer nun möglich">
|
|
<arrowlink COLOR="#5cb3a1" DESTINATION="ID_1315131204" ENDARROW="Default" ENDINCLINATION="691;0;" ID="Arrow_ID_86390894" STARTARROW="None" STARTINCLINATION="167;37;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536713790340" ID="ID_1436344296" MODIFIED="1561827465914" TEXT="Explorer: rootCurrent()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536713813792" ID="ID_255912594" MODIFIED="1536713903337" TEXT="Hilfsmittel für den IterChainSearch">
|
|
<linktarget COLOR="#5c8eb4" DESTINATION="ID_255912594" ENDARROW="Default" ENDINCLINATION="1465;0;" ID="Arrow_ID_1700114612" SOURCE="ID_1097583555" STARTARROW="None" STARTINCLINATION="798;71;"/>
|
|
</node>
|
|
<node CREATED="1536713912051" ID="ID_1531296292" MODIFIED="1536714003659" TEXT="Verhalten">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1536713937303" ID="ID_1307568676" MODIFIED="1536713956169" TEXT="macht die aktuelle (Kind)-Sequenz zur Root-Sequenz"/>
|
|
<node CREATED="1536713956780" ID="ID_940104678" MODIFIED="1536713969199" TEXT="verwirft den gesamten Inhalt des bestehendn Stack"/>
|
|
<node CREATED="1536713969931" ID="ID_1439776917" MODIFIED="1536714013625" TEXT="verwirft damit auch die ursprüngliche Root-Sequenz"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958962984" ID="ID_686602920" MODIFIED="1561827465914" TEXT="custom Layer ermöglichen">
|
|
<linktarget COLOR="#61afb3" DESTINATION="ID_686602920" ENDARROW="Default" ENDINCLINATION="-230;613;" ID="Arrow_ID_1710661685" SOURCE="ID_519507996" STARTARROW="None" STARTINCLINATION="1241;-1305;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536958972703" ID="ID_661166644" MODIFIED="1537050781115" TEXT="generische Builder-Funktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist einfach und offensichtlich;
|
|
</p>
|
|
<p>
|
|
ohnehin laufen schon ziemlich alle konkreten Layer-Builder nach einem Schema-F
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958979046" ID="ID_700334374" MODIFIED="1537050782627" TEXT="Typ per Template-Parameter übergeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536958994212" ID="ID_1735239890" MODIFIED="1537050791509" TEXT="flexible zusätzliche Argumente">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536973178765" ID="ID_1098421095" MODIFIED="1537052565699" TEXT="Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536959023376" ID="ID_928142688" MODIFIED="1536973192247" TEXT="Test implizit durch IterChainSearch">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536973293197" ID="ID_858941900" MODIFIED="1537052564048" TEXT="eigens abdecken">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536409170928" ID="ID_1850744645" MODIFIED="1536515953937" TEXT="Design-Probleme">
|
|
<icon BUILTIN="go"/>
|
|
<node COLOR="#338800" CREATED="1535919506060" FOLDED="true" ID="ID_1587572708" MODIFIED="1573229614688" TEXT="heterogene Prädikat-Typen">
|
|
<linktarget COLOR="#616f95" DESTINATION="ID_1587572708" ENDARROW="Default" ENDINCLINATION="49;-142;" ID="Arrow_ID_346491515" SOURCE="ID_1859852045" STARTARROW="None" STARTINCLINATION="-143;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535919549942" ID="ID_270773242" MODIFIED="1536409271272" TEXT="das zu Beginn verwendete Filter-Prädikat legt den Typ fest">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...für das dort hineingereichte Funktor-Objekt wird der Argument-Accessor ausgewählt (Metaprogrammierung).
|
|
</p>
|
|
<p>
|
|
Er ist dann im Typ des Wrappers == _Traits::Functor codiert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wir können zwar den im Wrapper enthaltenen Funktor neu zuweisen (in gewissen Grenzen),
|
|
</p>
|
|
<p>
|
|
aber er wird stets den zu Beginn gewählten Argument-Accessor nehmen.
|
|
</p>
|
|
<p>
|
|
Typischerweise wird dieser ja sogar beim Aufruf des getemplateteten Funtions-Operators geInlined
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535919835337" ID="ID_619686338" MODIFIED="1561827465916" TEXT="1.Lösung: doppelt wrappen?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535923167297" ID="ID_1635196754" MODIFIED="1535923219590" TEXT="Basis-Filter sieht unspezifische Form des Prädikates"/>
|
|
<node CREATED="1535923237336" ID="ID_508718189" MODIFIED="1535923251434" TEXT="im Funktor steckt eingewickelt eine spezifische Form"/>
|
|
<node CREATED="1535932069618" ID="ID_856161473" MODIFIED="1535932128786" TEXT="kein wirklicher overhead">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Aufruf vom äußeren in den inneren Wrapper ist 1:1 und sollte vom Compiler wegoptimiert werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535924949587" ID="ID_835090820" MODIFIED="1535932018158" TEXT="Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535924955458" ID="ID_1924886650" MODIFIED="1535927205707" TEXT="Typ des gewrappten Funktors konstruieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535924963017" ID="ID_1255665831" MODIFIED="1535927208519" TEXT="diesen schon in die Instanz der Basisklasse einfließen lassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535924983038" ID="ID_343931650" MODIFIED="1535927210570" TEXT="Konstruktor eigens definieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535924991781" ID="ID_1047870457" MODIFIED="1535927212273" TEXT="inline wrappen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535925016969" ID="ID_797104795" MODIFIED="1535927239938" TEXT="der Rest müßte von selber funktionieren...">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536514257510" ID="ID_1708992184" MODIFIED="1561827465916" TEXT="2.Lösung: type erasure auf dem Funktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536514274780" ID="ID_767166560" MODIFIED="1536514286353" TEXT="läuft auch auf doppelt wrappen hinaus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536514288618" ID="ID_821501153" MODIFIED="1536514362703" TEXT="...nur machen wir das im umgebauten Desgin ohnehin immer">
|
|
<arrowlink COLOR="#3163b8" DESTINATION="ID_389572303" ENDARROW="Default" ENDINCLINATION="1208;0;" ID="Arrow_ID_1470957358" STARTARROW="None" STARTINCLINATION="627;32;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536409302285" FOLDED="true" ID="ID_913930564" MODIFIED="1573229616333" TEXT="extrem komplexe Typen">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_913930564" ENDARROW="Default" ENDINCLINATION="-286;-25;" ID="Arrow_ID_1572610374" SOURCE="ID_1397772054" STARTARROW="None" STARTINCLINATION="-132;45;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536409316172" ID="ID_1468538186" MODIFIED="1536409340127" TEXT="Call-Traces sind nahezu unlesbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ich verbrenne Stunden beim Debuggen von neuem Code
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1536409470623" ID="ID_862991864" MODIFIED="1536409494631" TEXT="Ansatzpunkte">
|
|
<node CREATED="1536409438003" ID="ID_254117479" MODIFIED="1536409449286" TEXT="erhebliche Redundanzen in den Typen"/>
|
|
<node CREATED="1536409503106" ID="ID_377815860" MODIFIED="1536409513965" TEXT="konkrete Lambdas in der Typsignatur"/>
|
|
</node>
|
|
<node CREATED="1536409720285" ID="ID_610904065" MODIFIED="1561827466009" TEXT="Untersuchung">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1536409726421" ID="ID_1705785900" MODIFIED="1536409738318" TEXT="welche Typen werden wirklich benötigt">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1536409761248" ID="ID_753549743" MODIFIED="1536409843345" TEXT="Quelle == Basis-Typ"/>
|
|
<node CREATED="1536409788637" ID="ID_87247261" MODIFIED="1536409835506" TEXT="bei Transofmation: neuer value_type"/>
|
|
</node>
|
|
<node CREATED="1536420551954" ID="ID_1265946119" MODIFIED="1536420561095" TEXT="Rolle der Traits">
|
|
<node CREATED="1536420562706" ID="ID_1510273577" MODIFIED="1536420573085" TEXT="Baumuster erkennen">
|
|
<node CREATED="1536420576968" ID="ID_1438017036" MODIFIED="1536420618407" TEXT="monadisch: res(val)"/>
|
|
<node CREATED="1536420581231" ID="ID_790634219" MODIFIED="1536420608360" TEXT="imperativ: res(SRC&)"/>
|
|
</node>
|
|
<node CREATED="1536420632457" ID="ID_1027876524" MODIFIED="1536420638164" TEXT="Signatur abnehmen"/>
|
|
<node CREATED="1536420639016" ID="ID_221776251" MODIFIED="1536420654441" TEXT="Funktor(Holder)-Typ konstruieren"/>
|
|
<node CREATED="1536420659869" ID="ID_176968684" MODIFIED="1536420669838" TEXT="Resultat">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1536420671212" ID="ID_1077375672" MODIFIED="1536420678038" TEXT="Funktor(Holder)-Typ"/>
|
|
<node CREATED="1536420678842" ID="ID_1524886712" MODIFIED="1536420681830" TEXT="Ergebnis-Typ"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536420803778" ID="ID_1315131204" MODIFIED="1536499525208" TEXT="Funktions-Signatur verbergen">
|
|
<linktarget COLOR="#5cb3a1" DESTINATION="ID_1315131204" ENDARROW="Default" ENDINCLINATION="691;0;" ID="Arrow_ID_86390894" SOURCE="ID_1987289240" STARTARROW="None" STARTINCLINATION="167;37;"/>
|
|
<node CREATED="1536420811265" ID="ID_1167994865" MODIFIED="1536420823683" TEXT="reduzieren auf res(SRC)"/>
|
|
<node CREATED="1536420824983" ID="ID_784540518" MODIFIED="1536420836185" TEXT="konkrete Funktion in Adapter setzen"/>
|
|
<node CREATED="1536420932944" ID="ID_512498364" MODIFIED="1536420940219" TEXT="ArgAccessor beim Aufruf">
|
|
<node CREATED="1536420941519" ID="ID_1927165900" MODIFIED="1536420945112" TEXT="kann wegfallen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1536420945998" ID="ID_582317324" MODIFIED="1536420989876" TEXT="trotzdem notwendig">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1536420950054" ID="ID_1462776992" MODIFIED="1536420952593" TEXT="wegen Expander">
|
|
<node CREATED="1536421001935" ID="ID_1416192275" MODIFIED="1536421016769" TEXT="unterschiedliche Iter-Typen möglich"/>
|
|
<node CREATED="1536421023732" ID="ID_293881968" MODIFIED="1536421035374" TEXT="in beiden Baumuster-Fällen"/>
|
|
</node>
|
|
<node CREATED="1536421204268" ID="ID_1225988621" MODIFIED="1536421235479">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konsequenz: brauche <b>Template</b> Funktions-Operator
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536499557658" ID="ID_1939855291" MODIFIED="1536499572569" TEXT="dafür verschwindet konkreter Funktor-Typ vom Template">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536441211468" HGAP="84" ID="ID_435661366" MODIFIED="1536515901080" TEXT="Lösungs-Idee" VSHIFT="15">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1536441217427" ID="ID_1508660342" MODIFIED="1536441270931" TEXT="die Signatur im Builder konstruieren. Traits nur noch auf Signatur abstützen">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1536441337478" ID="ID_1343620192" MODIFIED="1536441363753" TEXT="Traits bieten nun einen Funktor-Konstruktur">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1536441426912" ID="ID_1985454424" MODIFIED="1536441520374">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Funktor für den Expander wird <i>explizit als Sonderfall</i>  aufgefaßt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das <i>eigentliche Problem </i>mit der bestehenden Lösung ist,
|
|
</p>
|
|
<p>
|
|
daß ich ausgerechnet mit diesem Sonderfall angefangen habe.
|
|
</p>
|
|
<p>
|
|
Daher ist jetzt das gesamte Design "anders herum"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536441367354" ID="ID_1778093460" MODIFIED="1536441424596" TEXT="welcher eine gegebene Funktion in eine vorgegebene function<SIG> einpasst"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536451222025" FOLDED="true" HGAP="9" ID="ID_389572303" MODIFIED="1573229603386" TEXT="Umbau" VSHIFT="5">
|
|
<linktarget COLOR="#3163b8" DESTINATION="ID_389572303" ENDARROW="Default" ENDINCLINATION="1208;0;" ID="Arrow_ID_1470957358" SOURCE="ID_821501153" STARTARROW="None" STARTINCLINATION="627;32;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536451240308" ID="ID_241157222" MODIFIED="1536451273762" TEXT="den SRC-Parameter optional machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536451256034" ID="ID_645889218" MODIFIED="1561827466009" TEXT="FunTraits sind idempotent">
|
|
<icon BUILTIN="button_ok"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1536451303308" ID="ID_1343290323" MODIFIED="1536451313142" TEXT="man kann sie mit dem Funktor aufrufen -> Sig"/>
|
|
<node CREATED="1536451313778" ID="ID_439029617" MODIFIED="1536451336475" TEXT="man kann sie mit Sig aufrufen -> Arg, Ret"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536451345998" ID="ID_1853688774" MODIFIED="1561827466010" TEXT="Funktor-Konstruktor-Funktion">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536451365731" ID="ID_552359289" MODIFIED="1536451394878" TEXT="für Aufruf aus dem Konstruktor-Kontext">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wo der volle Typ des Funktors FUN bekannt ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536451415725" ID="ID_1712691133" MODIFIED="1536451426247" TEXT="Bekommt SRC-Iterator als Template-Param"/>
|
|
<node CREATED="1536451430508" ID="ID_224998497" MODIFIED="1536451471881" TEXT="wirft eine std::function<Ret(SRC&)> ab"/>
|
|
<node CREATED="1536451473013" ID="ID_1179844665" MODIFIED="1536451543886" TEXT="in die der eigentliche Funktor geeignet adaptiert ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und in dem besonders wichtigen Fall,
|
|
</p>
|
|
<p>
|
|
in dem der Funktor direkt den SRC-Iterator akzeptiert,
|
|
</p>
|
|
<p>
|
|
wird er ohne Weiteres durchgereicht.
|
|
</p>
|
|
<p>
|
|
In dem Fall dann <b>keine</b> doppelte Verpackung mehr!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536453317787" ID="ID_975974776" MODIFIED="1536514227734" TEXT="integrieren in...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536453326978" ID="ID_1071395763" MODIFIED="1561827466010" TEXT="Transformer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536455906647" ID="ID_603515158" MODIFIED="1536455919470" TEXT="im Debugger beobachtet">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536455920701" ID="ID_1992285034" MODIFIED="1536455938637" TEXT="äußerer Funktor liegt im Heap">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1536455947209" ID="ID_1054869208" MODIFIED="1536455959131" TEXT="innerer Funktor ist aber direkt dort eingebettet"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536453368676" ID="ID_1560078731" MODIFIED="1536499292336" TEXT="Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536453373605" ID="ID_1544724438" MODIFIED="1536499295024" TEXT="MutableFilter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536453408359" ID="ID_63715215" MODIFIED="1561827466014" TEXT="Anpassen an Expander">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536507478977" ID="ID_1869401041" MODIFIED="1536508603516" TEXT="zwei Alternativen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1536507484384" ID="ID_1235979491" MODIFIED="1536507500681" TEXT="wie bisher">
|
|
<node CREATED="1536507602416" ID="ID_42128364" MODIFIED="1536508634353" TEXT="konkreter Funktor Typ-Parameter">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1536507659208" FOLDED="true" ID="ID_35307754" MODIFIED="1561827483838" TEXT="Adapter im konkreten Aufruf">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1536507751800" ID="ID_941404287" MODIFIED="1536507757104" TEXT="in expandChildren()"/>
|
|
<node CREATED="1536507757860" ID="ID_133943734" MODIFIED="1536507768814" TEXT="jeweils beide Varianten instantiiert"/>
|
|
</node>
|
|
<node CREATED="1536507818274" ID="ID_1978344432" MODIFIED="1536508645416" TEXT="Adapter-Lambda ruft (inneren) Basis-Funktor">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536507882434" ID="ID_216951915" MODIFIED="1536507892221" TEXT="type erasure">
|
|
<node CREATED="1536507918965" FOLDED="true" ID="ID_1992478190" MODIFIED="1561827483838" TEXT="expanded Iter als 2.Typ-Parameter">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1536507954841" ID="ID_281799195" MODIFIED="1536507969106" TEXT="weil wir ihn speichern müssen"/>
|
|
<node CREATED="1536507960432" ID="ID_164121163" MODIFIED="1536507962403" TEXT="im Stack"/>
|
|
</node>
|
|
<node CREATED="1536508021816" FOLDED="true" ID="ID_1317784150" MODIFIED="1561827483838" TEXT="müssen zwei Funktoren speichern">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1536508097204" ID="ID_1486255600" MODIFIED="1536508101760" TEXT="unvermeidbar, egal wo"/>
|
|
<node CREATED="1536508116330" ID="ID_156138966" MODIFIED="1536508135549">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da sich die Iteratoren <i>wirklich</i> unterscheiden können dürfen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536508169610" ID="ID_1935713564" MODIFIED="1536508703334" TEXT="beide Funktoren direkt in expandChildren() verwendet">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1536508188208" FOLDED="true" ID="ID_220313082" MODIFIED="1561827483838" TEXT="äußerer Adapter-Funktor ruft inneren Basis-Funktor">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1536508254591" ID="ID_1794037057" MODIFIED="1536508268217" TEXT="mehr Overhead wie alte Lösung"/>
|
|
<node CREATED="1536508268765" ID="ID_1221492112" MODIFIED="1536508288165" TEXT="aber genauso viel wie für die anderen Fälle (neue Lösung)"/>
|
|
<node CREATED="1536508292026" ID="ID_775504670" MODIFIED="1536508307124" TEXT="verwendet gleichen Code, Funktor-struct fällt weg"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536508310935" ID="ID_838394264" MODIFIED="1536508324120" TEXT="Entscheidung: type erasure">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1536508326877" ID="ID_206041639" MODIFIED="1536508777424" TEXT="die gesamte neue Lösung ist etwas aufwendiger zur Laufzeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wobei der konkrete Overhead noch nicht wirklich klar ist;
|
|
</p>
|
|
<p>
|
|
hängt davon ab, wie geschickt der Optimizer ist, und was man konkret als Funktoren angibt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Vermutlich haben wir hier
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
zwingend eine Indirektion durch einen Funktions-Pointer (weil eine Type Erasure stattfindet)
|
|
</li>
|
|
<li>
|
|
möglicherweise eine zusätzliche Heap-Allocation (es sei denn, der Optimizer ist wirklich clever)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="down"/>
|
|
</node>
|
|
<node CREATED="1536508343419" ID="ID_1905482399" MODIFIED="1536508782549" TEXT="und hat dafür einfacheren Code und klarere Template-Argumente">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und <b>das</b> ist das Argument, das sticht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
<node CREATED="1536508376894" ID="ID_1216206461" MODIFIED="1536508787136" TEXT="Erhalten der alten Lösung würde zwei redundante Code-Pfade erfordern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...will sagen, wenn schon eine neue Lösung, dann von A bis Z
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="up"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536514206125" HGAP="-18" ID="ID_1018008959" MODIFIED="1536514219722" TEXT="Implementierung umschreiben" VSHIFT="13">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536453419141" ID="ID_564310637" MODIFIED="1561827466015" TEXT="vereinfachen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536515844176" ID="ID_1550470066" MODIFIED="1536515856523" TEXT="nested Functor fällt weg"/>
|
|
<node CREATED="1536515857230" ID="ID_1234982362" MODIFIED="1536515868816" TEXT="zugehörige Builder fallen weg"/>
|
|
<node CREATED="1536515869405" ID="ID_1548641638" MODIFIED="1536515881255" TEXT="alle darauf aufbauenden Typen sind überflüssig"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535893137527" ID="ID_994961372" MODIFIED="1535893142488" TEXT="Verwendungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1535893144518" ID="ID_1137736223" MODIFIED="1535893214860" TEXT="ViewSpec solver im UI">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Suche wird geleitet durch die ViewSpecDSL
|
|
</li>
|
|
<li>
|
|
hinter dem (opaquen) TreeExplorer steckt die konkrete UI-Topologie
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535893231835" FOLDED="true" ID="ID_637460742" MODIFIED="1573229918492" TEXT="Such-Prädikate auf EventLog">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
EventLog ist ein Test-Hilfsmittel,
|
|
</p>
|
|
<p>
|
|
um Unit-Tests über UI-Bus-Interaktionen schreiben zu können.
|
|
</p>
|
|
<p>
|
|
Es gibt hierzu Test-Varianten, die jeden Aufruf in ein internes Log notieren.
|
|
</p>
|
|
<p>
|
|
Im Test verwendet man dann eine Pattern-Such-DSL,
|
|
</p>
|
|
<p>
|
|
hinter der sich eine verkettete Suche mit Backtracking verbirgt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node COLOR="#338800" CREATED="1535893353955" ID="ID_1665477644" MODIFIED="1561827466017" TEXT="bestehende Lösung umstellen">
|
|
<linktarget COLOR="#3eccac" DESTINATION="ID_1665477644" ENDARROW="Default" ENDINCLINATION="-4110;-2852;" ID="Arrow_ID_1163013232" SOURCE="ID_1626597975" STARTARROW="None" STARTINCLINATION="1631;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535893608745" ID="ID_11389264" MODIFIED="1535893673457" TEXT="Idee: Auswertungs-State">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1535893623463" ID="ID_371015216" MODIFIED="1535893629458" TEXT="als State Core im Iterator"/>
|
|
<node CREATED="1535893631990" ID="ID_129119743" MODIFIED="1535893641848" TEXT="hält den Quell-Iterator"/>
|
|
<node CREATED="1535893643956" ID="ID_279421694" MODIFIED="1535893667251" TEXT="delegiert / wrappt">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535893707036" ID="ID_257876647" MODIFIED="1536533157472" TEXT="Aufgabe: Filter erweiterbar machen">
|
|
<arrowlink COLOR="#62909b" DESTINATION="ID_650057716" ENDARROW="Default" ENDINCLINATION="99;93;" ID="Arrow_ID_1700598512" STARTARROW="None" STARTINCLINATION="-240;-19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535899922873" ID="ID_1971708144" MODIFIED="1535937992260" TEXT="bestehende Aufrufe in EventMatch konsolidieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1535934086931" ID="ID_805705448" MODIFIED="1535934155059" TEXT="internes API für die Such-Konfiguration einführen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...so daß es nur noch wenige Zugangs-Punkte zum unterliegenden Iterator gibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535934121614" ID="ID_757923717" MODIFIED="1535937964888" TEXT="umstellen von IterTools -> TreeExplorer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535938792363" ID="ID_428321880" MODIFIED="1535938844914" TEXT="CursorGear direkt als Core verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TreeExplorer macht das Wrappen für uns automatisch,
|
|
</p>
|
|
<p>
|
|
und außerdem haben wir nun ein direktes API für die Laufrichtung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535938028929" FOLDED="true" ID="ID_1910123172" MODIFIED="1573229808484" TEXT="Backtracking Search-Engine einbauen">
|
|
<arrowlink COLOR="#23408f" DESTINATION="ID_1801538785" ENDARROW="Default" ENDINCLINATION="20;-55;" ID="Arrow_ID_1048873840" STARTARROW="None" STARTINCLINATION="-120;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1535939763441" ID="ID_132867774" MODIFIED="1535939780642" TEXT="muß "nur noch" Cursor gegen neue State-Core austauschen"/>
|
|
<node CREATED="1535939781302" ID="ID_285459121" MODIFIED="1535939796824" TEXT="diese hält den Cursor plus einen Stack mit den Filtern"/>
|
|
<node COLOR="#338800" CREATED="1537058259201" ID="ID_1249469718" MODIFIED="1561827466019" TEXT="Anpassungen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537058272183" ID="ID_1629184923" MODIFIED="1537059375100" TEXT="Alles per Filter-Chain machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537058280542" ID="ID_1820744744" MODIFIED="1537058284929" TEXT="ist zwar aufwendiger..."/>
|
|
<node CREATED="1537058285286" ID="ID_1430429521" MODIFIED="1537058383182" TEXT="aber das einzig Sinnvolle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn durch das Backtracking
|
|
</p>
|
|
<p>
|
|
würde man nun ziemlich undurchsichtige Misch-Zustände bekommen.
|
|
</p>
|
|
<p>
|
|
Und: jeder direkt gesetzte Filter könnte die Invariante im Expander verletzen
|
|
</p>
|
|
<p>
|
|
(weil er einen Kind-Iterator leer machen könnte, ohne daß dieser gePOPpt wird)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537058418739" ID="ID_232136872" MODIFIED="1537059386568" TEXT="Umstellung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537058434897" ID="ID_1021441779" MODIFIED="1537059381029" TEXT="attachNextSerchStep">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537058445064" ID="ID_1377843323" MODIFIED="1537058450843" TEXT="kompletten Filter-Konfigurator"/>
|
|
<node CREATED="1537058451527" ID="ID_1849109468" MODIFIED="1537058459138" TEXT="stets auch die Richtung setzen"/>
|
|
<node CREATED="1537316776292" ID="ID_507846374" MODIFIED="1537316870949" TEXT="hier nun stets einen Schritt machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um "Hängenbleiben" auf dem gleichen Element auszuschließen.
|
|
</p>
|
|
<p>
|
|
Vorsicht: um sauber genau einen Schritt machen zu können, müssen wir explizit vorübergehend den Filter abschalten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5174b2" DESTINATION="ID_256131209" ENDARROW="Default" ENDINCLINATION="-241;-10;" ID="Arrow_ID_73536182" STARTARROW="None" STARTINCLINATION="169;19;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537058470628" ID="ID_244817932" MODIFIED="1537059384506" TEXT="refineSerach">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537058473468" ID="ID_1720204552" MODIFIED="1537058480839" TEXT="ebenfalls kompletten Filter-Konfigurator"/>
|
|
<node CREATED="1537058485338" ID="ID_738059771" MODIFIED="1537058694225" TEXT="Vorsicht: das gibt nun zusäztliche Lösungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil wir uns bisher bei allen vorausgegangenen Bedingungen
|
|
</p>
|
|
<p>
|
|
auf den ersten Match "festgebissen" haben, und nur über den Iterator mit der
|
|
</p>
|
|
<p>
|
|
zuletzt gesetzen Bedingung weiter iteriert haben.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Künftig gibt es nach jedem Fail ein Backtracking.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1537058600555" ID="ID_717984419" MODIFIED="1537058656433" TEXT="sollte aber bei reinen AND-Klauseln egal sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h es findet zwar ein Backtracking statt, aber wenn alle konjunktiven Klauseln gesetzt sind,
|
|
</p>
|
|
<p>
|
|
sollte sich erneut ein FAIL ergeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1537058662202" ID="ID_654601259" MODIFIED="1537058688483" TEXT="und bloß zusätzlichen overhead bei NOT-Match-Tests bewirken"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537059388025" ID="ID_1276869558" MODIFIED="1561827466024" TEXT="Tests scheitern...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537059395184" ID="ID_77123611" MODIFIED="1537316730803" TEXT="EventLog_test">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
est-event-log-test.cpp:228:  verify_callLogging: (log.ensureNot("fun").after("fun").after("fun2"))
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537059455216" ID="ID_318014472" MODIFIED="1537309403475">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verdacht: <b>Negation</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1537230016114" ID="ID_1768475576" MODIFIED="1537309001137" TEXT="nein... es war bisher kaputt">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1537230071267" ID="ID_325369118" MODIFIED="1537230244388" TEXT="und funktioniert jetzt korrekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
fun after fun matcht auf den immer gleichen Record
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1537230078498" ID="ID_746060961" MODIFIED="1537230098331" TEXT="wir setzen am vorherigen Match auf"/>
|
|
<node CREATED="1537230100031" ID="ID_831756745" MODIFIED="1537230107546" TEXT="das ist überraschend"/>
|
|
<node COLOR="#435e98" CREATED="1537230108686" FOLDED="true" ID="ID_256131209" MODIFIED="1561827483838" TEXT="sollten wir das ändern?">
|
|
<arrowlink COLOR="#73a3ae" DESTINATION="ID_1088562812" ENDARROW="Default" ENDINCLINATION="255;0;" ID="Arrow_ID_1747758330" STARTARROW="None" STARTINCLINATION="191;47;"/>
|
|
<linktarget COLOR="#5174b2" DESTINATION="ID_256131209" ENDARROW="Default" ENDINCLINATION="-241;-10;" ID="Arrow_ID_73536182" SOURCE="ID_507846374" STARTARROW="None" STARTINCLINATION="169;19;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1537230118588" ID="ID_173358506" MODIFIED="1537308994452" TEXT="principle of least surprise">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1537230125716" FOLDED="true" ID="ID_2590903" MODIFIED="1561827482932" TEXT="aber...">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1537230132898" FOLDED="true" ID="ID_595305834" MODIFIED="1561827469159" TEXT="manche Tests haben das ausgenützt">
|
|
<node CREATED="1537230371514" ID="ID_1967930414" MODIFIED="1537230375734" TEXT="real world?"/>
|
|
</node>
|
|
<node CREATED="1537230143633" FOLDED="true" ID="ID_1378112667" MODIFIED="1561827469159" TEXT="brauche dann eigene Einstiegs-Methode">
|
|
<node CREATED="1537308984470" ID="ID_1575859366" MODIFIED="1537308986984" TEXT="besser so"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537309349547" ID="ID_1102778316" MODIFIED="1537315501823" TEXT="bestehende Tests korrigieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537309372867" FOLDED="true" ID="ID_1847253086" MODIFIED="1561827483838" TEXT="verify_simpleUsage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537312791212" ID="ID_510039930" MODIFIED="1537312803182" TEXT="weiterer Fehler"/>
|
|
<node CREATED="1537312804010" ID="ID_1081351208" MODIFIED="1537312892636" TEXT="vorherigien Filter vor dem Step abschalten">
|
|
<arrowlink COLOR="#cb8fa1" DESTINATION="ID_665208250" ENDARROW="Default" ENDINCLINATION="55;0;" ID="Arrow_ID_1772260988" STARTARROW="None" STARTINCLINATION="-39;46;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537309378682" ID="ID_129678233" MODIFIED="1537315494792" TEXT="verify_callLogging">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537316714860" ID="ID_84746570" MODIFIED="1537320053126" TEXT="Tests zur Klarstellung ergänzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537059402359" ID="ID_1670401833" MODIFIED="1537320056202" TEXT="BusTerm_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537320056985" ID="ID_1069836812" MODIFIED="1537320066440" TEXT="AbstractTangible_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537320067432" ID="ID_1996707326" MODIFIED="1537320080797" TEXT="der hat diesen ganzen Umbau ausgelöst">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1537230718644" ID="ID_1760678465" MODIFIED="1537320265399" TEXT="Fix">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537230726491" ID="ID_1088562812" MODIFIED="1537315479387" TEXT="before / after gehen stets einen Schritt">
|
|
<linktarget COLOR="#73a3ae" DESTINATION="ID_1088562812" ENDARROW="Default" ENDINCLINATION="255;0;" ID="Arrow_ID_1747758330" SOURCE="ID_256131209" STARTARROW="None" STARTINCLINATION="191;47;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537312702960" HGAP="37" ID="ID_665208250" MODIFIED="1537315479387" VSHIFT="15">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar mit <i>abgeschaltetem </i>Filter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
für diesen einen Schritt
|
|
</p>
|
|
<p>
|
|
muß die Filter-Funktion vorübergehend deaktiviert werden,
|
|
</p>
|
|
<p>
|
|
damit wir exakt das nächste / vorhergehende Element bekommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#cb8fa1" DESTINATION="ID_665208250" ENDARROW="Default" ENDINCLINATION="55;0;" ID="Arrow_ID_1772260988" SOURCE="ID_1081351208" STARTARROW="None" STARTINCLINATION="-39;46;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537230751079" ID="ID_1776084088" MODIFIED="1561827466025" TEXT="neue reine Filter-Funktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537230790179" ID="ID_1688121233" MODIFIED="1537308959793" TEXT="wechseln nur den Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537230809608" ID="ID_132845471" MODIFIED="1537308961598" TEXT="attached as Step">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1537230937167" FOLDED="true" ID="ID_83896289" MODIFIED="1561827483838" TEXT="Namen">
|
|
<node CREATED="1537230952405" ID="ID_36863841" MODIFIED="1537230954560" TEXT="locate"/>
|
|
<node CREATED="1537230955156" ID="ID_1450598514" MODIFIED="1537230957952" TEXT="locateMatch"/>
|
|
<node CREATED="1537230958684" ID="ID_288175427" MODIFIED="1537230961695" TEXT="locateEvent"/>
|
|
<node CREATED="1537230962475" ID="ID_1446509249" MODIFIED="1537230964919" TEXT="locateCall"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537230778540" ID="ID_985799795" MODIFIED="1537308964650" TEXT="diese auch für den Einstieg verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536368106394" FOLDED="true" ID="ID_1324169393" MODIFIED="1573229781539" TEXT="in eigene Translation-Unit verschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537059357301" ID="ID_1501687281" MODIFIED="1537059360761" TEXT="Beobachtungen">
|
|
<node CREATED="1536368121224" ID="ID_684768731" MODIFIED="1536368139195">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Search-Engine bläht die Debug-Infos <b>gewaltig</b> auf
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1536368144661" ID="ID_184622907" MODIFIED="1537058233640" TEXT="BusTerm_test = 13.1 MB">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1536368166242" ID="ID_280400966" MODIFIED="1537058245743" TEXT="EventLog_test = 6.2 MB">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537058044500" ID="ID_637125647" MODIFIED="1537058178984" TEXT="Aber: Such-Iterator im Event-Log ist nicht der Hauptschuldige">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1537058071056" ID="ID_1523796232" MODIFIED="1537058162420" TEXT="Versuchsweise auskommentiert"/>
|
|
<node CREATED="1536368144661" ID="ID_1550616773" MODIFIED="1537058237543" TEXT="BusTerm_test = 11 MB">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1536368166242" ID="ID_1244843669" MODIFIED="1537058249425" TEXT="EventLog_test = 4 MB">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537059265873" ID="ID_798187553" MODIFIED="1537059347543" TEXT="leider merkt man aber die Umstellung auf IterChainSearch">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1536368144661" ID="ID_1266326166" MODIFIED="1537320654812" TEXT="BusTerm_test = 14.6 MB">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1536368166242" ID="ID_1222359374" MODIFIED="1537320670162" TEXT="EventLog_test = 7.8 MB">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537408492185" ID="ID_1391232995" MODIFIED="1537408509710" TEXT="nach Umstellung: hat nicht sonderlich viel gebracht">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1536368144661" ID="ID_1457614262" MODIFIED="1537408979742" TEXT="BusTerm_test = 11.7 MB">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1537408924511" ID="ID_764968453" MODIFIED="1537408971969" TEXT="AbstractTangible_test = 8.7">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1536368166242" ID="ID_40278059" MODIFIED="1537408966779" TEXT="EventLog_test = 4.5 MB">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1537409213000" ID="ID_980087931" MODIFIED="1537409228912" TEXT="aber: event-log.os = 5 MB">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537059850803" ID="ID_253192903" MODIFIED="1537059853438" TEXT="Plan">
|
|
<node CREATED="1537059854290" ID="ID_1281790716" MODIFIED="1537059867700" TEXT="der Typ der Search-Engine muß nicht verborgen werden"/>
|
|
<node CREATED="1537059868337" ID="ID_138143272" MODIFIED="1537059878979" TEXT="es kann daher ein direktes Objektfeld bleiben"/>
|
|
<node CREATED="1537059879759" ID="ID_893108945" MODIFIED="1537059904472" TEXT="alle Suchprädikate sind Lambdas -> Template Argumente"/>
|
|
<node CREATED="1537059905107" ID="ID_133126017" MODIFIED="1537059924085" TEXT="d.h. auch die Such-Funktionen müssen nach hinten in das CPP gedrückt werden"/>
|
|
<node COLOR="#338800" CREATED="1537059925313" ID="ID_1283278546" MODIFIED="1537400192425" TEXT="Problem Var-Arg">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537059941287" ID="ID_1072965326" MODIFIED="1537059944938" TEXT="Argument-Match"/>
|
|
<node CREATED="1537059945310" ID="ID_1104771437" MODIFIED="1537059950057" TEXT="RegExp-Sequenz"/>
|
|
<node CREATED="1537059950597" ID="ID_1688685593" MODIFIED="1537059976646" TEXT="beide erzeugen aber einen STL-container als Intermediary">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1537059978146" ID="ID_1403964414" MODIFIED="1537059984405" TEXT="d.h. man kann dazwischen schneiden"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537059994048" ID="ID_1556879726" MODIFIED="1537408486805" TEXT="Umbau">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537060007341" ID="ID_137118669" MODIFIED="1537402606149" TEXT="eigene Translation-Unit EventLog.cpp anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537060024891" ID="ID_416527676" MODIFIED="1537407285711" TEXT="Ctor nach hinten schieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537060040409" ID="ID_440163527" MODIFIED="1537407287283" TEXT="Auswerte-Logik nach hinten schieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537060054767" ID="ID_1081334498" MODIFIED="1537407288629" TEXT="Problem: private Matcher-Builder">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537060094809" ID="ID_442340693" MODIFIED="1537407293640" TEXT="in freie Template-Funktionen verwandeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537060267290" ID="ID_1006625301" MODIFIED="1537407322172" TEXT="die direkten Filter-Konfigurier-Funktionen ebenso">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geht gar nicht anders, denn diese sind templates
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537060121158" ID="ID_1857002867" MODIFIED="1537407306625" TEXT="Such-Funktionen nach hinten reichen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535893799799" ID="ID_706866636" MODIFIED="1535938019075" TEXT="Auswertungs-Stack">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1535893826972" ID="ID_352546105" MODIFIED="1535894073967" TEXT="aktueller Frame">
|
|
<node CREATED="1535894074891" ID="ID_1972842519" MODIFIED="1535923151832" TEXT="== aktuell wirksamer Suchfilter"/>
|
|
<node CREATED="1535894076546" ID="ID_880245387" MODIFIED="1535894084445" TEXT="schießt Suchposition ein"/>
|
|
</node>
|
|
<node CREATED="1535893989214" ID="ID_875812160" MODIFIED="1535894010499">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Invariante</u>: <b>pullMatch</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1535894029921" ID="ID_152779506" MODIFIED="1535894037411" TEXT="den Stack schrittweise hochsteigen"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535894097279" ID="ID_1801538785" MODIFIED="1561827466033" TEXT="als eigene Lib-Klasse bauen">
|
|
<linktarget COLOR="#23408f" DESTINATION="ID_1801538785" ENDARROW="Default" ENDINCLINATION="20;-55;" ID="Arrow_ID_1048873840" SOURCE="ID_1910123172" STARTARROW="None" STARTINCLINATION="-120;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1535894115317" ID="ID_1507592237" MODIFIED="1536018340937" TEXT="Design-Frage: wie konkret?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1536018209730" ID="ID_1130583934" MODIFIED="1536018221348" TEXT="nur das generische Auswertungs-Schema"/>
|
|
<node CREATED="1536018222528" ID="ID_1509547591" MODIFIED="1536018255176" TEXT="die einzelnen Auswertungs-Schritte als Funktor (Monaden-Stil)"/>
|
|
<node CREATED="1536018255860" ID="ID_1267468732" MODIFIED="1536018275981" TEXT="der unterliegende Iterator als Template-Parameter"/>
|
|
<node CREATED="1536018293535" ID="ID_361886715" MODIFIED="1536018315757" TEXT="Abkürzung für direkten Wert-equality-Match"/>
|
|
<node CREATED="1536018276593" ID="ID_1222260775" MODIFIED="1536018287299" TEXT="prekonfigurierte Builder-Funktionen für Standardfälle"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018364845" FOLDED="true" ID="ID_1351452920" MODIFIED="1573229908166" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018375244" ID="ID_1906913554" MODIFIED="1536717634181" TEXT="Kern: Explore-Mechanismus">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018644456" ID="ID_477475522" MODIFIED="1536329729458" TEXT="Signatur der Explore-Funktion festlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018705511" ID="ID_1131109871" MODIFIED="1536329731179" TEXT="greedy Tiefensuche">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018802738" ID="ID_1560348563" MODIFIED="1536353099280" TEXT="Abbruchbedingung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018816272" ID="ID_40740226" MODIFIED="1536353104580" TEXT="Ende der Filterkette">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018829583" ID="ID_722941976" MODIFIED="1536353106355" TEXT="aktueller Filter erschöpft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536340043113" ID="ID_1162927294" MODIFIED="1561827466034" TEXT="aktuellen Zustand als Argument">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536340051461" ID="ID_1232898317" MODIFIED="1536345629500" TEXT="Wichtig: Referenz">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1232898317" ENDARROW="Default" ENDINCLINATION="550;0;" ID="Arrow_ID_1329838760" SOURCE="ID_1977741990" STARTARROW="None" STARTINCLINATION="109;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536340255596" ID="ID_1394539187" MODIFIED="1536340348029" TEXT="überflüssige Kopie erstellt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1536340275802" ID="ID_1689368781" MODIFIED="1536340292559" TEXT="im Aufruf des inneren (grwrappten) Funktors">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1536340301958" ID="ID_932937045" MODIFIED="1536340319264" TEXT="das reingegebene Argument zeigt noch (korrekt) auf die aktuelle Pipeline"/>
|
|
<node CREATED="1536340325843" ID="ID_1834736142" MODIFIED="1536340342005" TEXT="aber das eingwickelte Lambda sieht eine const& auf eine Kopie"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536342792784" ID="ID_363834044" MODIFIED="1536342806527" TEXT="doppeltes Wrappen unnötig">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536342807526" ID="ID_1490056918" MODIFIED="1536342900054" TEXT="stattdessen im vector<Step> wrappen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. die <i>einzelnen</i> Steps in der Pipeline direkt wrappen.
|
|
</p>
|
|
<p>
|
|
Dann ist außen herum keine Anpassung der Argumente mehr notwendig,
|
|
</p>
|
|
<p>
|
|
und man kann die Expand-Funktion direkt als std::function-Objekt durchgeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536340063062" ID="ID_1554385479" MODIFIED="1536340152896" TEXT="und zwar const&">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...um den Expand-Funktor zu zwingen, eine Kopie zu machen;
|
|
</p>
|
|
<p>
|
|
es sollte die Filter-Konfiguration auf der Kopie manipuliert werden,
|
|
</p>
|
|
<p>
|
|
während das Original auf dem Auswertungs-Stack liegen bleibt,
|
|
</p>
|
|
<p>
|
|
für späteres Backtracking...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536345349807" ID="ID_219089137" MODIFIED="1536345462776" TEXT="TreeExplorer strippen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536345360133" ID="ID_23274093" MODIFIED="1536345384449" TEXT="wird immer noch außern herumgewickelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit man stets weitere Builder-Funktionen auf der Pipeline aufrufen kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536345386770" ID="ID_1554908631" MODIFIED="1536345421597" TEXT="wir brauchen aber den Filter-Iterator selber">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil wir <i>diesen</i> manipulieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536345422997" ID="ID_1977741990" MODIFIED="1536345460034" TEXT="nur so kann man eine Referenz auf den Zustand in den Expand-Funktor geben">
|
|
<arrowlink DESTINATION="ID_1232898317" ENDARROW="Default" ENDINCLINATION="550;0;" ID="Arrow_ID_1329838760" STARTARROW="None" STARTINCLINATION="109;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018862802" ID="ID_1044555993" MODIFIED="1536329736419" TEXT="abgeleiteten Frame konstruieren">
|
|
<linktarget COLOR="#65a7b1" DESTINATION="ID_1044555993" ENDARROW="Default" ENDINCLINATION="70;92;" ID="Arrow_ID_575633930" SOURCE="ID_1532889609" STARTARROW="None" STARTINCLINATION="149;-3;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536857187385" FOLDED="true" ID="ID_1180686110" MODIFIED="1573229874089" TEXT="Bug! Referenz auf *this">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1536857213605" ID="ID_1051501156" MODIFIED="1536857238050" TEXT="...und dann moved man *this aus dem Builder!!!">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1536857284075" ID="ID_887891479" MODIFIED="1536857344032" TEXT="brauche *this...">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1536857289235" ID="ID_1909570040" MODIFIED="1536857313452" TEXT="in configureFilterChain"/>
|
|
<node CREATED="1536857326814" ID="ID_149310473" MODIFIED="1536857328426" TEXT="this->depth()"/>
|
|
<node CREATED="1536857336620" ID="ID_1691329557" MODIFIED="1536857806626" TEXT="this->stepChain_">
|
|
<linktarget COLOR="#d22d65" DESTINATION="ID_1691329557" ENDARROW="Default" ENDINCLINATION="147;-23;" ID="Arrow_ID_828211693" SOURCE="ID_396903078" STARTARROW="None" STARTINCLINATION="1;-33;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1536857741221" ID="ID_1903828771" MODIFIED="1536958903408" TEXT="bricht das ganze Konzept hier zusammen??">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#435e98" CREATED="1536880103264" HGAP="27" ID="ID_1970250282" MODIFIED="1536958907215" TEXT="so schaugts aus...." VSHIFT="-10">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1536857782632" ID="ID_396903078" MODIFIED="1536857806626" TEXT="stepChain_ ist das Problem">
|
|
<arrowlink COLOR="#d22d65" DESTINATION="ID_1691329557" ENDARROW="Default" ENDINCLINATION="147;-23;" ID="Arrow_ID_828211693" STARTARROW="None" STARTINCLINATION="1;-33;"/>
|
|
</node>
|
|
<node CREATED="1536880086127" ID="ID_1559582643" MODIFIED="1536882591818" TEXT="depth wohl noch ein Größeres">
|
|
<node CREATED="1536882781354" ID="ID_1998865921" MODIFIED="1536882788421" TEXT="weil daran die Abbruchbedingung hängt"/>
|
|
<node CREATED="1536882789057" ID="ID_170176785" MODIFIED="1536882873905" TEXT="und depth sich aber automatisch ergibt -> Backtracking"/>
|
|
</node>
|
|
<node CREATED="1536882920310" ID="ID_1625878480" MODIFIED="1536882937553" TEXT="eigentlich müßte...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nach der »reinen Lehre«
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1536882938955" FOLDED="true" ID="ID_475907399" MODIFIED="1561827483838" TEXT="der Baum entweder sich selber entfalten können">
|
|
<node CREATED="1536883521914" ID="ID_857765324" MODIFIED="1536883531340" TEXT="und dazu den Chain in sich tragen"/>
|
|
<node CREATED="1536883532120" ID="ID_153639655" MODIFIED="1536883537739" TEXT="und auch seinen eigenen Level kennen"/>
|
|
</node>
|
|
<node CREATED="1536882952177" FOLDED="true" ID="ID_563964508" MODIFIED="1561827483838" TEXT="oder von außerhalb entfaltet werden">
|
|
<node CREATED="1536883544846" ID="ID_224633668" MODIFIED="1536883607066" TEXT="dann aber auch die Entfaltung von außen bekommen"/>
|
|
<node CREATED="1536883607966" ID="ID_1870181162" MODIFIED="1536883618816" TEXT="also klassich-imperativ"/>
|
|
<node CREATED="1536883623932" ID="ID_567889201" MODIFIED="1536883629455" TEXT="nix Monade!"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1536958857294" ID="ID_1302534828" MODIFIED="1536958940320" TEXT="Fazit: nur der zweite Ansatz ist durchführbar">
|
|
<arrowlink COLOR="#81445a" DESTINATION="ID_1848331022" ENDARROW="Default" ENDINCLINATION="72;-412;" ID="Arrow_ID_1608996048" STARTARROW="None" STARTINCLINATION="672;68;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1536969411521" HGAP="36" ID="ID_1686255544" MODIFIED="1536969491348" TEXT="und selbst der braucht eine Art Hintertür" VSHIFT="8">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...insofern wir nämlich zwingend auf den jeweilign Kind-<i>Iterator</i> zugreifen müssen.
|
|
</p>
|
|
<p>
|
|
Nicht nur auf den aktuellen Wert (=dereferenzierter Iterator, d.h. die Funktion yield())
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018406232" ID="ID_1330264339" MODIFIED="1561827466037" TEXT="Schritte als Funktoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018684754" FOLDED="true" ID="ID_1076606298" MODIFIED="1573229877554" TEXT="geeignete Signatur für die Schritt-Funktoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536184281271" ID="ID_1736323474" MODIFIED="1536184299802" TEXT="Problem: Funktor-Signatur zu Beginn nicht bekannt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1536184313018" ID="ID_306473960" MODIFIED="1536184367056" TEXT="es würde genügen, wenn der Werttyp kompatibel ist">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1536184383689" ID="ID_1457889497" MODIFIED="1536184509943">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir <i>müssen </i>hier eine Festlegung treffen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil die Ergebnisse der einzelnen Schritt-Funktoren,
|
|
</p>
|
|
<p>
|
|
jeweils in den Auswertungs-Stack gepackt werden sollen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Daher müssen sie untereinander kompatibel sein.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536184509936" ID="ID_936035440" MODIFIED="1536184832177" TEXT="pragmatische Wahl: Kopie des Basis-Filters">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im typischen Fall kopiert man den Basis-Iterator,
|
|
</p>
|
|
<p>
|
|
und manipuliert dann einige Einstellungen auf diesem.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wir könnten diese Kopie-Semantik sogar <i>erzwingen,</i>
|
|
</p>
|
|
<p>
|
|
indem wir als Argument-Typ des Schritt-Funktors eine const& vorgeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536185340920" ID="ID_1706168706" MODIFIED="1536185362297" TEXT="also: konstruiere Pipeline mit Filter"/>
|
|
<node CREATED="1536185364045" ID="ID_301562283" MODIFIED="1536185381295" TEXT="dann: Filter -> Filter als Funktor vorgeben"/>
|
|
<node COLOR="#338800" CREATED="1536194368432" ID="ID_665607293" MODIFIED="1561827466042" TEXT="kniffelig in der Praxis">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
<node CREATED="1536194407802" ID="ID_752443094" MODIFIED="1536194421332" TEXT="der "Filter"-Typ ist in einen TreeExplorer gewrappt"/>
|
|
<node CREATED="1536194422544" ID="ID_1594827200" MODIFIED="1536194440618" TEXT="konkret ist der Quell-Typ aber nur ein IterableDecorator"/>
|
|
<node CREATED="1536194493975" ID="ID_1706559693" MODIFIED="1536194563398" TEXT="und der doppelt gewrappter Funktor....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...den ich mache, um den Adapter in jedem Einzelfall zu bekommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536194565261" ID="ID_892309176" MODIFIED="1536194581751" TEXT="...führt dazu, daß der innere Funktor ein Template ist"/>
|
|
<node CREATED="1536194582411" ID="ID_427362932" MODIFIED="1536194600916" TEXT="und deshalb mit IterableDecorator& ge-probed wird"/>
|
|
<node CREATED="1536195443615" ID="ID_1532213156" MODIFIED="1536195450119" TEXT="Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1536195452006" ID="ID_1758963929" MODIFIED="1536195513457" TEXT="IterableDecorator hat einen Wildcard-Konstruktor"/>
|
|
<node CREATED="1536195515142" ID="ID_207755200" MODIFIED="1536271102169" TEXT="deshalb scheint die Konvertierung string -> IterableDecorator möglich">
|
|
<linktarget COLOR="#d83e76" DESTINATION="ID_207755200" ENDARROW="Default" ENDINCLINATION="262;10;" ID="Arrow_ID_1979852913" SOURCE="ID_360255766" STARTARROW="None" STARTINCLINATION="262;5;"/>
|
|
</node>
|
|
<node CREATED="1536195621631" ID="ID_1458745075" MODIFIED="1536195633265" TEXT="...was dann aber im eingewickelten MutableFunctor scheitert"/>
|
|
<node CREATED="1536195633854" ID="ID_1469022446" MODIFIED="1536195641136" TEXT="(und ohnehin ein Schmarrrn wäre)"/>
|
|
</node>
|
|
<node CREATED="1536195694269" ID="ID_260759561" MODIFIED="1536273228593" TEXT="Lösung?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536195707299" ID="ID_1061111376" MODIFIED="1536273251780" TEXT="der innere Funktor ist generisch">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1536195819221" FOLDED="true" ID="ID_730902625" MODIFIED="1561827483839" TEXT="auf den flexiblen Adapter verzichten">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1536270307241" ID="ID_1232849452" MODIFIED="1536270310156" TEXT="bringt nix"/>
|
|
<node CREATED="1536270310936" ID="ID_1638227415" MODIFIED="1536270381734" TEXT="string -> IterableDecorator greift trotzdem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und fällt dann beim Instantiieren des Template auf die Schnautze
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536271061916" ID="ID_360255766" MODIFIED="1536271107605" TEXT="ist ein grundsätzliches Problem">
|
|
<arrowlink COLOR="#d83e76" DESTINATION="ID_207755200" ENDARROW="Default" ENDINCLINATION="262;10;" ID="Arrow_ID_1979852913" STARTARROW="None" STARTINCLINATION="262;5;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536271137786" FOLDED="true" ID="ID_618430280" MODIFIED="1561827483839" TEXT="Fehl-Konvertierung gezielt unterbinden">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1536271169845" ID="ID_481868916" MODIFIED="1536271374301">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sofern eine Initialisierung ausidem Source-Iterator <i>möglich ist</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536271209768" ID="ID_1767817102" MODIFIED="1536271396476" TEXT="...weil es dann grundsätzch nicht notwendig ist, eigens etwas zu tun"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536273280517" ID="ID_422856174" MODIFIED="1536273415840">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und sonst ist das <i>nicht wirklich</i> "kniffelig"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bloß sind die zig-fach geschachtelten Template-Typen,
|
|
</p>
|
|
<p>
|
|
die dann die Intantiierungs-Call-Hierarchie bevölkern,
|
|
</p>
|
|
<p>
|
|
nahezu unlesbar....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
AAber ... wenn es erst mal duch den Compiler ist,
|
|
</p>
|
|
<p>
|
|
dann <i>sollte </i>der Optimizer diese gesamten x-fachen Wrapper nahezu restlos entfernen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536273453876" HGAP="46" ID="ID_1094128800" MODIFIED="1536326529585" TEXT="verwende nun BoundFunctor<Filter(Filter const&)> als Signatur" VSHIFT="5">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1536273527418" ID="ID_180233427" MODIFIED="1536273554776">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konsequenz: jede Argument-Funktion wird <i>nochmal</i> gewrappt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1536273556422" ID="ID_368248341" MODIFIED="1536273569201" TEXT="...und kann damit auch ein generisches Lambda sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018696977" ID="ID_1710558292" MODIFIED="1536326467718" TEXT="Sequenz solcher Funktoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018923378" ID="ID_1163666446" MODIFIED="1561827466043" TEXT="Pipeline konstruieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018931433" FOLDED="true" ID="ID_1532889609" MODIFIED="1573229882688" TEXT="treeExplorer-Konfiguration">
|
|
<arrowlink COLOR="#65a7b1" DESTINATION="ID_1044555993" ENDARROW="Default" ENDINCLINATION="70;92;" ID="Arrow_ID_575633930" STARTARROW="None" STARTINCLINATION="149;-3;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536353107155" HGAP="33" ID="ID_1163131751" MODIFIED="1561827466043" TEXT="Problem: Basis-Layer" VSHIFT="37">
|
|
<arrowlink COLOR="#4471b4" DESTINATION="ID_942897075" ENDARROW="Default" ENDINCLINATION="37;-79;" ID="Arrow_ID_537236489" STARTARROW="None" STARTINCLINATION="30;44;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536353117930" ID="ID_625995057" MODIFIED="1536353132265" TEXT="hinzugefügt für "leeren" Zustand">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1536353133264" ID="ID_597888311" MODIFIED="1536353144626" TEXT="Backtracking in leeren Zustand">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1536357642662" ID="ID_77507334" MODIFIED="1536357654371" TEXT="Basis-Layer wird eigentlich nie mehr besucht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536353280436" ID="ID_967254721" MODIFIED="1561827466044" TEXT="Problem: clearFilter()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536353286739" ID="ID_1451254899" MODIFIED="1536353295077" TEXT="bauchen wir das überhaupt">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1536353310976" ID="ID_809196267" MODIFIED="1536353322688" TEXT=""Filter komplett abschalten"">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1536353297546" ID="ID_1841672356" MODIFIED="1536353306185" TEXT="war erst mal nur für Test">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536353335500" ID="ID_698525366" MODIFIED="1536717475219" TEXT="muß Stack der partiellen Auswertungen verwerfen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir sind irgendwo im Baum, nicht auf dem Basis-Layer.
|
|
</p>
|
|
<p>
|
|
Und der Basis-Layer steht irgendwo, nicht an der aktuellen Position.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#60a2d5" DESTINATION="ID_33678789" ENDARROW="Default" ENDINCLINATION="315;0;" ID="Arrow_ID_1930258825" STARTARROW="None" STARTINCLINATION="106;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536717586774" ID="ID_47823025" MODIFIED="1536717611106" TEXT="mit HIlfsfunktion im TreeExplorer / Expander einfach zu implementieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536115788134" ID="ID_1444917457" MODIFIED="1536281847097" TEXT="Problem: Basis-Typ inferieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536115842002" ID="ID_1601482334" MODIFIED="1536121336222" TEXT="resultiert aus treeExplorer-Aufruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536121365113" ID="ID_1114285918" MODIFIED="1536121373905" TEXT="const STL container unterstützen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536115852336" ID="ID_1044191557" MODIFIED="1536281849860" TEXT="muß aber geeignete Funktoren binden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018420398" ID="ID_41628967" MODIFIED="1537050023015" TEXT="Adaptieren der Quell-Datensequenz">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018880168" ID="ID_1619721301" MODIFIED="1536326442522" TEXT="macht normalerweise TreeExplorer">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1619721301" ENDARROW="Default" ENDINCLINATION="129;0;" ID="Arrow_ID_1721152439" SOURCE="ID_1700266521" STARTARROW="None" STARTINCLINATION="76;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018887223" ID="ID_832237706" MODIFIED="1537050024641" TEXT="speziell: gear switch">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018442123" ID="ID_829730232" MODIFIED="1536329759111" TEXT="Abkürzung für direkten Match">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018985450" ID="ID_1700266521" MODIFIED="1536329755895" TEXT="Wert-Typ deduzieren">
|
|
<arrowlink DESTINATION="ID_1619721301" ENDARROW="Default" ENDINCLINATION="129;0;" ID="Arrow_ID_1721152439" STARTARROW="None" STARTINCLINATION="76;-5;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536019008151" ID="ID_29813547" MODIFIED="1536329757422" TEXT="equality comparision in Lambda">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018471975" ID="ID_1115030606" MODIFIED="1537050027130" TEXT="Variante für bidirektionale Suche">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018956285" ID="ID_128441804" MODIFIED="1537050078736" TEXT="einfach CursorGear als Quelle verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536357666667" ID="ID_886527146" MODIFIED="1561827466049" TEXT="Design-Kritik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536357672802" ID="ID_2301559" MODIFIED="1536357696186" TEXT="aktuelles Design ist minimalistisch aber nicht elegant">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1536357853649" ID="ID_1868098250" MODIFIED="1536357864980" TEXT="API geradliniger als die interne Struktur">
|
|
<node CREATED="1536357700806" ID="ID_484166025" MODIFIED="1536357804847" TEXT="der Basis-Layer ist aufgrund des API vorhanden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
es ist praktisch, zunächst "leer" zu konstruieren
|
|
</li>
|
|
<li>
|
|
es ist verständlicher, wenn alle Bedingungen symmetrisch angegeben werden
|
|
</li>
|
|
<li>
|
|
es ist natürlich, daß ein "leerer" Filter alles durchläßt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536357809367" ID="ID_118025251" MODIFIED="1536357830652" TEXT="die clearFilter()-Funktion folgt derselben Logik">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Filter leer == alles durchlassen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536357878006" FOLDED="true" ID="ID_1225195123" MODIFIED="1573229898167" TEXT="Aufräumen und nachrüsten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536357891412" ID="ID_942897075" MODIFIED="1561827466050" TEXT="den Basis-Layer eliminieren">
|
|
<linktarget COLOR="#4471b4" DESTINATION="ID_942897075" ENDARROW="Default" ENDINCLINATION="37;-79;" ID="Arrow_ID_537236489" SOURCE="ID_1163131751" STARTARROW="None" STARTINCLINATION="30;44;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536357900635" ID="ID_646733499" MODIFIED="1536533192790" TEXT="brauche einen "leer"-Status im Filter">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536367745114" ID="ID_945289619" MODIFIED="1536367753030" TEXT="explizit als bool-Flag">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1536367754089" ID="ID_649387933" MODIFIED="1536533189307" TEXT="im Filter-Funktor verstecken">
|
|
<arrowlink COLOR="#67ac9b" DESTINATION="ID_109911994" ENDARROW="Default" ENDINCLINATION="1326;0;" ID="Arrow_ID_1556921295" STARTARROW="None" STARTINCLINATION="142;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536357917385" ID="ID_1615410357" MODIFIED="1536539160556" TEXT="wenn leer, dann direkt den Basis-Layer konfigurieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536357952068" ID="ID_876149668" MODIFIED="1536539163737" TEXT="nur an die Kette anfügen, wenn nicht leer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536539178616" HGAP="1" ID="ID_708494808" MODIFIED="1536632461895" TEXT="defekt" VSHIFT="20">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#338800" CREATED="1536539306399" FOLDED="true" ID="ID_639133520" MODIFIED="1561827483839" TEXT="Basis-Layer wird zwei mal gepullt">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536539323716" ID="ID_1627599615" MODIFIED="1536539353260" TEXT="einmal beim direkten Rekonfigurieren"/>
|
|
<node CREATED="1536539357408" ID="ID_834480997" MODIFIED="1536539373834" TEXT="dann nochmal generisch"/>
|
|
<node COLOR="#338800" CREATED="1536541001266" ID="ID_1480503625" MODIFIED="1536632457387" TEXT="in else-Zweig ziehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536539386764" ID="ID_487266350" MODIFIED="1536632452032" TEXT="erschöpfter Iter bricht ab">
|
|
<arrowlink COLOR="#c5789c" DESTINATION="ID_1288939799" ENDARROW="Default" ENDINCLINATION="99;3;" ID="Arrow_ID_1528021143" STARTARROW="None" STARTINCLINATION="-35;27;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536539286897" ID="ID_1288939799" MODIFIED="1561827466050" TEXT="overconstrained triggert Assertion">
|
|
<linktarget COLOR="#c5789c" DESTINATION="ID_1288939799" ENDARROW="Default" ENDINCLINATION="99;3;" ID="Arrow_ID_1528021143" SOURCE="ID_487266350" STARTARROW="None" STARTINCLINATION="-35;27;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536631251921" HGAP="51" ID="ID_588077559" MODIFIED="1536631280009" TEXT="sollte stattdessen leer werden" VSHIFT="23">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536357967826" ID="ID_634133289" MODIFIED="1561827466050" TEXT="clearFilter()">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536357973769" ID="ID_33678789" MODIFIED="1536358316984" TEXT="brauche Unterstützung vom Expander">
|
|
<linktarget COLOR="#60a2d5" DESTINATION="ID_33678789" ENDARROW="Default" ENDINCLINATION="315;0;" ID="Arrow_ID_1930258825" SOURCE="ID_698525366" STARTARROW="None" STARTINCLINATION="106;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536357986087" ID="ID_1097583555" MODIFIED="1536716860209" TEXT="rootCurrent()">
|
|
<arrowlink COLOR="#5c8eb4" DESTINATION="ID_255912594" ENDARROW="Default" ENDINCLINATION="1465;0;" ID="Arrow_ID_1700114612" STARTARROW="None" STARTINCLINATION="798;71;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536358193211" ID="ID_601406114" MODIFIED="1536716881154" TEXT="hebt aktuelle Sequenz auf Root-Level"/>
|
|
<node COLOR="#338800" CREATED="1536358204137" ID="ID_1724606451" MODIFIED="1536716878774" TEXT="verwirft den sonstigen Stack komplett"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536792181982" ID="ID_548701484" MODIFIED="1536846067609" TEXT="search direkt per Prädikat">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. direkt das Prädikat, und nicht eine Funktion, die den Filter konfiguriert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536792241949" ID="ID_613611906" MODIFIED="1536792249583" TEXT="setzt direkt nur ein neues Prädikat"/>
|
|
<node CREATED="1536792250124" ID="ID_10955924" MODIFIED="1536792257390" TEXT="spart viel Syntax ein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1536845264898" ID="ID_1033092941" MODIFIED="1536845289109" TEXT="Problem: capture forward">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1536845290596" ID="ID_1184113483" MODIFIED="1536845467915" TEXT="Lamda soll eine "universelle referenz" capturen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536845309386" ID="ID_1593606355" MODIFIED="1536845460398" TEXT="Ausweg: forward-into captured value">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536845374585" ID="ID_794602132" LINK="https://stackoverflow.com/a/20669290" MODIFIED="1536845438985" TEXT="geht seit C++14"/>
|
|
<node CREATED="1536845439219" FOLDED="true" ID="ID_372370252" MODIFIED="1561827483839" TEXT="nur Eclipse / CDT mault herum">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1536845496960" ID="ID_1490455562" MODIFIED="1536845539474" TEXT="und deshalb...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...habe ich noch gar nicht gemerkt, daß das geht,
|
|
</p>
|
|
<p>
|
|
und manchen komischen Workaround implementiert.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1536845594971" ID="ID_1942437093" MODIFIED="1536845602373" TEXT="Eclipse updaten?">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958590136" ID="ID_1848331022" MODIFIED="1537050002466" TEXT="Refactoring Pipeline-Struktur">
|
|
<linktarget COLOR="#81445a" DESTINATION="ID_1848331022" ENDARROW="Default" ENDINCLINATION="72;-412;" ID="Arrow_ID_1608996048" SOURCE="ID_1302534828" STARTARROW="None" STARTINCLINATION="672;68;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1536958603857" ID="ID_610488133" MODIFIED="1536958622137" TEXT="das ursprüngliche Implementierungs-Konzept scheitert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1536958626605" ID="ID_1277097786" MODIFIED="1536958638227" TEXT="aber ich will an dem Pipeline-Konzept festhalten">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1536958647378" ID="ID_270574796" MODIFIED="1536958666418" TEXT="Konsequenz: Schluß mit der Magie">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1536958668327" ID="ID_392267635" MODIFIED="1536977591699" TEXT="keine geheimnisvollen Lambda-Closures mehr">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958680150" ID="ID_1572201908" MODIFIED="1561827466054" TEXT="zwei Layer verwenden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536958702987" FOLDED="true" ID="ID_1313964418" MODIFIED="1561827483839" TEXT="Basis == trivialer Explorer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536958719665" ID="ID_806425486" MODIFIED="1536977595267" TEXT="macht lediglich eine Kopie des Filters">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536958727368" ID="ID_1206856632" MODIFIED="1536958732419" TEXT="nichts mehr automatisch"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958733950" FOLDED="true" ID="ID_374374485" MODIFIED="1561827483839" TEXT="Dekorator == Steuer-Logik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536958744325" ID="ID_151094681" MODIFIED="1536977615339" TEXT="hält den stepChain_">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958772594" FOLDED="true" ID="ID_365283571" MODIFIED="1561827482932" TEXT="klinkt sich in iterNext ein">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1536958792215" FOLDED="true" ID="ID_519507996" MODIFIED="1561827469160" TEXT="TreeExplorer: custom-Layer">
|
|
<arrowlink COLOR="#61afb3" DESTINATION="ID_686602920" ENDARROW="Default" ENDINCLINATION="-230;613;" ID="Arrow_ID_1710661685" STARTARROW="None" STARTINCLINATION="1241;-1305;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1536973229630" ID="ID_1567071992" MODIFIED="1536973238830" TEXT="brauche doch keinen Custom-Layer">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1536973239964" ID="ID_1858748865" MODIFIED="1536973282118" TEXT="ist besser ohne....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil ich dann auf dem IterChainSearch unmittelbar die builder-Funktionen definieren kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536977661129" FOLDED="true" ID="ID_700598895" MODIFIED="1561827469160" TEXT="Vorsicht: brauche nochmal IterableDecorator">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn: TreeExplorer == IterableDecorator< Pipeline >
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536977678590" ID="ID_747407291" MODIFIED="1537022078175" TEXT="sonst wird meine spezielle IterNext() nicht aufgerufen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der oberste Layer, also hier IterChainSearch
|
|
</p>
|
|
<p>
|
|
ist selbst ein StateCore. Also brauche ich noch einen Dekocator
|
|
</p>
|
|
<p>
|
|
Wenn der fehlt, wird der nächste darunterliegende Decorator gepullt,
|
|
</p>
|
|
<p>
|
|
und der wickellt direkt den Expander ein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1537022084564" ID="ID_447764404" MODIFIED="1537022104224" TEXT="brauche doch einen top-Level TreeExplorer + custom-Layer">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1537022109392" ID="ID_1885636592" MODIFIED="1537022142275" STYLE="fork" TEXT="pragmatisch: direkt auch operator++ überschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536958815668" FOLDED="true" ID="ID_327461551" MODIFIED="1561827482932">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
konfiguriert <i>danach direkt</i> den Filter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536969507092" ID="ID_1318810550" MODIFIED="1536977610592" TEXT="braucht dazu eine Hintertür im Explorer-Layer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1536969537728" ID="ID_1955805225" MODIFIED="1536969691123" TEXT="kann/darf diese nicht für Basis-Iterator nutzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil der Basis-Iterator (also der Template-Parameter SRC)
|
|
</p>
|
|
<p>
|
|
explizit und absichtlich einen anderen Typ haben <i>könnte,</i> als der expandierte Kind-Iterator.
|
|
</p>
|
|
<p>
|
|
Das ist ein wesentliches Feature dieses Expander-Designs, würde aber leider eine
|
|
</p>
|
|
<p>
|
|
komplett generische Accessor-Funktion unmöglich machen (das Template würde in
|
|
</p>
|
|
<p>
|
|
einem Solchen Fall insgesamt vom Compiler zurückgewiesen)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537022195013" ID="ID_1801625619" MODIFIED="1537050004022" TEXT="Korrektheit der Auswertungs-Logik">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537022206627" ID="ID_983878679" MODIFIED="1561827466055" TEXT="mit komplexem Funktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1537022226504" FOLDED="true" ID="ID_1825074472" MODIFIED="1561827483839" TEXT="faul?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sausage-bacon-tomato-and-sausage-spam-spam-bacon-spam-tomato-and-spam-spam-bacon-tomato-and-spam-bacon-tomato-and-spam-tomato-and-spam
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1537024323509" ID="ID_22995423" MODIFIED="1537024327665" TEXT="ja">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1537024330564" ID="ID_1923248765" MODIFIED="1537024353996" TEXT="das Element, auf das wir backtracken, kommt raus"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537024363024" ID="ID_197150338" MODIFIED="1537024376343" TEXT="muß nach Backtracking explizit neu aufsetzen und hochspulen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1537024386500" ID="ID_792998865" MODIFIED="1537024403713" TEXT="schon besser....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sausage-bacon-tomato-and-spam-spam-bacon-spam-tomato-and-spam-bacon-tomato-and-bacon-tomato-and-tomato-and
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1537022216506" ID="ID_794497840" MODIFIED="1537050005604" TEXT="mit Backtracking">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1535894132587" ID="ID_1888561007" MODIFIED="1537050042593" TEXT="Unit-Test: IterChainSearch_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1536018569210" ID="ID_1083474400" MODIFIED="1536018578102" TEXT="Test-Fixture">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1536018580388" ID="ID_186304417" MODIFIED="1536018584425" TEXT="lovely spam">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1536121351659" ID="ID_1756544626" MODIFIED="1536121358722" TEXT="const container">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018539621" ID="ID_1857591081" MODIFIED="1536717648741" TEXT="simpleSearch()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018544936" ID="ID_1750921303" MODIFIED="1537050039988" TEXT="chainedIteration()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1536018552912" ID="ID_385004210" MODIFIED="1537050041216" TEXT="backtracking()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1536015468698" ID="ID_1045359957" MODIFIED="1557498707236" TEXT="utils">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1536015471377" ID="ID_1732583592" MODIFIED="1557498707236" TEXT="regex-Iteratoren">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1536015489143" ID="ID_979562288" MODIFIED="1557498707236" TEXT="std::sregex_token_itertor"/>
|
|
<node CREATED="1536015509308" ID="ID_1011220828" MODIFIED="1557498707236" TEXT="geschickt verpacken"/>
|
|
<node CREATED="1536015513076" ID="ID_849722427" MODIFIED="1557498707236" TEXT="den Regex-Include opaque halten"/>
|
|
<node CREATED="1536015525154" ID="ID_1039059758" MODIFIED="1557498707236" TEXT="soll mal in util.hpp"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573230287134" ID="ID_1958309835" MODIFIED="1573230291318" TEXT="Concepts">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1573230307678" ID="ID_1856823830" MODIFIED="1573230336518" TEXT="»Lumiera Forward Iterator« integrieren"/>
|
|
</node>
|
|
<node CREATED="1540682664865" ID="ID_1702211999" MODIFIED="1557498707236" TEXT="Metaprogramming">
|
|
<node CREATED="1540682674455" ID="ID_1625152878" MODIFIED="1557498707236" TEXT="Typliste filtern">
|
|
<node CREATED="1540682680286" ID="ID_1172485112" MODIFIED="1557498707236" TEXT="nach canConvert">
|
|
<node CREATED="1540682731631" ID="ID_1059841081" MODIFIED="1557498707236" TEXT="die Typen, in die man umwandeln kann">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1540682747461" ID="ID_1097757447" MODIFIED="1557498707236" TEXT="sinnvoll zum Binden an Rec<GenNode>">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1540682686558" ID="ID_349304672" MODIFIED="1576282357968" TEXT="aber das eigentliche Problem ist...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wie bekommt man dann den konvertierten Wert 'raus.
|
|
</p>
|
|
<p>
|
|
Visitor ist entweder void, oder bool
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573230375839" ID="ID_270568302" MODIFIED="1573230382276" TEXT="policies">
|
|
<node CREATED="1573230393523" ID="ID_1929317164" MODIFIED="1573230398694" TEXT="wie viel const-correctness?">
|
|
<node CREATED="1573230673519" ID="ID_269010776" MODIFIED="1573230690445" TEXT="prefer immutable over const-correct">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573230399348" ID="ID_963172794" MODIFIED="1573230404213" TEXT="Rolle der Iteration">
|
|
<node CREATED="1573230406221" ID="ID_1939609996" MODIFIED="1573230435834" TEXT="als funktionale Quelle">
|
|
<arrowlink COLOR="#3f76e9" DESTINATION="ID_333704322" ENDARROW="Default" ENDINCLINATION="-542;0;" ID="Arrow_ID_1390962202" STARTARROW="None" STARTINCLINATION="183;24;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573230456930" ID="ID_1636521851" MODIFIED="1573230459836" TEXT="utils">
|
|
<node CREATED="1573230461194" ID="ID_225640230" MODIFIED="1573230465260" TEXT="knapp halten">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1573230469672" ID="ID_1095270711" MODIFIED="1573230478491" TEXT="minimale Includes haben absolute Priorität"/>
|
|
<node CREATED="1573230497284" ID="ID_1008077184" MODIFIED="1573230520598" TEXT="Subgruppen">
|
|
<node CREATED="1573230502540" ID="ID_1611372107" MODIFIED="1573230505064" TEXT="meta/util"/>
|
|
<node CREATED="1573230513506" ID="ID_197961459" MODIFIED="1573230516350" TEXT="ID-Helper"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1573230535302" ID="ID_1413538720" MODIFIED="1576282357968" TEXT=""contains" / Suche nur über Container">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
kein allgemeines Such-Framework bauen!
|
|
</li>
|
|
<li>
|
|
den Begriff des "Containers" knapp halten: was keine const_reference bietet, ist kein Container
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667336713909" ID="ID_259014029" MODIFIED="1667336726184" TEXT="Framework">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1667336734205" FOLDED="true" ID="ID_1054510557" MODIFIED="1667336746223" TEXT="Lumiera Time">
|
|
<node CREATED="1667336756809" ID="ID_286019153" MODIFIED="1667336765133" TEXT="lib::time::Time ist ein Zeitpunkt"/>
|
|
<node CREATED="1667336768112" ID="ID_120722451" MODIFIED="1667336788066" TEXT="lib::time::TimeValue ist ein interne Zeit-Implementierung"/>
|
|
<node CREATED="1667336795340" ID="ID_1772915486" MODIFIED="1667336809222" TEXT="lib::time::TimeSpan ist ein Intervall mit Start und Dauer"/>
|
|
<node CREATED="1667336814578" ID="ID_443069684" MODIFIED="1667337242282" TEXT="Quantisierung">
|
|
<node CREATED="1667336818154" ID="ID_228764070" MODIFIED="1667336839107" TEXT="TimeValue + symbolische Grid-Referenz"/>
|
|
<node CREATED="1667336841967" ID="ID_1852849270" MODIFIED="1667336856426" TEXT="Grid über das Advice-System publiziert"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667476797049" FOLDED="true" ID="ID_767502481" MODIFIED="1670204015059" TEXT="Diskussion: interne Zeitbasis">
|
|
<linktarget COLOR="#af1a4c" DESTINATION="ID_767502481" ENDARROW="Default" ENDINCLINATION="96;-430;" ID="Arrow_ID_1672039685" SOURCE="ID_1838246834" STARTARROW="None" STARTINCLINATION="-670;38;"/>
|
|
<linktarget COLOR="#535cb5" DESTINATION="ID_767502481" ENDARROW="Default" ENDINCLINATION="-9;23;" ID="Arrow_ID_1371034703" SOURCE="ID_368365221" STARTARROW="None" STARTINCLINATION="-97;6;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667486621881" ID="ID_566152244" MODIFIED="1667486629636" TEXT="#1258 clarify internal time base">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1667486644110" ID="ID_1984451593" MODIFIED="1667486648120" TEXT="Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1667486649845" ID="ID_93808620" MODIFIED="1667486680650" TEXT="grid-based Time-Scale kann niemals alle relevanten Werte exakt repräsentieren"/>
|
|
<node CREATED="1667486681289" ID="ID_1245609548" MODIFIED="1667486715504" TEXT="egal ob man nun floating-point nimmt, oder eine feste integrale Basis (µ-Ticks)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667486847011" ID="ID_1394182591" MODIFIED="1667486860346" TEXT="sehe folgende Lösungen">
|
|
<linktarget COLOR="#b3a5d6" DESTINATION="ID_1394182591" ENDARROW="Default" ENDINCLINATION="-42;135;" ID="Arrow_ID_1017363931" SOURCE="ID_945218071" STARTARROW="None" STARTINCLINATION="-118;6;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1667486862210" ID="ID_860525476" MODIFIED="1667487583167" TEXT="Umstellen auf Bruch-Darstellung">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1667487232831" ID="ID_1006730826" MODIFIED="1667487247673" TEXT="rein auf logischer Basis wäre das die 1.Wahl"/>
|
|
<node CREATED="1667487249733" ID="ID_344272813" MODIFIED="1667487263783" TEXT="hat aber möglicherweise einen starken Performance-Impact">
|
|
<node CREATED="1667487265203" ID="ID_1416124429" MODIFIED="1667487277405" TEXT="doppelt so viel Daten pro Zeitpunk"/>
|
|
<node CREATED="1667487277956" ID="ID_1373749694" MODIFIED="1667487299330" TEXT="gcd-Normalisierung nach jeder Multiplikation"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667486880606" ID="ID_293148639" MODIFIED="1667487585840" TEXT="mehrere Basis-Zeitformate erlauben">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1667486901227" ID="ID_869733709" MODIFIED="1667486908494" TEXT="eines davon wäre dann FSecs"/>
|
|
<node CREATED="1667486909138" ID="ID_1371778930" MODIFIED="1667486921835" TEXT="ein anderes das µ-Grid"/>
|
|
<node CREATED="1667486924968" ID="ID_1851075217" MODIFIED="1667486937530" TEXT="Integration problematisch">
|
|
<node CREATED="1667486951149" ID="ID_1186754865" MODIFIED="1667486966790" TEXT="std::chrono macht genau dies">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1667486938994" ID="ID_1194275689" MODIFIED="1667486950390" TEXT="erfordert Metaprogrammierung"/>
|
|
<node CREATED="1667486968874" ID="ID_782557379" MODIFIED="1667487226117" TEXT="Alternative: breite APIs">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Man würde also neben das Standard-Format ein toleriertes zweites Format stellen, welches dann ein Bürger zweiter Klasse wäre, aber auf allen wichtien APIs als 2.Alternative mit auftaucht. Zudem würde man gewisse Abkürzungs-Pfade schaffen, auf denen die alternative Spec dann <i>verlustfrei durchgereicht </i>werden kann.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
es ist überhaupt nicht klar, welches Format dann der Standardfall sein sollte
|
|
</li>
|
|
<li>
|
|
das läuft vor allem auf eine Performance-Betrachtung hinaus, und einen trade-off, wo man ggfs Fehler durch andere Programmierer akzeptiert
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1667487313780" ID="ID_605045817" MODIFIED="1667487588066" TEXT="Problem nur umgehen">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1667487323563" ID="ID_255906636" MODIFIED="1667487341802" TEXT="es sind ja nur ganz wenige Stellen, die mit einem µ-Grid wirklich Probleme haben"/>
|
|
<node CREATED="1667487342753" ID="ID_463347104" MODIFIED="1667487469159">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn man zum µ-Grid eine eindeutige Rundungs-Regel hinzufügt,
|
|
</p>
|
|
<p>
|
|
kann es praktisch auch Sound-Samples korrekt addressieren:<br /><br />1/96000 ≙ 10,41666666666666666667 <i>µTicks</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1667487486510" ID="ID_1354208250" MODIFIED="1667487501583" TEXT="Notwendigkeit einer genaueren Behandlung per Metadaten durchreichen">
|
|
<node CREATED="1667487512650" ID="ID_968209763" MODIFIED="1667487526228" TEXT=""dies sind 96kHz-Samples""/>
|
|
<node CREATED="1667487528568" ID="ID_745033416" MODIFIED="1667487546865" TEXT="dann kann eine Implementierung "downstream" mit Divisor arbeiten"/>
|
|
<node CREATED="1667487547957" ID="ID_1232559601" MODIFIED="1667487568454" TEXT="und Output geht an die Soundkarte mit 96kHz"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592184752" ID="ID_1933332619" MODIFIED="1667592189752" TEXT="Aufräum-Arbeiten">
|
|
<linktarget COLOR="#d42360" DESTINATION="ID_1933332619" ENDARROW="Default" ENDINCLINATION="120;134;" ID="Arrow_ID_1382957344" SOURCE="ID_1052463489" STARTARROW="None" STARTINCLINATION="-43;-56;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592193783" ID="ID_1808934689" MODIFIED="1667592204255" TEXT="#1259 organise raw time base implementation">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1667592218952" ID="ID_1463501252" MODIFIED="1667592230199" TEXT="Einsichten">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1667592232354" ID="ID_1809679126" MODIFIED="1667592268849" TEXT="die unterliegende Roh-Implementierung wird stets „durchscheinen“"/>
|
|
<node CREATED="1667592285128" ID="ID_945218071" MODIFIED="1667592349554">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Besonderen bei den <i>pragmatischen Lösungen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b3a5d6" DESTINATION="ID_1394182591" ENDARROW="Default" ENDINCLINATION="-42;135;" ID="Arrow_ID_1017363931" STARTARROW="None" STARTINCLINATION="-118;6;"/>
|
|
<icon BUILTIN="full-2"/>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1667592366001" ID="ID_170684768" LINK="#ID_745987096" MODIFIED="1667592483713" TEXT="Zeit-Berechnungen brauchen einen validen Zugang">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1667592593027" ID="ID_1398816169" MODIFIED="1667592611842" TEXT="Aufgaben">
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592613824" ID="ID_1877249067" MODIFIED="1667593560997" TEXT="keine externen Library-Typen mehr im normalen Implementierungs code">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1667592632302" ID="ID_1344505411" MODIFIED="1667592635745" TEXT="boost::rational"/>
|
|
<node CREATED="1667592636666" ID="ID_392219650" MODIFIED="1667592641529" TEXT="gavl_time_t"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592643724" ID="ID_504422240" MODIFIED="1667592665218" TEXT="LibGavl-Dependency hier entfernen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1667592666825" ID="ID_1632149108" MODIFIED="1667592677380" TEXT="so sehr ich Gavl im allgemeinen gut finde"/>
|
|
<node CREATED="1667592677944" ID="ID_130946855" MODIFIED="1667592698682" TEXT="wir brauchen keine Lib um einen int64_t zu deklarieren">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1667592700101" ID="ID_942374659" MODIFIED="1667592737240" TEXT="ansonsten wird Gavl nicht / noch nicht verwendet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und ganz im Besonderen: wir stützen uns für die Zeitbehandlung nicht auf libGavl ab
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593471839" ID="ID_1651396499" MODIFIED="1670203676799" TEXT="gavl_time_t ersetzen durch Wrapper MicroTicks">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593606149" ID="ID_1259605001" MODIFIED="1670203652106" TEXT="_raw() ⟶ _microTicks()">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203683451" ID="ID_937451574" MODIFIED="1670203743053" TEXT="direkt konvertierbar auf int64_t">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203743874" ID="ID_1876693617" MODIFIED="1670203758849" TEXT="nicht direkt konvertierbar aus time::Time">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592743130" ID="ID_675688540" MODIFIED="1667593547383">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
FSecs durch einen neuen Wrapper <font face="Monospaced" color="#1e178c"><b>RSec</b></font> ersetzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1667592790281" ID="ID_1680785799" MODIFIED="1667592800092" TEXT="außerdem den neuen lib/rational.hpp hier einbinden"/>
|
|
<node CREATED="1667592805748" ID="ID_290360900" MODIFIED="1667592820329" TEXT="explizit als Typ RSec verwenden für alle Konvertierungen"/>
|
|
<node CREATED="1667592821013" ID="ID_289952678" MODIFIED="1667592916791" TEXT="RSec">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592825916" ID="ID_66335543" MODIFIED="1667592941549" TEXT="implizit konstruierbar aus Rat">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592930415" ID="ID_569654636" MODIFIED="1670203770202" TEXT="implizit konstruierbar aus time::Time">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667592835795" ID="ID_1955597942" MODIFIED="1667592942626">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>nicht</b> implizit konstruierbar aus int64_t
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1667592866911" ID="ID_416309268" MODIFIED="1667592869523" TEXT="ganz wichtig"/>
|
|
<node CREATED="1667592870151" ID="ID_1316405427" MODIFIED="1667592884425" TEXT="denn int64_t impliziert µ-Ticks"/>
|
|
<node CREATED="1667592895059" ID="ID_556517411" MODIFIED="1667592912143" TEXT="sollte explizit konstruierbar sein, mit Skalen-Transformation"/>
|
|
</node>
|
|
<node CREATED="1667592989079" ID="ID_531764150" MODIFIED="1667593020006" TEXT="minimale Arithmetik-Integration mit Time und Duration"/>
|
|
<node CREATED="1667593029266" ID="ID_1518807557" MODIFIED="1667593045317" TEXT="aber Zeit-Größen nur explizit konstruierbar (= Status quo)"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593084541" ID="ID_737389227" MODIFIED="1667593105376" TEXT="C-Library effektiv entfernen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1667593106935" ID="ID_1453484901" MODIFIED="1667593139782" TEXT="ich will keine C-Implementierungen mehr">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1667593146938" ID="ID_572582896" MODIFIED="1667593420308" TEXT="die C-Library verführt dazu, das Time-Framework zu umgehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...seinerzeit fand ich diese Art »Offenheit« noch gut; auch weil ich mir erhoffte, damit mehr Contributors zu bekommen. Die Erfahrungen sprechen dagegen; klar, die Leute mögen erst einmal gerne „move fast and break things“ — aber wenn dann Aufräumen oder anstrengende Konzeptions-Arbeit notwendig würde, bleibt alles liegen und man verschwindet aus dem Projekt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593164461" ID="ID_1585303440" MODIFIED="1667593241126" TEXT="Umbau">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593169047" ID="ID_377190169" MODIFIED="1667593239462" TEXT="Header umbenennen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593179870" ID="ID_1823116307" MODIFIED="1667593239462" TEXT="Header und Implementierung in C++">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593196675" ID="ID_530670970" MODIFIED="1667593239463" TEXT="plain-C-Tests in C++-Tests umziehen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667593209815" ID="ID_1675418151" MODIFIED="1667593239463" TEXT="Hinweise aus Dokumentation entfernen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1667336859796" ID="ID_1810244902" MODIFIED="1667337099718" TEXT="Timecode">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1667336865688" ID="ID_1539710424" MODIFIED="1667336875998" TEXT="kann aus einer lib::time::QuTime erzeugt werden"/>
|
|
<node CREATED="1667336880473" ID="ID_789960595" MODIFIED="1667337093278" TEXT="Stand 2011... (2022) nur SMPTE-Format implementiert">
|
|
<icon BUILTIN="flag-orange"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1670203198923" FOLDED="true" ID="ID_195957857" MODIFIED="1670204958743" TEXT="Design-Kritik">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1670203232878" ID="ID_368365221" MODIFIED="1670204032769" TEXT="Verhältnis zur Implementierungs-Basis unklar">
|
|
<arrowlink COLOR="#535cb5" DESTINATION="ID_767502481" ENDARROW="Default" ENDINCLINATION="-9;23;" ID="Arrow_ID_1371034703" STARTARROW="None" STARTINCLINATION="-97;6;"/>
|
|
</node>
|
|
<node CREATED="1670203264566" ID="ID_428273621" MODIFIED="1670203286172" TEXT="Debugging und Testcode schafft doch literale Zugänge"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203289398" ID="ID_809304620" MODIFIED="1670203870830" TEXT="Immutabilität erscheint fragwürdig">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1667770629647" ID="ID_1236820860" MODIFIED="1670203851793" TEXT="#1261 reconsider (im)mutability of time entities">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670204619655" ID="ID_1759515738" MODIFIED="1670204679042" TEXT="TimeVar für Berechnungen niveliert semantische Markierung">
|
|
<linktarget COLOR="#f2343e" DESTINATION="ID_1759515738" ENDARROW="Default" ENDINCLINATION="166;8;" ID="Arrow_ID_1959295757" SOURCE="ID_1588461392" STARTARROW="None" STARTINCLINATION="-129;-5;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670204052113" ID="ID_1534149938" MODIFIED="1670204073846" TEXT="Problem mit der Werte-Limitierung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670204087132" ID="ID_1403269339" MODIFIED="1670204092980" TEXT="#1263 consistent clipping of time duration">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1670204097323" ID="ID_1011988316" MODIFIED="1670204161413" TEXT="Offset und Duration braucht eine andere (größere) Domäne">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Begründung: sie entstehen als Delta aus validen Zeitpunkten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1670204169634" ID="ID_1754685572" MODIFIED="1670204363701" TEXT="Refactoring Offset-Konstruktion">
|
|
<linktarget COLOR="#26b81b" DESTINATION="ID_1754685572" ENDARROW="Default" ENDINCLINATION="331;-981;" ID="Arrow_ID_636518434" SOURCE="ID_1491328900" STARTARROW="None" STARTINCLINATION="-1095;84;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1670204184655" ID="ID_1092716549" MODIFIED="1670204199898" TEXT="Offset macht nun die Limitierungen"/>
|
|
<node CREATED="1670204200509" ID="ID_699139338" MODIFIED="1670204213099" TEXT="delegiert dazu an einen protected-ctor auf TimeValue"/>
|
|
<node CREATED="1670204214419" ID="ID_1562184209" MODIFIED="1670204223542" TEXT="Duration macht nur noch den Absoutbetrag"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1670204367479" ID="ID_600631420" MODIFIED="1670204378958" TEXT="Design noch nicht optimal">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1670204381408" ID="ID_12412150" MODIFIED="1670204393672" TEXT="Zugang zur Limitierungsfunktion problematisch">
|
|
<node CREATED="1670204394437" ID="ID_328468461" MODIFIED="1670204422149" TEXT="sollte protected sein">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1670204407834" ID="ID_1521072795" MODIFIED="1670204413020" TEXT="kein general-purpose Util"/>
|
|
<node CREATED="1670204413617" ID="ID_1825520187" MODIFIED="1670204420067" TEXT="Limitierung sollte nicht wahlfrei sein"/>
|
|
</node>
|
|
<node CREATED="1670204429399" ID="ID_256174974" MODIFIED="1670204448043" TEXT="braucht damit aber unterscheidbare ctor-Signatur">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1670204461587" ID="ID_1011570785" MODIFIED="1670204488608" TEXT="Limitierung auf dem Basis-ctor kommt in die Quere">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1670204449421" ID="ID_788489713" MODIFIED="1670204497787" TEXT="muß deshalb x-fach ein/auspacken">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670204511138" ID="ID_1144294293" MODIFIED="1670204539603" TEXT="Limitierung tritt in Arrithmetik ehr zufällig auf">
|
|
<node CREATED="1670204540718" ID="ID_1255308536" MODIFIED="1670204561965" TEXT="es ist praktisch nicht vorhersagbar, wann limitiert wird"/>
|
|
<node CREATED="1670204592570" ID="ID_1588461392" MODIFIED="1670204684420" TEXT="das liegt an dem transparenten Übergang in TimeVar">
|
|
<arrowlink COLOR="#f2343e" DESTINATION="ID_1759515738" ENDARROW="Default" ENDINCLINATION="166;8;" ID="Arrow_ID_1959295757" STARTARROW="None" STARTINCLINATION="-129;-5;"/>
|
|
</node>
|
|
<node CREATED="1670204715456" ID="ID_647133339" MODIFIED="1670204719419" TEXT="Wunsch">
|
|
<node CREATED="1670204720743" ID="ID_87999446" MODIFIED="1670204735721" TEXT="LImitieren bei expliziten Konstruktoren (semantische Markierung)"/>
|
|
<node CREATED="1670204736590" ID="ID_1752769748" MODIFIED="1670204759294" TEXT="nahtloser Einstieg in Arithmetik aus allen Typen"/>
|
|
<node CREATED="1670204764337" ID="ID_591425903" MODIFIED="1670204776244" TEXT="Ergebnis-Typ nach inhaltlicher Logik">
|
|
<node CREATED="1670204803999" ID="ID_1882907381" MODIFIED="1670204814909" TEXT="Differenz ⟹ Offset"/>
|
|
<node CREATED="1670204815956" ID="ID_672733611" MODIFIED="1670204833364" TEXT="Linearkombination: Zeitpunkte bzw. Offsets"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1670203323167" ID="ID_1083592054" MODIFIED="1670203328942" TEXT="Refactoring">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203333148" ID="ID_1052463489" MODIFIED="1670203824726" TEXT="Wrapper für die Implementierungs-Basis">
|
|
<arrowlink COLOR="#d42360" DESTINATION="ID_1933332619" ENDARROW="Default" ENDINCLINATION="120;134;" ID="Arrow_ID_1382957344" STARTARROW="None" STARTINCLINATION="-43;-56;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203448666" ID="ID_1420123614" MODIFIED="1670203482999" TEXT="MicroTick ersetzt gavl_time_t">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203464680" ID="ID_349050555" MODIFIED="1670203482999" TEXT="RSec ersetzt FSecs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203472359" ID="ID_1087095065" MODIFIED="1670203483000" TEXT="bisherige C-Library auflösen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1670203346727" ID="ID_1489900097" MODIFIED="1670203553277" TEXT="time::Time als Basis">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1670203370236" ID="ID_974452608" MODIFIED="1670203375393" TEXT="algebraisch und mutable"/>
|
|
<node CREATED="1670203376013" ID="ID_72780058" MODIFIED="1670203381494" TEXT="TimeVar komplett entfernen"/>
|
|
<node CREATED="1670203387130" ID="ID_1357163033" MODIFIED="1670203395404" TEXT="time::Mutation komplett entfernen"/>
|
|
</node>
|
|
<node CREATED="1670203401635" ID="ID_135612509" MODIFIED="1670203425528" TEXT="Design der Zeit-Enitäten verifizieren"/>
|
|
<node CREATED="1670203429905" ID="ID_1045402545" MODIFIED="1670203445062" TEXT="Algebra / Operatoren konsolidieren"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1670203488757" ID="ID_1532708654" MODIFIED="1670203541963" TEXT="time::Control anpassen und vereinfachen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1670203509562" ID="ID_1543321531" MODIFIED="1670203517718" TEXT="soll weiterhin">
|
|
<node CREATED="1670203518560" ID="ID_1636215930" MODIFIED="1670203523492" TEXT="als Mediator fungieren"/>
|
|
<node CREATED="1670203524072" ID="ID_758755449" MODIFIED="1670203535578" TEXT="die verschiedenen Ziel-Typen nivellieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482524641484" ID="ID_1651495185" MODIFIED="1557498707236" TEXT="Architektur">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1544199543455" ID="ID_970297070" MODIFIED="1557498707236" TEXT="Struktur">
|
|
<node CREATED="1544199550166" ID="ID_16943853" MODIFIED="1557498707236" TEXT="Layer">
|
|
<node CREATED="1544199559524" ID="ID_1685135526" MODIFIED="1557498707236" TEXT="rein gedankliche Gliederung"/>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1544199565372" FOLDED="true" ID="ID_39523665" MODIFIED="1576282357967" TEXT="(neue)Namen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
denke etwa seit einem halben Jahr darüber nach.
|
|
</li>
|
|
<li>
|
|
bisher hatte ich mich nicht getraut...
|
|
</li>
|
|
<li>
|
|
im September mit Benny besprochen (per Mail). Seine Reaktion klang sogar begeistert; das hat mich ermutigt
|
|
</li>
|
|
<li>
|
|
natürlich ist es eine Menge Arbeit, aber jetzt, wo ich allein bin, kann ich sowas einfach durchziehen, ohne daß es zerredet wird
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1544199568851" ID="ID_1812468720" MODIFIED="1544199771897" TEXT="Stage">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node COLOR="#435e98" CREATED="1544199791747" ID="ID_852392563" MODIFIED="1544199874242" TEXT="interaction layer">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544199811227" ID="ID_799439008" MODIFIED="1544199868636">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bisher <i>"GUI"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544199916181" ID="ID_398666439" MODIFIED="1544199920920" TEXT="stage and backstage"/>
|
|
</node>
|
|
<node CREATED="1544199570723" ID="ID_1872450664" MODIFIED="1544199772984" TEXT="Steam">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node COLOR="#435e98" CREATED="1544199800697" ID="ID_778136654" MODIFIED="1544199879626" TEXT="translation layer">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544199822802" ID="ID_1885697959" MODIFIED="1544199858919">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bisher <i>"Proc-Layer"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544199922788" ID="ID_40712142" MODIFIED="1544199936342" TEXT="where does the actual magic happen?"/>
|
|
</node>
|
|
<node CREATED="1544199573307" ID="ID_730329516" MODIFIED="1544199773973" TEXT="Vault">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node COLOR="#435e98" CREATED="1544199808170" ID="ID_1715886507" MODIFIED="1544199883499" TEXT="adaptation layer">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544199828825" ID="ID_830501554" MODIFIED="1544199848431">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bisher <i>"Backend"</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544199952785" ID="ID_1989078064" MODIFIED="1544199955148" TEXT="deep down"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584202142543" ID="ID_1162501513" MODIFIED="1584202145125" TEXT="Subsysteme"/>
|
|
<node CREATED="1584202146097" ID="ID_876294763" MODIFIED="1584202148362" TEXT="ETD">
|
|
<node CREATED="1584202158174" ID="ID_1136082827" MODIFIED="1584202164409" TEXT="inhärente Einschränkungen">
|
|
<node CREATED="1584202165470" ID="ID_1464264076" MODIFIED="1584202167873" TEXT="Diff-System">
|
|
<node CREATED="1584202213999" ID="ID_795618786" MODIFIED="1584202220155" TEXT="Ausdrucksformen">
|
|
<node CREATED="1584202221198" ID="ID_1125078676" MODIFIED="1584202224996" TEXT="Population"/>
|
|
<node CREATED="1584202225838" ID="ID_510134595" MODIFIED="1584202239327" TEXT="Mutation">
|
|
<node CREATED="1584202244254" ID="ID_900246695" MODIFIED="1584202249039" TEXT="Umordnen"/>
|
|
<node CREATED="1584202249610" ID="ID_663093917" MODIFIED="1584202253667" TEXT="Hinzufügen / Löschen"/>
|
|
</node>
|
|
<node CREATED="1584202239940" ID="ID_1326489257" MODIFIED="1584202242808" TEXT="Wert-Manipulation"/>
|
|
</node>
|
|
<node CREATED="1584201875333" ID="ID_1634323626" MODIFIED="1584202923362" TEXT="Konstruktor vs. Populations-Diff">
|
|
<linktarget COLOR="#2e3f60" DESTINATION="ID_1634323626" ENDARROW="Default" ENDINCLINATION="-1672;80;" ID="Arrow_ID_1671674197" SOURCE="ID_1310327519" STARTARROW="None" STARTINCLINATION="-1407;99;"/>
|
|
<node CREATED="1584202280926" ID="ID_1191279412" MODIFIED="1584202293547" TEXT="Objekte geben Invarianten via Konstruktor vor"/>
|
|
<node CREATED="1584202294330" ID="ID_930873161" MODIFIED="1584202321186" TEXT="INS liefert einen Wert ohne Einschränkungen"/>
|
|
<node CREATED="1584202321796" ID="ID_78459313" MODIFIED="1584202344074" TEXT="Diskrepanz -> Policy">
|
|
<node CREATED="1584202427011" ID="ID_187571593" MODIFIED="1584202439683" TEXT="Default: leere Hülle nur mit ID"/>
|
|
<node CREATED="1584202441233" ID="ID_1377510165" MODIFIED="1584202571097" TEXT="Strukturmodel und Ctor im Einzelfall abgestimmt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn im Einzelfall bereits mit der INS-Nachricht bestimmte global sichtbare Properties mit gegeben sein müssen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
dann bedeutet das, auch das betreffende Objekt erzwingt diese als Invariante per ctor
|
|
</li>
|
|
<li>
|
|
und das Struktur-Modell verlangt per Konvention an dieser Stelle das Senden eines entsprechenden Rumpf-Record
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1584202179452" ID="ID_149859727" MODIFIED="1584202181656" TEXT="Datentypen"/>
|
|
</node>
|
|
<node CREATED="1584202591061" ID="ID_413326869" MODIFIED="1584202595479" TEXT="Struktur-Modell">
|
|
<node CREATED="1584202600843" ID="ID_306089528" MODIFIED="1584202604263" TEXT="per Domäne">
|
|
<node CREATED="1584202604970" ID="ID_192625861" MODIFIED="1584202873530" TEXT="für das GUI">
|
|
<arrowlink COLOR="#3041c7" DESTINATION="ID_165150753" ENDARROW="Default" ENDINCLINATION="-3211;307;" ID="Arrow_ID_1316612875" STARTARROW="None" STARTINCLINATION="-1533;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1531419748046" ID="ID_1791265013" MODIFIED="1557498707236" TEXT="Lebenszyklus">
|
|
<node COLOR="#338800" CREATED="1531419790153" ID="ID_1605635763" MODIFIED="1582443076662" TEXT="#1145 define startup sequence">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531419814485" ID="ID_373568821" MODIFIED="1557498707236" TEXT="#1146 complete application startup sequence">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531419837826" ID="ID_719335579" MODIFIED="1557498707236" TEXT="#1147 establish UI start-up sequence">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1531420231598" ID="ID_1997153046" MODIFIED="1557498707236" TEXT="#1148 populate initial session">
|
|
<arrowlink COLOR="#665692" DESTINATION="ID_1392317817" ENDARROW="Default" ENDINCLINATION="-1993;202;" ID="Arrow_ID_609042013" STARTARROW="Default" STARTINCLINATION="1943;108;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1582443973100" HGAP="47" ID="ID_1989055863" MODIFIED="1582443988612" TEXT="getriggert von InteractionDirector::populateContent_afterStart()" VSHIFT="22">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482524498822" ID="ID_431883229" MODIFIED="1557498707236" TEXT="Datenstrom">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567302856" ID="ID_599503027" MODIFIED="1680567686765" TEXT="Output-Management">
|
|
<icon BUILTIN="stop"/>
|
|
<node CREATED="1680567318639" ID="ID_1726615423" MODIFIED="1680567321766" TEXT="Verdrahtung">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567648993" ID="ID_1721405470" MODIFIED="1680567663524" TEXT="Grundkonzept">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1681340561579" ID="ID_852560386" MODIFIED="1681340580970" TEXT="Output-Protokoll">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681340585412" ID="ID_1620112929" MODIFIED="1681340749166" TEXT="TODO: ownership + Fehlerbehandlung für »Allocation« nochmal überdenken">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es fällt auf, daß ich in dem Entwurf von 2011 die Allocation selber nur als Referenz rausgegeben habe, und dann für jeden darauf eröffneten Slot ein smart-Handle. Zunächst einmal sieht das <i>vernünftig</i>  aus, weil die Slots typischerweise sofort noch im gleichen Thread belegt werden. Was ist aber wenn...↯ — kann sich dann die belegte Allocation <i>verklemmen?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681340821574" ID="ID_91498886" LINK="https://issues.lumiera.org/ticket/878" MODIFIED="1681340858985" TEXT="#878 OutputSlot lifecycle and re-entrance">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680567322328" ID="ID_1487342906" MODIFIED="1680567331604" TEXT="externe Schnittstellen"/>
|
|
<node CREATED="1680567342943" ID="ID_1794041409" MODIFIED="1680567346762" TEXT="Video-Widergabe">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680567215056" ID="ID_1644608240" MODIFIED="1680567628091" TEXT="Einbinden: GUI-Output-Manager">
|
|
<linktarget COLOR="#fe756b" DESTINATION="ID_1644608240" ENDARROW="Default" ENDINCLINATION="-1507;-562;" ID="Arrow_ID_246148002" SOURCE="ID_73360951" STARTARROW="None" STARTINCLINATION="-591;33;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482524516371" ID="ID_396707258" MODIFIED="1557498707236" TEXT="Event-Sourcing">
|
|
<node CREATED="1539135156755" ID="ID_1302245670" MODIFIED="1557498707236" TEXT="vermittelnder Träger">
|
|
<node CREATED="1539134733747" ID="ID_1189184036" MODIFIED="1557498707236" TEXT="DiffConstituent">
|
|
<linktarget COLOR="#4e31e2" DESTINATION="ID_1189184036" ENDARROW="Default" ENDINCLINATION="-767;-123;" ID="Arrow_ID_156898929" SOURCE="ID_353086867" STARTARROW="None" STARTINCLINATION="-1608;-84;"/>
|
|
<linktarget COLOR="#4e31e2" DESTINATION="ID_1189184036" ENDARROW="Default" ENDINCLINATION="-432;-65;" ID="Arrow_ID_1794591374" SOURCE="ID_1179407482" STARTARROW="None" STARTINCLINATION="-1379;-131;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1539134841549" ID="ID_818387120" MODIFIED="1557498707236" TEXT="neues Konzept">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1539134848420" ID="ID_4911843" MODIFIED="1557498707236" TEXT="ein selbstbezüglicher substanzloser Strukturkern"/>
|
|
<node CREATED="1539134911707" ID="ID_847488848" MODIFIED="1557498707236" TEXT="DiffConstituent -> emanation as diff"/>
|
|
<node CREATED="1539395579133" ID="ID_589161293" MODIFIED="1557498707236" TEXT="Anforderungen">
|
|
<node CREATED="1539395591547" ID="ID_1807468145" MODIFIED="1557498707236" TEXT="Population-Diff erzeugen"/>
|
|
<node CREATED="1539395603034" ID="ID_1342955865" MODIFIED="1557498707236" TEXT="Delta-Diff erzeugen">
|
|
<node CREATED="1539395609169" ID="ID_1189203662" MODIFIED="1557498707236" TEXT="muß exakt den vorherigen Stand kennen"/>
|
|
<node CREATED="1539395620120" ID="ID_1953087376" MODIFIED="1576282357967" TEXT="Stichwort: asynchrone Kommunkiation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GUI und Session schicken Nachrichten.
|
|
</p>
|
|
<p>
|
|
Während der Builder läuft, kann das GUI schon weitere Nachrichten geschickt haben,
|
|
</p>
|
|
<p>
|
|
die dann noch in der ProcDispatcher-Queue hängen. Daher kann sich die Antwort
|
|
</p>
|
|
<p>
|
|
als Resultat auf einen Builder-Lauf noch auf einen vorherigen Zustand beziehen.
|
|
</p>
|
|
<p>
|
|
Es kann aber auch ein Builder-Lauf die kummulierten Ergebnisse von mehreren Commands behandeln.
|
|
</p>
|
|
<p>
|
|
In jedem Fall muß der DiffConstituent genau wissen, was der zuletzt geschickte Stand war,
|
|
</p>
|
|
<p>
|
|
damit er einen Diff erzeugt, der garantiert auf der anderen Seite anwendbar ist.
|
|
</p>
|
|
<p>
|
|
Denn letzteres ist bei uns eine Grundannahme. Es gibt keine ungefähren Diffs!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544840221709" ID="ID_790020807" MODIFIED="1557498707236" TEXT="Aufbereiten gemäß »systematisches UI-Modell«">
|
|
<arrowlink COLOR="#5f7288" DESTINATION="ID_531041967" ENDARROW="Default" ENDINCLINATION="-964;-27;" ID="Arrow_ID_603305631" STARTARROW="None" STARTINCLINATION="1678;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539270491013" ID="ID_1435731309" MODIFIED="1557498707236" TEXT="Problem der korrekten Diff-Struktur">
|
|
<arrowlink COLOR="#d47366" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="590;-127;" ID="Arrow_ID_308349501" STARTARROW="None" STARTINCLINATION="915;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1482524530842" FOLDED="true" ID="ID_606738640" MODIFIED="1573230611958" TEXT="Dependency-Injection">
|
|
<icon BUILTIN="wizard"/>
|
|
<node CREATED="1515975589922" ID="ID_367021032" MODIFIED="1538868806804" TEXT="Architektur">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522738923747" ID="ID_1842493496" MODIFIED="1522738930926" TEXT="feste Ordnung der Komponenten"/>
|
|
<node CREATED="1522738931490" ID="ID_1729361793" MODIFIED="1522738935077" TEXT="Lebenszyklus"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1515975593614" ID="ID_79714950" MODIFIED="1538868845282" TEXT="Technik">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Frühjahr 2018 komplett überarbeitet.
|
|
</p>
|
|
<p>
|
|
Lösung scheint nun "rund" zu sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1515975596673" ID="ID_1304673048" MODIFIED="1515975599660" TEXT="für Services">
|
|
<node CREATED="1515975622405" ID="ID_962877206" MODIFIED="1515975633971" TEXT="Dependency-Injection-Manager">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1515975635484" ID="ID_225934542" MODIFIED="1538868853937" TEXT="einfache Lösungen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1515975650458" ID="ID_1359158691" MODIFIED="1522738941329" TEXT="Serivice by-Name">
|
|
<linktarget COLOR="#b6829b" DESTINATION="ID_1359158691" ENDARROW="Default" ENDINCLINATION="1134;-1646;" ID="Arrow_ID_927211935" SOURCE="ID_1305671938" STARTARROW="None" STARTINCLINATION="1359;916;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1515975677462" ID="ID_1848164117" MODIFIED="1515975685784" TEXT="Problem: Lebenszyklus">
|
|
<node COLOR="#338800" CREATED="1492094235291" FOLDED="true" HGAP="36" ID="ID_451964727" MODIFIED="1563022756032" TEXT="#1086 unify Depend singleton and instance management" VSHIFT="-20">
|
|
<linktarget COLOR="#7188b5" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="2227;-4042;" ID="Arrow_ID_1654818003" SOURCE="ID_871055051" STARTARROW="None" STARTINCLINATION="775;393;"/>
|
|
<linktarget COLOR="#5c71a3" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="767;-2073;" ID="Arrow_ID_1454095581" SOURCE="ID_1714114896" STARTARROW="None" STARTINCLINATION="1892;380;"/>
|
|
<linktarget COLOR="#8697be" DESTINATION="ID_451964727" ENDARROW="Default" ENDINCLINATION="200;-562;" ID="Arrow_ID_1211717131" SOURCE="ID_1032947061" STARTARROW="None" STARTINCLINATION="1387;-152;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520722130803" ID="ID_1194364308" MODIFIED="1561827466066" TEXT="Anforderungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1520722192387" ID="ID_1178804552" MODIFIED="1520722204325" TEXT="leicht zu verwenden">
|
|
<node CREATED="1520722210416" ID="ID_18853847" MODIFIED="1520722214920" TEXT="access by-name"/>
|
|
<node CREATED="1520722205225" ID="ID_187805501" MODIFIED="1520722209444" TEXT="klare einfache Syntax"/>
|
|
<node CREATED="1520722223159" ID="ID_1464262858" MODIFIED="1520722243728" TEXT="geringer Overhead beim Zugriff"/>
|
|
</node>
|
|
<node CREATED="1520722250315" ID="ID_1739587251" MODIFIED="1520722257494" TEXT="Standard-Fall: Singleton">
|
|
<node CREATED="1520722258346" ID="ID_601560365" MODIFIED="1520722263109" TEXT="meint: lazy initialisation"/>
|
|
</node>
|
|
<node CREATED="1520722285614" ID="ID_243579470" MODIFIED="1520722297840" TEXT="rekonfigurierbar als Service">
|
|
<node CREATED="1520722553009" ID="ID_186796738" MODIFIED="1520722562724" TEXT="Service-Instanz kontrolliert Lebenszyklus"/>
|
|
<node CREATED="1520722565023" ID="ID_705029613" MODIFIED="1520722569219" TEXT="kann geschlossen werden"/>
|
|
</node>
|
|
<node CREATED="1520722582981" ID="ID_412048061" MODIFIED="1520722588312" TEXT="Konfigurierbarkeit" VGAP="2">
|
|
<node CREATED="1520722616336" ID="ID_609325041" MODIFIED="1520722635842" TEXT="Policy">
|
|
<node CREATED="1520722600227" ID="ID_1619106434" MODIFIED="1520722604870" TEXT="klar"/>
|
|
<node CREATED="1520722606698" ID="ID_1509953000" MODIFIED="1520722608430" TEXT="sicher"/>
|
|
<node CREATED="1520722594371" ID="ID_1430939011" MODIFIED="1520722647022" TEXT="ad hoc"/>
|
|
</node>
|
|
<node CREATED="1520722662066" ID="ID_1398252383" MODIFIED="1520722668845" TEXT="Eigenschaften">
|
|
<node CREATED="1520722689638" ID="ID_555318445" MODIFIED="1520722702296" TEXT="Service"/>
|
|
<node CREATED="1520723536370" ID="ID_98564224" MODIFIED="1520723551009" TEXT="Mockbarkeit"/>
|
|
<node CREATED="1520722720322" ID="ID_1574090447" MODIFIED="1520722762564" TEXT="Implementierung"/>
|
|
</node>
|
|
<node CREATED="1521081597008" HGAP="23" ID="ID_198915567" MODIFIED="1561827466071" TEXT="Design-Schlußfolgerungen" VSHIFT="11">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521081661071" ID="ID_500707872" MODIFIED="1533608414048" TEXT="Lösung-1">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
war im Einsatz seit Beginn der Lumiera-Projektes.
|
|
</p>
|
|
<p>
|
|
Wurde aufgegeben da
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die Policies komplexe Lösungsvarianten implementierten, die nie gebraucht wurden
|
|
</li>
|
|
<li>
|
|
die Implementierung einen tückischen Fehler in CLang aufgedeckt hat
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521081684036" ID="ID_1402765741" MODIFIED="1521081692822" TEXT="Polycy-based"/>
|
|
<node CREATED="1521081693419" ID="ID_889786982" MODIFIED="1521081703773" TEXT="Spezialisierung des Depend-Templates"/>
|
|
<node CREATED="1521081709169" ID="ID_390237547" MODIFIED="1521081723794" TEXT="ein zentraler Header, wird per depend.hpp includiert"/>
|
|
<node CREATED="1521081724766" ID="ID_1002030069" MODIFIED="1521081739408" TEXT="erfordert Forwards aller zu spezialisierenden Payload-Typen"/>
|
|
</node>
|
|
<node CREATED="1521081775631" ID="ID_1326847098" MODIFIED="1533608414048" TEXT="Lösung-2">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Im Einsatz seit der Behebung des CLang-Problems bis heute (3/2018).
|
|
</p>
|
|
<p>
|
|
Wird nun aufgegeben, da sich auf dieser Basis keine DI implementieren läßt,
|
|
</p>
|
|
<p>
|
|
welche auf einem Service mit explizitem Lebenszyklus beruht.
|
|
</p>
|
|
<p>
|
|
Außerdem stellte sich diese Lösung als ziemlich fragil heraus
|
|
</p>
|
|
<p>
|
|
und benötigt diverse Laufzeit-Konsistenzchecks, die den Implementierungscode schwer lesbar machen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521081796836" ID="ID_1599810209" MODIFIED="1521081803975" TEXT="Zuweisung eines Factory-Funktors"/>
|
|
<node CREATED="1521082335930" ID="ID_1689932476" MODIFIED="1521082347044" TEXT="via Depend-Instanz-Initialisierung"/>
|
|
<node CREATED="1521082503275" ID="ID_230807085" MODIFIED="1521082510286" TEXT="erst zur Laufzeit"/>
|
|
<node CREATED="1521082510738" ID="ID_1074113096" MODIFIED="1521082525452" TEXT="jederzeit und an beliebiger Stelle möglich"/>
|
|
<node CREATED="1521082548173" ID="ID_1948451513" MODIFIED="1521082559567" TEXT="Konsistenz nur per Laufzeit-Check"/>
|
|
<node CREATED="1521082560611" ID="ID_1943270534" MODIFIED="1521082576132" TEXT="fragil da von Init-Ordnung abhängig"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1521082621363" ID="ID_1344462005" MODIFIED="1538868598480" TEXT="Lösung-NEU">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1521082670076" ID="ID_916083959" MODIFIED="1521160630521" TEXT="geeignete Technik gesucht">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1521082703384" ID="ID_510028220" MODIFIED="1561827466072" TEXT="Anforderungen / Wünsche">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1521082629322" ID="ID_1026313608" MODIFIED="1521082657826" TEXT="Storage und Zugriffs-Steuerung in einem Modul zusammen"/>
|
|
<node CREATED="1521083235390" ID="ID_816115467" MODIFIED="1521153348286" TEXT="Konfiguration ad hoc, am Ort des Service-Providers"/>
|
|
<node CREATED="1521083250124" ID="ID_914104558" MODIFIED="1521154409699" TEXT="Optional per Mix-In an die Provider-Instanz gebunden"/>
|
|
<node CREATED="1521083332673" ID="ID_1445046036" MODIFIED="1521083346179" TEXT="temporär global schattierbar für Test-Mocking"/>
|
|
<node CREATED="1521083598077" ID="ID_1129579564" MODIFIED="1521083604836" TEXT="Problem Konsistenz">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521158992344" ID="ID_985106186" MODIFIED="1538868483324" TEXT="Fazit">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1521159000968" ID="ID_1381648131" MODIFIED="1521159186533">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bei <i>diesem</i> Wunsch-Profil bleibt nur eine Variante von <b>Lösung-2</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn nur eine dynamische Laufzeit-Factory ermöglicht, <i>jederzeit</i>  den Konstruktionsmodus zu wechseln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1521159238935" ID="ID_1109622706" MODIFIED="1521159663752" TEXT="Ein Instanz-Pointer ist zwingend notwendig und auch besser">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn nur ein Instanz-Pointer kann umgebogen oder auf NULL zurückgesetzt werden.
|
|
</p>
|
|
<p>
|
|
Der einzige Ausweg aus diesem Dilemma wäre eine statische Lösung,
|
|
</p>
|
|
<p>
|
|
in der bereits durch den #include von lib/depend.hpp endgültig klar wäre,
|
|
</p>
|
|
<p>
|
|
was für eine Art von Dependency-Factory zum Einsatz kommen soll. Denn nur auf <i>diesem</i>
|
|
</p>
|
|
<p>
|
|
Weg könnte der Optimiser unmittelbar auf eine Singleton-Instanz im statischen Speicher
|
|
</p>
|
|
<p>
|
|
zugreifen, nach einem Check auf ein atomic<bool>.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Eine solche statische Lösung allerdings widerspricht nicht nur meinen Wünschen,
|
|
</p>
|
|
<p>
|
|
sondern wäre auch architektonisch ungünstig, denn dadurch
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
entsteht eine zentrale DI-Konfiguration
|
|
</li>
|
|
<li>
|
|
erfolgt eine Rückverkopplung von lib/depend.hpp auf die Applikations-Struktur
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521159870784" ID="ID_1588722588" MODIFIED="1521160019955" TEXT="der Zugang zur DependencyFactory ist stets ein virtueller Funktionsaufruf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn er muß komplett generisch sein, und lib/depend.hpp darf keinerlei Kenntnis
|
|
</p>
|
|
<p>
|
|
über die konkrete DependencyFactory voraussetzen. Denn sonst würden wir die
|
|
</p>
|
|
<p>
|
|
Freiheit der dynamischen Laufzeit-Konfiguration verlieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521160020971" ID="ID_1097297428" MODIFIED="1521160553255" TEXT="Deshalb sollte die Factory konventionell implementiert werden, nicht als Lambda">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn ein Lambda kann in dieser Lage grundsätzlich keinen optimierungs-Vorteil bringen,
|
|
</p>
|
|
<p>
|
|
und die konventionelle Lösung hat demgegenüber den Vorteil, daß sie Struktur und Kontrakt explizit macht.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521160107759" ID="ID_669924852" MODIFIED="1521239034598" TEXT="Das Konsistenz-Problem ist in Wirklichkeit ein Architekturproblem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es läuft darauf hinaus, daß die Nutzung eines Dienstes zwar <i>on demand</i> erfolgt,
|
|
</p>
|
|
<p>
|
|
jedoch <i>stets erst nach</i> seiner Bereitstellung. So etwas läßt sich niemals über einzelne
|
|
</p>
|
|
<p>
|
|
technische Einrichtungen lösen, denn es ist eine Frage des Aufbaues der gesamten Applikation.
|
|
</p>
|
|
<p>
|
|
Es gibt hierfür nur zwei Lösungswege
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
dynamisch: man definiert alle Abhängigkeiten durch Regeln und zieht das System nach Bedarf konsistent hoch, was bedingt, daß <i>alle </i>Abhängigkeiten über diesen Mechanismus laufen müssen
|
|
</li>
|
|
<li>
|
|
statisch: man strukturiert das System so, daß Nutzer erst nach dem Hochfahren der von ihnen benötigten Subsysteme aktiv sein können
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9c1bb" DESTINATION="ID_669924852" ENDARROW="Default" ENDINCLINATION="795;125;" ID="Arrow_ID_949036001" SOURCE="ID_1505788760" STARTARROW="None" STARTINCLINATION="779;51;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520722136029" ID="ID_1922898574" MODIFIED="1561827466075" TEXT="Problem: double checked locking">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1520725664365" ID="ID_1453945091" MODIFIED="1520725671423" TEXT="was bringt C++11?">
|
|
<node CREATED="1520725673123" ID="ID_574000501" LINK="http://preshing.com/20130930/double-checked-locking-is-fixed-in-cpp11/" MODIFIED="1520726129608" TEXT="Jeff Preshings: double-checked-locking-is-fixed-in-cpp11"/>
|
|
<node CREATED="1520726409894" ID="ID_1296403824" LINK="http://www.modernescpp.com/index.php/thread-safe-initialization-of-a-singleton" MODIFIED="1520726425377" TEXT="Rainer Grimm: thread local initialization of singletons"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520726342863" ID="ID_1875729983" MODIFIED="1531584013606" TEXT="moderne Lösung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1520726350894" ID="ID_47446040" MODIFIED="1522421521283" TEXT="Atomics">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522421526272" ID="ID_406901713" MODIFIED="1522421532577" TEXT="Performance sehr gut"/>
|
|
<node CREATED="1522421537122" ID="ID_1012365029" MODIFIED="1522421553659" TEXT="nahe an einem direkten lokalen Zugriff"/>
|
|
<node CREATED="1522421554271" ID="ID_1930807074" MODIFIED="1522421564034" TEXT="etwa halb so schnell wie DCL alleine"/>
|
|
<node CREATED="1522421564582" ID="ID_596046075" MODIFIED="1522421575992" TEXT="Zugriff etwa 1 Nanosekunde">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1520726354878" ID="ID_1241761015" MODIFIED="1522421518773" TEXT="vorgeschaltetes thread_local">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1520726364612" ID="ID_818685184" MODIFIED="1520726369804" TEXT="Performance nicht klar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1521160832611" ID="ID_1479783938" MODIFIED="1521161094120">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>scheidet</i> für unser Nutzungsmuster aus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es bedutet effektiv, daß viele Instanz-Zeiger "herumfliegen",
|
|
</p>
|
|
<p>
|
|
welche man in einer zentralen Registry erfassen müßte, um sie bei Bedarf
|
|
</p>
|
|
<p>
|
|
wieder auf NULL zurücksetzen zu können.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520722149761" ID="ID_39179906" MODIFIED="1531584013616" TEXT="neue Implementierung" VGAP="6">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521160662691" FOLDED="true" ID="ID_1475127406" MODIFIED="1563022738735" TEXT="Design Syntax und Nutzungsmuster">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521161117092" ID="ID_672223000" MODIFIED="1521161119935" TEXT="Syntax">
|
|
<node CREATED="1521161120859" ID="ID_1236102866" MODIFIED="1521161279265" TEXT="Depend<Bla> instance"/>
|
|
<node CREATED="1521161130050" ID="ID_1706757665" MODIFIED="1521161170232" TEXT="instance().doIt()"/>
|
|
<node CREATED="1521161171324" ID="ID_744864215" MODIFIED="1521330199058" TEXT="DependInject<Bla>::useSingleton<UnterBla>"/>
|
|
<node CREATED="1521161572133" ID="ID_1327949928" MODIFIED="1521330165247" TEXT="DependInject<Bla>::ServiceInstance<UnterBla> service{p1, p2, p3}"/>
|
|
<node CREATED="1521161634205" ID="ID_619508229" MODIFIED="1521330190739" TEXT="DependInject<Bla>::Local<UnterBla> mock"/>
|
|
<node CREATED="1521161919893" ID="ID_1606842354" MODIFIED="1521161929704" TEXT="mock->doItSpecial()"/>
|
|
</node>
|
|
<node CREATED="1521207954859" ID="ID_631339002" MODIFIED="1521418307590" TEXT="Analyse">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1521208242178" ID="ID_539882602" MODIFIED="1533608414052" TEXT="erforderliche Mechanismen">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1521208254376" ID="ID_1933406851" MODIFIED="1561827466082" TEXT="Singleton">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521208339124" ID="ID_287433738" MODIFIED="1521696567487" TEXT="Closure über konkreten Ctor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208339124" ID="ID_826329078" MODIFIED="1521696572039" TEXT="(optional)Closure mit speziellen Argumenten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209708336" ID="ID_1667188609" MODIFIED="1521332921903" TEXT="Storage für UnterBla-Instanz bereitstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208380663" ID="ID_1434723425" MODIFIED="1521332927022" TEXT="neuen lazy-init-Service-Zugang in Depend<Bla> installieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208395181" ID="ID_1161468794" MODIFIED="1521332931094" TEXT="Check, ob der vorher dort bestehende Zugang bereits verwendet wurde">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208451621" ID="ID_1429591553" MODIFIED="1521332932846" TEXT="Exception aus DependInject, falls ja">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208257336" ID="ID_1129640741" MODIFIED="1561827466083" TEXT="ServiceInstance">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521208859989" ID="ID_549061661" MODIFIED="1521387920055" TEXT="Lazy-Init-Factory deaktivieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208793630" ID="ID_1357481546" MODIFIED="1521335430941" TEXT="Service-Zugang in Depend<Bla> injizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208889297" ID="ID_214019029" MODIFIED="1521335434588" TEXT="Lebenszyklus-Koppelung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. Service-Zugang wird automatisch geschlossen,
|
|
</p>
|
|
<p>
|
|
wenn die DependInject-Instanz stirbt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208943105" ID="ID_295121984" MODIFIED="1521335440371" TEXT="Ownership an übergebener Service-Impl übernehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208724943" ID="ID_1527628667" MODIFIED="1521335442003" TEXT="smart-ptr-artiger Zugriff auf die Service-Impl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521208339124" FOLDED="true" ID="ID_1092066450" MODIFIED="1561827483839" TEXT="(optional)Closure über konkreten Ctor">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521688310369" ID="ID_1697840327" MODIFIED="1521688369496" TEXT="sinnlos">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sie werden ja sofort ausgewertet, da die Service-Instanz unmittelbar gebaut wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521688321599" ID="ID_764253251" MODIFIED="1521688339230" TEXT="stattdessen: ctor-Argumente forwarden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208261887" ID="ID_384054163" MODIFIED="1561827466085" TEXT="Local">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521209044203" ID="ID_1994153994" MODIFIED="1521696576989" TEXT="(optional)Closure mit speziellen Argumenten ">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209708336" ID="ID_1870723126" MODIFIED="1521411844636" TEXT="Storage für UnterBla-Instanz bereitstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209447572" ID="ID_1106858165" MODIFIED="1521411847148" TEXT="bestehenden Service-Zugang aus Depend<Bla> beiseite speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209547606" ID="ID_1693604174" MODIFIED="1521411853636" TEXT="temporär neuen Service-Zugang in Depend<Bla> installieren, an erzeugte Closure delegierend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209759585" FOLDED="true" ID="ID_267047467" MODIFIED="1561827483839" TEXT="Lebenszyklus-Koppelung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521209811802" ID="ID_1712617923" MODIFIED="1521411860363" TEXT="für die UnterBla-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521209827775" ID="ID_280216675" MODIFIED="1521411861265" TEXT="für den temporär installierten Service-Zugang">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521208724943" ID="ID_221402501" MODIFIED="1521411863017" TEXT="smart-ptr-artiger Zugriff auf die Service-Impl">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521209904013" FOLDED="true" ID="ID_1098048607" MODIFIED="1561827483839" STYLE="fork" TEXT="debug/Kontroll-API">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521209958014" ID="ID_1638584681" MODIFIED="1521411938195" TEXT="Lebenszustand">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521209945287" FOLDED="true" ID="ID_42798820" MODIFIED="1561827482933" TEXT="Erzeugen/Zerstören der Instanz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521411917770" ID="ID_50731939" MODIFIED="1521411938195" TEXT="YAGNI"/>
|
|
</node>
|
|
<node CREATED="1521210051457" ID="ID_1794637059" MODIFIED="1521411938195" TEXT="explizites Deinstallieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521213011289" ID="ID_1360216253" MODIFIED="1533608414058" TEXT="Vereinheitlichung">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1521213017168" ID="ID_1734833663" MODIFIED="1561827466087" TEXT="alle Varianten">
|
|
<node CREATED="1521213036670" ID="ID_1288760048" MODIFIED="1521416387077" TEXT="sind move-only">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521213116611" ID="ID_1639434185" MODIFIED="1521213127773" TEXT="enthalten eine Closure über einen konkreten Ctor"/>
|
|
<node CREATED="1521213855997" ID="ID_1959805856" MODIFIED="1521213868751" TEXT="installieren eine mit dieser parametrisierte Factory"/>
|
|
<node CREATED="1521236923444" FOLDED="true" ID="ID_909632246" MODIFIED="1561827483840" TEXT="irgendwie...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1521236930715" ID="ID_1673303474" MODIFIED="1521236948604" TEXT="managen alle die Service-Instanz"/>
|
|
<node CREATED="1521236972917" ID="ID_513518069" MODIFIED="1521236991993">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>aber</b> Lebenszyklus ist an die Factory gebunden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521236997978" ID="ID_937624268" MODIFIED="1521237012251" TEXT="...und im Fall Singleton lebt die Factory länger"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521237050866" ID="ID_306994173" MODIFIED="1561827466088" TEXT="die Factory">
|
|
<node CREATED="1521237057169" FOLDED="true" ID="ID_1684411297" MODIFIED="1561827483840" TEXT="ist stets stateless">
|
|
<node CREATED="1521237078919" ID="ID_576191440" MODIFIED="1521237088921" TEXT="Zustand steckt im instance-Ptr"/>
|
|
<node CREATED="1521237089413" ID="ID_961860289" MODIFIED="1521237111238" TEXT="Zustand steckt im DependInject-Lebenszyklus"/>
|
|
</node>
|
|
<node CREATED="1521237387044" ID="ID_1004256215" MODIFIED="1521237394199" TEXT="speichert aber eine konkrete Closure"/>
|
|
<node CREATED="1521237410713" ID="ID_1848566975" MODIFIED="1521237417420" TEXT="der default-Fall könnte generisch sein"/>
|
|
</node>
|
|
<node CREATED="1521238550267" ID="ID_722062331" MODIFIED="1561827466089" TEXT="Ort für Storage">
|
|
<node CREATED="1521238557210" FOLDED="true" ID="ID_674365093" MODIFIED="1561827483840" TEXT="für die Factory">
|
|
<node CREATED="1521238571832" ID="ID_53152012" MODIFIED="1521238597166" TEXT="Heap">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1521238576920" FOLDED="true" ID="ID_1251870411" MODIFIED="1561827482933" TEXT="in DependInject">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521238764190" ID="ID_1859795284" MODIFIED="1521238777840" TEXT="für zwei Fälle ist das die natürliche Wahl"/>
|
|
<node CREATED="1521238796793" ID="ID_1719458168" MODIFIED="1521238815844" TEXT="den ersten Fall (Singleton) quetschen wir hier mit rein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1521242379731" ID="ID_1396082906" MODIFIED="1521242418936" TEXT="erzwingt lokalen Typ oder opaque holder">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521240566398" FOLDED="true" ID="ID_1596629515" MODIFIED="1561827482933" TEXT="in den Trampolin-Funktionen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521242426269" ID="ID_256868222" MODIFIED="1521242434728" TEXT="normalerweise inline"/>
|
|
<node CREATED="1521242435292" ID="ID_503349041" MODIFIED="1521242454674" TEXT="automatisch heap-alloziert für komplexe closure">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521238641935" FOLDED="true" ID="ID_1638918713" MODIFIED="1561827483840" TEXT="Factory-Trampolin">
|
|
<node CREATED="1521238662196" ID="ID_1029621449" MODIFIED="1521238671488" TEXT="Heap">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1521238665347" FOLDED="true" ID="ID_1310408215" MODIFIED="1561827482933" TEXT="statisch">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521238747512" ID="ID_183342291" MODIFIED="1521238753603" TEXT="bietet sich an..."/>
|
|
<node CREATED="1521238754287" ID="ID_1930878495" MODIFIED="1521238758794" TEXT="paßt zum Design-Stil"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521238885741" HGAP="116" ID="ID_378163884" MODIFIED="1521238895249" TEXT="Stil-Fragen" VSHIFT="-29">
|
|
<node CREATED="1521238918577" ID="ID_592274908" MODIFIED="1521238925476" TEXT="Wunsch: unscheinbar-elegant"/>
|
|
<node CREATED="1521238926208" ID="ID_1895053354" MODIFIED="1521238933626" TEXT="explizite "Maschinerie" vermeiden"/>
|
|
<node CREATED="1521239771475" ID="ID_658740954" MODIFIED="1521239917171" TEXT="Storage ist wenn möglich statisch"/>
|
|
<node BACKGROUND_COLOR="#e3d49b" COLOR="#990000" CREATED="1521238998374" ID="ID_1505788760" MODIFIED="1521239221405" TEXT="keine Architektur-Fragen technisch "lösen"">
|
|
<arrowlink COLOR="#a9c1bb" DESTINATION="ID_669924852" ENDARROW="Default" ENDINCLINATION="795;125;" ID="Arrow_ID_949036001" STARTARROW="None" STARTINCLINATION="779;51;"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1521239059741" ID="ID_1063831478" MODIFIED="1533608414063" TEXT="Grenzfälle ausklammern">
|
|
<node CREATED="1521239073363" ID="ID_1392431590" MODIFIED="1521239273497" STYLE="fork" TEXT="Shutdown von Singletons">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1521239466149" ID="ID_178901788" MODIFIED="1521239728744" TEXT="Local schattiert Lebensende">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Folgendes Szenario ignorieren wir:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
eine Dependency ist als Service konfiguriert
|
|
</li>
|
|
<li>
|
|
für einen Testmock wird eine Local-Konfiguration darübergelegt
|
|
</li>
|
|
<li>
|
|
der Service wechselt seinen Lebenszyklus-Status (aktiv/inaktiv)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
⟹ der Service zerschießt den Local, oder der Local restauriert am Ende den bereits toten Service.
|
|
</p>
|
|
<p>
|
|
Har Har Har! Selber schuld wer sowas macht.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521169086441" ID="ID_284471203" MODIFIED="1522557526161" TEXT="Design">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521240056932" ID="ID_1189728630" MODIFIED="1533608414064" TEXT="Strukturen">
|
|
<node CREATED="1521240105285" ID="ID_711335043" MODIFIED="1561827466092" TEXT="Dependency-Factory">
|
|
<node CREATED="1521240317600" FOLDED="true" ID="ID_1626104494" MODIFIED="1561827483840" TEXT="Design-1">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521240110948" ID="ID_219745040" MODIFIED="1521240117087" TEXT="ist ein Interface"/>
|
|
<node CREATED="1521240117611" ID="ID_786865088" MODIFIED="1521240124694" TEXT="nicht getemplated"/>
|
|
<node CREATED="1521240284429" ID="ID_1132898054" MODIFIED="1521240294807" TEXT="eingebettetes getyptes Trampolin"/>
|
|
<node CREATED="1521240298267" ID="ID_116565565" MODIFIED="1521240312364" TEXT="Folge: static_cast nach Factory-Aufruf"/>
|
|
</node>
|
|
<node CREATED="1521240336717" FOLDED="true" ID="ID_468626388" MODIFIED="1561827483840" TEXT="Design-2">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521241524730" ID="ID_267557752" MODIFIED="1521241530652" TEXT="ist generisches Front-End"/>
|
|
<node CREATED="1521241625115" ID="ID_469205839" MODIFIED="1521241635214" TEXT="bietet API zum (re)Konfigurieren"/>
|
|
<node CREATED="1521241544559" FOLDED="true" ID="ID_1174783081" MODIFIED="1561827482933" TEXT="nur eine Funktion konfigurierbar">
|
|
<node CREATED="1521241553590" ID="ID_1087180465" MODIFIED="1521241560816" TEXT="entweder ins Trampolin eingebettet"/>
|
|
<node CREATED="1521241561380" ID="ID_437866764" MODIFIED="1521241569823" TEXT="oder als Funktionszeiger"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1521245885376" ID="ID_1336783261" MODIFIED="1521416492280" TEXT="könnte komplett wegfallen">
|
|
<linktarget COLOR="#b4a9c1" DESTINATION="ID_1336783261" ENDARROW="Default" ENDINCLINATION="224;0;" ID="Arrow_ID_37940927" SOURCE="ID_870619413" STARTARROW="None" STARTINCLINATION="83;-7;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522389217216" FOLDED="true" ID="ID_1137026613" MODIFIED="1561827483840" TEXT="bekommt neue Rolle">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522389224063" ID="ID_913743224" MODIFIED="1522389235913" TEXT="speichert ctor und automatischen dtor"/>
|
|
<node CREATED="1522389236525" ID="ID_773636278" MODIFIED="1522389243256" TEXT="übernimmt das Managen der Objekte"/>
|
|
<node CREATED="1522389243868" ID="ID_104693188" MODIFIED="1522389252479" TEXT="ist interne Schnittstelle zur Konfiguration"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521242246702" ID="ID_650712800" MODIFIED="1561827466094" TEXT="DependInject">
|
|
<node CREATED="1521242468983" ID="ID_956915310" MODIFIED="1521242481313" TEXT="ist nur ein Lebenszyklus-Manager"/>
|
|
<node CREATED="1521242666204" ID="ID_219666575" MODIFIED="1521242758283" TEXT="delegiert an eine funktionale Konfig"/>
|
|
<node CREATED="1521242758775" ID="ID_594637783" MODIFIED="1521242762355" TEXT="ist komplett generisch"/>
|
|
</node>
|
|
<node CREATED="1521242784556" ID="ID_1052722676" MODIFIED="1561827466094" TEXT="Konfig-Selektor">
|
|
<node CREATED="1521242793458" ID="ID_1174857326" MODIFIED="1521242802085" TEXT="baut die Closure"/>
|
|
<node CREATED="1521242805641" ID="ID_68866373" MODIFIED="1521242811164" TEXT="baut die funktionale Konfig"/>
|
|
<node CREATED="1521242824239" ID="ID_1013563756" MODIFIED="1521242834313" TEXT="inline-wegwerf-Objekt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521240053852" ID="ID_666003564" MODIFIED="1533608414069" STYLE="fork" TEXT="Detail-Fragen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#990000" CREATED="1521169099047" ID="ID_1183392158" MODIFIED="1561827466094" TEXT="DependencyFactory-Rahmenklasse">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521416462342" ID="ID_1333178845" MODIFIED="1521418281285" TEXT="fällt weg"/>
|
|
<node CREATED="1521416471820" ID="ID_870619413" MODIFIED="1521418281285" TEXT="wir arbeiten direkt mit Lambdas">
|
|
<arrowlink COLOR="#b4a9c1" DESTINATION="ID_1336783261" ENDARROW="Default" ENDINCLINATION="224;0;" ID="Arrow_ID_37940927" STARTARROW="None" STARTINCLINATION="83;-7;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521169111957" ID="ID_1706232823" MODIFIED="1521418281285" TEXT="Ort für den Implementierungs-Pointer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521169130251" ID="ID_1252056818" MODIFIED="1521418281285" TEXT="Zugang für DependInject">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521324229082" ID="ID_1398878858" MODIFIED="1561827466096" TEXT="Storage">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521324240124" ID="ID_1099103129" MODIFIED="1521418281285">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
statische Storage ist <i>irgendwie cool</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1521324275919" FOLDED="true" ID="ID_1710451095" MODIFIED="1561827483840" TEXT="sehe aber auch keinen wirklichen Vorteil">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1521324529228" ID="ID_1786667023" MODIFIED="1521418281285" TEXT="man muß sich nicht um die de-Allokation kümmern"/>
|
|
<node CREATED="1521324554465" ID="ID_1577416641" MODIFIED="1521418281285" TEXT="Storage ist garantiert vorhanden, kein out-of-Memory"/>
|
|
<node CREATED="1521324668449" ID="ID_1013908061" MODIFIED="1521418281285" TEXT="Meyers Singleton ist elegant und schnell"/>
|
|
</node>
|
|
<node CREATED="1521324321601" ID="ID_805959606" MODIFIED="1521418281285" TEXT="Nachteil: Storage ist stets belegt, auch wenn nicht notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das gilt im Besonderen für eine default-Storage als Singleton.
|
|
</p>
|
|
<p>
|
|
Wofern wir dynamisch konfigurieren (wollen), muß dieser Default stets statisch bereitgestellt werden,
|
|
</p>
|
|
<p>
|
|
selbst wenn die dynamische Konfiguration so angelegt ist, daß die Storage nie benötigt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521324883035" ID="ID_1438637057" MODIFIED="1521418281285" TEXT="Heap-Allokation könnte insgesamt einfacher sein">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521326541575" ID="ID_966508253" MODIFIED="1521418281285" TEXT="umgebaut auf Heap">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521254014422" ID="ID_961824675" MODIFIED="1561827466096" TEXT="Meyers Singleton oder explizit ausprogrammieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521303577633" ID="ID_1665490706" MODIFIED="1521418281285" TEXT="das wäre die "Standard-Lösung" für Singletons"/>
|
|
<node CREATED="1521303616675" FOLDED="true" ID="ID_135579041" MODIFIED="1561827483840" TEXT="hier aber nicht sinnvoll...">
|
|
<node CREATED="1521303634705" FOLDED="true" ID="ID_433169847" MODIFIED="1561827482933" TEXT="weil wir explizit ein Lock halten müssen">
|
|
<node CREATED="1521303738410" ID="ID_213625497" MODIFIED="1521418281286" TEXT="um den Instanz-Pointer und die Factory zu managen"/>
|
|
<node CREATED="1521303749169" ID="ID_762346402" MODIFIED="1521418281286" TEXT="und der Compiler für Meyers Singleton nochmal ein Lock generiert"/>
|
|
</node>
|
|
<node CREATED="1521303775845" ID="ID_1256913997" MODIFIED="1521418281286" TEXT="weil wir unsere Singletons ggfs explizit zerstören wollen"/>
|
|
<node CREATED="1521303816879" ID="ID_1463480909" MODIFIED="1521418281286" TEXT="weil wir eine Closure für den Konstruktor erzeugen wollen"/>
|
|
<node CREATED="1521303847923" ID="ID_917362189" MODIFIED="1521418281286" TEXT="weil wir Abstrakte Typen explizit ausschließen müssen"/>
|
|
</node>
|
|
<node CREATED="1521303869768" ID="ID_712811337" MODIFIED="1521418281286" TEXT="all das wäre auch mit Meyers Singleton irgendwie hinzubekommen....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...aber dann eben nicht mehr <i>elegant.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521303905491" ID="ID_1749674332" MODIFIED="1521418281286" TEXT="Fazit: explizit ist besser">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521253797733" ID="ID_1640990866" MODIFIED="1561827466098" TEXT="Fehlerbehandlung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521253803963" ID="ID_100415207" MODIFIED="1521418281286" TEXT="Installation wenn Factory bereits genutzt wurde">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521253831776" FOLDED="true" ID="ID_1332033733" MODIFIED="1561827483840" TEXT="Zugriff auf Service bevor er hochgefahren wurde">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1521253858692" ID="ID_442301762" MODIFIED="1521418281286" TEXT="tückisch">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1521253867787" ID="ID_662728746" MODIFIED="1521418281286" TEXT="Lifecycle-Handle existiert erst viel später">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1521385652999" FOLDED="true" ID="ID_1974848336" MODIFIED="1561827482933" TEXT="statischer Schutz">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1521385660206" FOLDED="true" ID="ID_200575604" MODIFIED="1561827469160" TEXT="fragil">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1521385687874" ID="ID_1561975152" MODIFIED="1521418281286" TEXT="C++ kennt keine statische Klassen-Initialisierung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1521385709463" FOLDED="true" ID="ID_713439022" MODIFIED="1561827469140" TEXT="workaround">
|
|
<node CREATED="1521385721637" ID="ID_1822970415" MODIFIED="1521418281286" TEXT="Initialisieren eines statischen member">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521385768359" FOLDED="true" ID="ID_1123247553" MODIFIED="1525124215436" TEXT="ist unzuverlässig">
|
|
<node CREATED="1521385782861" ID="ID_1190214158" MODIFIED="1521418281286" TEXT="erfordert non-const member"/>
|
|
<node CREATED="1521385787980" ID="ID_81600101" MODIFIED="1521418281286" TEXT="wird vom Compiler wegoptimiert"/>
|
|
<node CREATED="1521385795059" ID="ID_1426898485" MODIFIED="1521418281286" TEXT="sofern er Wirkungslosigkeit nachweisen kann...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Und das hängt nur von den Umständen ab.
|
|
</p>
|
|
<p>
|
|
In einem einfachen statisch gelinkten Executable entfernt gcc die gesamte Variable sogar ohne Optimierung.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
In Zukunft könnten Compiler/Linker noch "schlauer" werden...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521386182598" ID="ID_1671815821" MODIFIED="1521418281286" TEXT="ist undurchsichtig">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521386206627" ID="ID_1928841192" MODIFIED="1521418281286" TEXT="erzeugt eh bloß eine Fehlermeldung"/>
|
|
<node CREATED="1521386219297" ID="ID_1181038545" MODIFIED="1521418281286" TEXT="...was auch noch beim Hochfahren des Service passieren kann"/>
|
|
</node>
|
|
<node CREATED="1521386241406" ID="ID_1481722887" MODIFIED="1521418281286" TEXT="es ist ein Architektur-Problem">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521253986491" ID="ID_546204807" MODIFIED="1521418281286" TEXT="Singleton wenn Interfaceklasse abstrakt ist">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522557552545" FOLDED="true" ID="ID_399844845" MODIFIED="1561827483841" TEXT="Zugriff im statischen Shutdown">
|
|
<linktarget COLOR="#27a7a7" DESTINATION="ID_399844845" ENDARROW="Default" ENDINCLINATION="-36;283;" ID="Arrow_ID_1430148682" SOURCE="ID_1023585478" STARTARROW="None" STARTINCLINATION="104;0;"/>
|
|
<linktarget COLOR="#487bba" DESTINATION="ID_399844845" ENDARROW="Default" ENDINCLINATION="237;509;" ID="Arrow_ID_1393532861" SOURCE="ID_1003385410" STARTARROW="None" STARTINCLINATION="733;-537;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1522557562543" ID="ID_442673617" MODIFIED="1522558305695" TEXT="tückisches Problem">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1522557575925" FOLDED="true" ID="ID_1228603701" MODIFIED="1561827482933" TEXT="Frage: eigenen Basis-Layer im System schaffen?">
|
|
<arrowlink COLOR="#af98b6" DESTINATION="ID_736034555" ENDARROW="Default" ENDINCLINATION="2208;-356;" ID="Arrow_ID_1927977085" STARTARROW="None" STARTINCLINATION="448;721;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522557704291" ID="ID_1761521925" MODIFIED="1522557712303" TEXT="durchdiskutiert und abgelehnt"/>
|
|
<node CREATED="1522557712890" ID="ID_898328822" MODIFIED="1522557717398" TEXT="wird sehr kompliziert"/>
|
|
<node CREATED="1522557718154" ID="ID_36441623" MODIFIED="1522557725172" TEXT="architektonisch nicht sinnvoll"/>
|
|
</node>
|
|
<node CREATED="1522557731064" FOLDED="true" ID="ID_164363356" MODIFIED="1561827482933" TEXT="Untersuchung: statische Init">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522557739071" ID="ID_1920814871" MODIFIED="1522557754025" TEXT="verhält sich tatsächlich korrekt lt. Standard"/>
|
|
<node CREATED="1522557754877" ID="ID_1831893028" MODIFIED="1522557767223" TEXT="das ClassLock wird erst on-demand erzeugt"/>
|
|
<node CREATED="1522557767787" ID="ID_405329609" MODIFIED="1522557791751">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
daher <b>muß</b> sein dtor <b>vor</b> dem dtor von DependencyFactory laufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522557924661" FOLDED="true" ID="ID_1965837896" MODIFIED="1561827469160" TEXT="konsistent?">
|
|
<node CREATED="1522557833985" ID="ID_449005089" MODIFIED="1522557848371" TEXT="Bis zum dtor-Aufruf ist alles kohärent"/>
|
|
<node CREATED="1522557848983" ID="ID_612135780" MODIFIED="1522557867537" TEXT="da man nur via lib::Depend reinkommt..."/>
|
|
<node CREATED="1522557868197" ID="ID_497122193" MODIFIED="1522557918362" TEXT="wird der statische dtor nach dem letzten zugreifenden Kontext laufen"/>
|
|
<node CREATED="1522557968159" ID="ID_838129103" MODIFIED="1522557989248" TEXT="Aber ein solcher Aufruf kann selber in eine andere Translation-Unit umgeleitet worden sein"/>
|
|
<node CREATED="1522557990388" ID="ID_1629893682" MODIFIED="1522558003636" TEXT="kann daher niemals wasserdicht sein">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522557828066" FOLDED="true" ID="ID_1861289683" MODIFIED="1561827482934" TEXT="Fazit">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1522558005906" ID="ID_1914654214" MODIFIED="1522558192841" TEXT="re-entrance während dem dtor-Aufruf eigens behandeln">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn während dem dtor existiert das Lock nicht mehr.
|
|
</p>
|
|
<p>
|
|
Man kann aber die Logik so umordnen, daß der instance-Ptr nach dem eigentlichen Deleter auf NULL gesetzt wird.
|
|
</p>
|
|
<p>
|
|
Das ist <b>nicht threadsafe</b>, was aber hier akzeptabel ist (Shutdown läuft überwiegend
|
|
</p>
|
|
<p>
|
|
single-threaded, sofern man keine thread_locals einsetzt. Aber diese werden vor alle anderen
|
|
</p>
|
|
<p>
|
|
Destruktoren gesequenced. Sollte passen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522558025471" ID="ID_408630768" MODIFIED="1522558194504" TEXT="danach spezielle Sperre einbauen, da die Factory nicht mehr existiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522558045236" ID="ID_269006227" MODIFIED="1522558059135" TEXT="solche Konsistenz-Checks sind wertvoll">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521160691830" FOLDED="true" ID="ID_53329830" MODIFIED="1563022733852" TEXT="Implementierung ausführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521418559868" ID="ID_592269917" MODIFIED="1521688403021" TEXT="Depend<SRV> Front-End">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521418571594" ID="ID_1432227459" MODIFIED="1521688407751" TEXT="DependInject<SRV> ersetzt dependency-factory.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521418598463" ID="ID_237484313" MODIFIED="1531584013617" TEXT="Objekterzeugung erweitern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#990000" CREATED="1521418618052" ID="ID_1253147848" MODIFIED="1533608414078" TEXT="auf beliebige Argumente">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1521688471643" ID="ID_1037697154" MODIFIED="1521688504558" TEXT="gefährlich wenn Objekterzeugung lazy">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1521688505734" ID="ID_1656307893" MODIFIED="1521688520760" TEXT="der Client sieht ja nicht, wie wir die Argumente speichern"/>
|
|
<node CREATED="1521688524620" ID="ID_480802115" MODIFIED="1521688537015" TEXT="sinnvoll nur im Fall Service-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521418627130" ID="ID_206705145" MODIFIED="1533608414078" TEXT="auf allgemeine Closures">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521696315169" ID="ID_914761003" MODIFIED="1521696326988" TEXT="ob das wohl geht...."/>
|
|
<node CREATED="1521696477035" ID="ID_1232450528" MODIFIED="1521696510682" TEXT="Verdammter Mist! Wird die Closure nun kopiert oder geMOVEd?"/>
|
|
<node COLOR="#338800" CREATED="1521696673440" ID="ID_1408713510" MODIFIED="1521751343055" TEXT="compile-time Checks mal verifizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521696334383" ID="ID_1627167666" MODIFIED="1561827466112" TEXT="gefällt mir nicht wirklich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn nun wird das "singleton" schon ziemlich gehaltlos,
|
|
</p>
|
|
<p>
|
|
und es ist einigermaßen undurchsichtig, wo nun die Instanz erzeugt wird.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings gibt es auch kein stichhaltiges Argument, dieses Feature<i> nicht</i> zu implementieren.
|
|
</p>
|
|
<p>
|
|
Es ist halt einfach nahheliegend, daß man mal eine Subklasse mit abweichenden Parametern
|
|
</p>
|
|
<p>
|
|
konstruieren wollen könnte, und es ist von der Implementierung her "quasi geschenkt".
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node COLOR="#338800" CREATED="1522389159792" ID="ID_1574961457" MODIFIED="1522389181299" TEXT="besserer Name">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522389172206" ID="ID_14747848" MODIFIED="1522389177726" TEXT="komplettes Refactoring">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522389165095" ID="ID_533975153" MODIFIED="1522389170272" TEXT="DependencyFactory">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433938944" ID="ID_546086969" MODIFIED="1531584013622" TEXT="double-checked-locking">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521433948534" ID="ID_176845865" MODIFIED="1533608414081" TEXT="umstellen auf atomics">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521779239745" ID="ID_1772115642" MODIFIED="1561827466113">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Thema</u>: Memory access order constraints
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#5a6caa" DESTINATION="ID_1416813337" ENDARROW="Default" ENDINCLINATION="-1755;162;" ID="Arrow_ID_751165448" STARTARROW="None" STARTINCLINATION="-4287;-237;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521783335195" ID="ID_594004742" LINK="http://en.cppreference.com/w/cpp/atomic/memory_order" MODIFIED="1521783351104" TEXT="CPP-Reference"/>
|
|
</node>
|
|
<node CREATED="1521783156564" ID="ID_1193354198" MODIFIED="1521783219950">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#45317b">Grundidee</font>: <b>synchronizes-with</b>-Beziehung herstellen <i>auf Guard-Variable</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521788423421" ID="ID_992901826" MODIFIED="1561827466114" TEXT="use-cases">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1521788428588" FOLDED="true" ID="ID_1454492096" MODIFIED="1561827483841" TEXT="lazy init">
|
|
<node CREATED="1521788443562" ID="ID_699722245" MODIFIED="1521788611886" TEXT="acquire-release ist "ausreichend"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das meint zweierlei
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
wir brauchen keine volle sequentielle Konsistenz
|
|
</li>
|
|
<li>
|
|
eigentlich würde <i>consume</i> statt <i>acquire</i> genügen,<br />aber wir verzichten auf diesen ehr theoretischen Performance-Gewinn,<br />welcher nur relevant wäre, wenn wir auf ARM einen modernen Compiler einsetzen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521788638623" ID="ID_16016457" MODIFIED="1521788679409">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
essentiell ist, im Mutex-geschützten Bereich
|
|
</p>
|
|
<p>
|
|
auf einer temporären lokalen Instanz-Variable zu arbeiten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521788695911" FOLDED="true" ID="ID_326620949" MODIFIED="1561827483841" TEXT="config Singleton-sub">
|
|
<node CREATED="1521788724243" ID="ID_1337448866" MODIFIED="1521788751467" TEXT="hier wird synchronizes-with per Mutex (blocking) hergestellt"/>
|
|
<node CREATED="1521788777364" ID="ID_1496795291" MODIFIED="1521788787982" TEXT="der Atomic wird nur gelesen, um einen Fehler zu erkennen"/>
|
|
<node CREATED="1521788788546" ID="ID_1572121226" MODIFIED="1521788818778" TEXT="...es würde sogar ein nicht-atomic genügen"/>
|
|
<node CREATED="1521788825341" ID="ID_984179535" MODIFIED="1521788870307" TEXT="memory_order_relaxed wäre korrekt"/>
|
|
<node CREATED="1521788871702" ID="ID_1445815040" MODIFIED="1521789034029" TEXT="aber seq_cst ist tolerierbar und lesbarer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
weil per Definitionem dieses gesamte Konfigurations-Thema
|
|
</p>
|
|
<p>
|
|
als <i>nicht performance-kritisch</i> eingestuft wird -- und ich mehr Wert darauf lege,
|
|
</p>
|
|
<p>
|
|
die verschiedenen Belange im Quelltext nicht zu vermischen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521789050110" FOLDED="true" ID="ID_916308999" MODIFIED="1561827483841" TEXT="start Service">
|
|
<node CREATED="1521789241116" FOLDED="true" ID="ID_1521979010" MODIFIED="1561827482934" TEXT="Frage: besteht hier eine race-condition?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521789253954" ID="ID_1012950744" MODIFIED="1521789259925" TEXT="das ist eine Architektur-Frage"/>
|
|
<node CREATED="1521789283782" FOLDED="true" ID="ID_87566462" MODIFIED="1561827469160" TEXT=""Ja" würde bedeuten....">
|
|
<node CREATED="1521789292172" ID="ID_1709140060" MODIFIED="1521789340386" TEXT="daß Konkurrenz zwischen Singleton und Service vorgesehen ist"/>
|
|
<node CREATED="1521789342638" ID="ID_1682448407" MODIFIED="1521789361687" TEXT="und wir müßten in diesem Fall mit CAS den Service veröffentlichen"/>
|
|
</node>
|
|
<node CREATED="1521789364195" ID="ID_603083662" MODIFIED="1521789452318" TEXT="die Antwort ist eindeutig "Nein"">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gilt schlichtweg als Architektur-Fehler, wenn hier eine Kollision geschiet.
|
|
</p>
|
|
<p>
|
|
Und es gibt keinen sinnvollen Weg, wie die Applikation dann weiterarbeiten kann.
|
|
</p>
|
|
<p>
|
|
Daher werfen wir ja auch error::Fatal
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521789511870" ID="ID_553276693" MODIFIED="1521789526160" TEXT="Konsistenz-check und Service-Start im Mutex sind ausreichend"/>
|
|
<node CREATED="1521789611377" ID="ID_923887770" MODIFIED="1521789676331" TEXT="aber der Service muß per memory_order_release veröffentlicht werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn sonst könnte genau das gleiche Desaster passieren,
|
|
</p>
|
|
<p>
|
|
das auch in fehlerhaftem Double-Checked-Locking auftritt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1521789904872" ID="ID_1237807951" MODIFIED="1521789930400" TEXT="...was aber durch den default (memory_order_seq_cst) mit impliziert ist">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521789938539" FOLDED="true" ID="ID_1248059454" MODIFIED="1561827483841" TEXT="stop Service">
|
|
<node CREATED="1521789943683" ID="ID_128133787" MODIFIED="1521790025755" TEXT="völlig analog: instance = nullptr braucht release-Semantik"/>
|
|
<node CREATED="1521790091662" FOLDED="true" ID="ID_1518955379" MODIFIED="1561827482934" TEXT="Frage: besteht ein Race auf den Destruktor?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521790108228" ID="ID_1075157743" MODIFIED="1521790114983" TEXT="das ist wiederum eine Architektur-Frage"/>
|
|
<node CREATED="1521790115851" ID="ID_1077549103" MODIFIED="1521790219873" TEXT="theoretisch besteht er sehr wohl">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...d.h. das ganze Locking und die memory-order schützt uns hier <b>überhaupt nicht</b>!
|
|
</p>
|
|
<p>
|
|
Es kann sehr wohl passieren, daß ein anderer Thread grade eben noch
|
|
</p>
|
|
<p>
|
|
sicht den Pointer auf den Service geholt hat, und wir dann den Service zerstören, während
|
|
</p>
|
|
<p>
|
|
der andere Thread ihn grade nutzt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521790222356" ID="ID_168283882" MODIFIED="1521790445457">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
unsere Architektur stellt aber sicher,
|
|
</p>
|
|
<p>
|
|
daß dieser Fall nicht relevant ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
Weil der "andere Thread" nur von zwei Subsystemen her kommen kann
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
dem Subsystem selber, das auch den Service erzeugt.<br />Beispiel ist eine UI-Interaktion aus dem Event-Loop thread
|
|
</li>
|
|
<li>
|
|
aus einem anderen Subsystem, das vom Serivce-Provider abhängt
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
In beiden Fällen stellen unsere Prinzipien zum Betreiben von Subsystemen sicher,
|
|
</p>
|
|
<p>
|
|
daß dieser "andere Thread" nicht (mehr) aktiv sein darf, wenn der Shutdown erfolgt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521790458636" FOLDED="true" ID="ID_1895342635" MODIFIED="1561827469160" TEXT="Ausnahme: Emergency-Shutdown">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1521790499246" ID="ID_671183540" MODIFIED="1521790505505" TEXT="wenn ein Subsystem zusammenbricht"/>
|
|
<node CREATED="1521790506069" ID="ID_1950061016" MODIFIED="1521790513032" TEXT="sind seine Services bereits weg,"/>
|
|
<node CREATED="1521790515308" ID="ID_1260618160" MODIFIED="1521790538596" TEXT="wenn der Subsystem-Manager den Applikations-Shutdown signalisiert"/>
|
|
<node CREATED="1521790557030" ID="ID_663628696" MODIFIED="1521790571891">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier ist ein <b>Segfault</b> möglich
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521791102683" FOLDED="true" ID="ID_1344381807" MODIFIED="1561827483841" TEXT="Mock">
|
|
<node CREATED="1521791122872" FOLDED="true" ID="ID_236648459" MODIFIED="1561827482934" TEXT="Generell unterstellen wir hier gutmütige Verhältnisse">
|
|
<node CREATED="1521791137678" ID="ID_1107870970" MODIFIED="1521791147768" TEXT="Mocks sollen niemals produktiv verwendet werden"/>
|
|
<node CREATED="1521791149596" ID="ID_301182144" MODIFIED="1521791176628" TEXT="Concurrency tritt (wenn überhaupt) nur sehr kontrolliert auf"/>
|
|
</node>
|
|
<node CREATED="1521791233344" ID="ID_1474658967" MODIFIED="1521791269115" TEXT="auch hier erschlägt Mutex + default-Memory-order alle Belange">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521434009142" ID="ID_117782655" MODIFIED="1533608414088" TEXT="Performance-Messung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521791686994" ID="ID_1750734364" MODIFIED="1521791753975" TEXT="Erwartetes Ergebnis: wird nur geringfügig langsamer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn wir sind auf x86_64 -- und diese Plattform ist per default <i>fast überall</i> sequentially coherent
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521866206751" ID="ID_702466096" MODIFIED="1521882798384" TEXT="Bezugspunkt: Zugriff auf bereits existierenden Service">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1521791785677" ID="ID_565916879" MODIFIED="1561827466120" TEXT="drei Fälle">
|
|
<icon BUILTIN="forward"/>
|
|
<node COLOR="#338800" CREATED="1521791790172" ID="ID_995415475" MODIFIED="1521882801672" TEXT="Mutex für jeden Zugriff">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521791805930" ID="ID_1036499157" MODIFIED="1521882803656" TEXT="Lösung ohne Atomics (inkorrekt)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521791823055" ID="ID_1820322207" MODIFIED="1521882806238" TEXT="Lösung mit Atomics">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521791837014" ID="ID_1625592637" MODIFIED="1521882823105" TEXT="Messwerte als Verhältniszahl angeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522110414912" ID="ID_1861060212" MODIFIED="1531584013624" TEXT="Singleton-Erzeugung zusammenführen">
|
|
<linktarget COLOR="#5f8d94" DESTINATION="ID_1861060212" ENDARROW="Default" ENDINCLINATION="-566;0;" ID="Arrow_ID_319700222" SOURCE="ID_1624172022" STARTARROW="None" STARTINCLINATION="205;-440;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522110563499" ID="ID_470760423" MODIFIED="1533608414089" TEXT="stets ausführend">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522110568307" ID="ID_311971109" MODIFIED="1522110579069" TEXT="Depend<SUB>"/>
|
|
<node CREATED="1522110579561" ID="ID_1773742926" MODIFIED="1522110587404" TEXT="mit SUB == konkreter Typ"/>
|
|
</node>
|
|
<node CREATED="1522110657678" ID="ID_22217041" MODIFIED="1533608414089" TEXT="Locking/Korrektheit">
|
|
<node CREATED="1522110665733" ID="ID_329494929" MODIFIED="1522110676431" TEXT="Achtung abweichender Typ!">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1522110683363" ID="ID_352813223" MODIFIED="1522110710611" TEXT="Normaler Zugang via Depend<SUB> wird zum Synonym"/>
|
|
<node CREATED="1522111399080" ID="ID_753159927" MODIFIED="1561827466120" TEXT="kaskadierend">
|
|
<node CREATED="1522110724165" ID="ID_879974852" MODIFIED="1522110749614" TEXT="acquire Lock<SUB>"/>
|
|
<node CREATED="1522110842845" ID="ID_12886357" MODIFIED="1522110920894" TEXT="store into Depend<SUB>::instance"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522110508507" ID="ID_789229743" MODIFIED="1533608414090" TEXT="Fälle">
|
|
<node CREATED="1522110513930" ID="ID_752814721" MODIFIED="1561827466120" TEXT="normal-default">
|
|
<node CREATED="1522113463844" ID="ID_1945711876" MODIFIED="1522113489197" TEXT="nur Konstruktor / Destruktor-Funktion"/>
|
|
<node CREATED="1522113490025" ID="ID_1330140057" MODIFIED="1522113531135" TEXT="Alternativ-Behandlung für nicht-instantiierbare Typen"/>
|
|
</node>
|
|
<node CREATED="1522110520777" ID="ID_336202422" MODIFIED="1561827466120" TEXT="Subclass-default">
|
|
<node CREATED="1522113128835" ID="ID_166213716" MODIFIED="1522113152107" TEXT="kaskadierenden Zugriff als Factory"/>
|
|
<node CREATED="1522113152999" ID="ID_1443678098" MODIFIED="1522113288917" TEXT="Instantiierungs-Check kann entfallen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...man <i>könnte</i> ihn aber genausogut auch machen.
|
|
</p>
|
|
<p>
|
|
Das Argument ist: wenn wir kaskadierend aufrufen, dann ist das Ergebnis in jedem Fall korrekt,
|
|
</p>
|
|
<p>
|
|
und wird auch durch das Installieren dieses (zweiten) Zuganges in keinster Weise beeinträchtigt.
|
|
</p>
|
|
<p>
|
|
Sollte Depend<SUB> bereits instantiiert sein, dann auch gut.
|
|
</p>
|
|
<p>
|
|
Der kaskadierende Aufruf liest dann einfach <i>dessen</i> Instanz-Pointer
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522110531344" ID="ID_1376369013" MODIFIED="1561827466121" TEXT="custom-ctor">
|
|
<node CREATED="1522112368219" ID="ID_774074460" MODIFIED="1522112375518" TEXT="konkreten Typ feststellen"/>
|
|
<node CREATED="1522112376154" FOLDED="true" ID="ID_1394042003" MODIFIED="1561827483841" TEXT="für diesen...">
|
|
<node CREATED="1522113449575" ID="ID_644735948" MODIFIED="1522113456734" TEXT="acquire Lock<SUB>"/>
|
|
<node CREATED="1522112395280" ID="ID_995036578" MODIFIED="1522113339076" TEXT="Instantiierungs-Check">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier notwendig, weil wir eine neue Factory-Funktion ablegen.
|
|
</p>
|
|
<p>
|
|
Das könnte mit dem Factory-Management einer bereits installierten Konfiguration kollidieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522112400703" ID="ID_1562178283" MODIFIED="1522112404258" TEXT="Factory erstellen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522200092935" ID="ID_1314237888" MODIFIED="1533608414092" TEXT="Deleter-Behandlung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522200102534" ID="ID_284894079" MODIFIED="1561827466121" TEXT="bisher">
|
|
<node CREATED="1522200106373" ID="ID_1981188993" MODIFIED="1522200226028" TEXT="was die Factory zurückliefert, wird nicht gemanaged">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1522200122883" ID="ID_564595724" MODIFIED="1522200229769" TEXT="der instance-Pointer bleibt bestehen, selbst wenn das Objekt weg ist">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1522200231404" ID="ID_357657857" MODIFIED="1522200238612" TEXT="ned schee">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522200147696" ID="ID_929047067" MODIFIED="1561827466122" TEXT="gewünscht">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#338800" CREATED="1522200152927" ID="ID_326569334" MODIFIED="1522382081602" TEXT="keine Memory-leaks">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522200167861" ID="ID_908074030" MODIFIED="1522382083234" TEXT="alles soll zerstört werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522200189706" ID="ID_302642427" MODIFIED="1522382084962" TEXT="möglichst alle instance-Pointer zurücksetzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522384942847" ID="ID_1152640572" MODIFIED="1522387791802" TEXT="Fehlermeldung beim Zugriff nach Zerstörung">
|
|
<linktarget COLOR="#639d9e" DESTINATION="ID_1152640572" ENDARROW="Default" ENDINCLINATION="-89;0;" ID="Arrow_ID_1512382393" SOURCE="ID_1741501987" STARTARROW="None" STARTINCLINATION="28;-1;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522200249626" ID="ID_215336836" MODIFIED="1522382087401" TEXT="Freunschafts-fähig">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522384902500" ID="ID_1741501987" MODIFIED="1533608414094" TEXT="Zugriff beim Herunterfahren">
|
|
<arrowlink COLOR="#639d9e" DESTINATION="ID_1152640572" ENDARROW="Default" ENDINCLINATION="-89;0;" ID="Arrow_ID_1512382393" STARTARROW="None" STARTINCLINATION="28;-1;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522387798572" HGAP="35" ID="ID_1522844249" MODIFIED="1522387935592" TEXT="war ein übriggebliebener Destruktor in einem Mock" VSHIFT="12">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
zwar wird beim Löschen des Mock
|
|
</p>
|
|
<p>
|
|
die ursprüngliche Factory wieder an ihren Platz zurückgeschoben,
|
|
</p>
|
|
<p>
|
|
aber niemand sagt, daß ein Move auch wirklich ein Move (swap) ist.
|
|
</p>
|
|
<p>
|
|
Muß daher diese leer gewordene temporäre Factory explizit auf Default-Zustand zurücksetzen,
|
|
</p>
|
|
<p>
|
|
damit nicht doch noch der Deleter läuft.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522387936585" ID="ID_1922190351" MODIFIED="1522388778471" TEXT="es wäre besser, wenn Factory überhaupt nicht assignable wäre">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und man stattdessen explizit eine <i>gefährliche Funktion</i>  aufrufen muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522334796724" ID="ID_1080992734" MODIFIED="1531584013626" TEXT="Funktoren zusammenführen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522334843062" ID="ID_1526236017" MODIFIED="1533608414095" TEXT="DependencyFactory für">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522334805635" ID="ID_315782435" MODIFIED="1522384992864" TEXT="Erzeugungs-Funktor"/>
|
|
<node CREATED="1522334818473" ID="ID_750129060" MODIFIED="1522334821036" TEXT="Deleter"/>
|
|
<node CREATED="1522334822001" ID="ID_644059909" MODIFIED="1522334935421" TEXT="automatisches Instanz-Management"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522334859291" ID="ID_1496044958" MODIFIED="1533608414096" TEXT="korrekt handhaben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522334896942" ID="ID_1215786079" MODIFIED="1522382047552" TEXT="default-Fall">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522334903741" ID="ID_1875541619" MODIFIED="1522382049855" TEXT="abstrakte Basisklasse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522381984647" ID="ID_136231234" MODIFIED="1561827466122" TEXT="Klasse ohne Default-ctor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522384796267" FOLDED="true" ID="ID_1913154173" MODIFIED="1561827483841" TEXT="Problem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1522384813129" ID="ID_502713353" MODIFIED="1522384821715" TEXT="private mit Freunschaft"/>
|
|
<node CREATED="1522384822583" ID="ID_1870041254" MODIFIED="1522384845999" TEXT="std::is_constructible<X> kann das nicht unterscheiden"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522384848011" ID="ID_834547191" MODIFIED="1522384870993" TEXT="Lösung: duck-Detector im Rumpf von DependencyFactory">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522334912412" ID="ID_1391948557" MODIFIED="1522382053286" TEXT="custom-Funktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522334917035" ID="ID_259163474" MODIFIED="1522382054565" TEXT="custom-Deleter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522367884794" ID="ID_42634215" MODIFIED="1533608414097" TEXT="Analyse der Schritte">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522367595914" ID="ID_615466863" MODIFIED="1561827466123" TEXT="Use-cases">
|
|
<node CREATED="1522367601081" FOLDED="true" ID="ID_1594593457" MODIFIED="1561827483841" TEXT="default">
|
|
<node CREATED="1522367513966" ID="ID_18197809" MODIFIED="1522381907638" TEXT="nominelle Target-Klasse">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367550688" ID="ID_1892572153" MODIFIED="1522381910426" TEXT="Objekt per default ctor erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367555520" ID="ID_1067588123" MODIFIED="1522381912781" TEXT="instanz managen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522367604945" FOLDED="true" ID="ID_681132036" MODIFIED="1561827483841" TEXT="Subclass">
|
|
<node CREATED="1522367701660" ID="ID_381217567" MODIFIED="1522381919492" TEXT="Subklasse feststellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367650099" ID="ID_887791148" MODIFIED="1522381923778" TEXT="nur delegieren an Depend<SUB>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522367617999" FOLDED="true" ID="ID_1310241568" MODIFIED="1561827483842" TEXT="custom-Functor">
|
|
<node CREATED="1522367712338" ID="ID_1169276081" MODIFIED="1522381927169" TEXT="Functor speichern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367731959" ID="ID_1766531478" MODIFIED="1522381929444" TEXT="Objekt per Funktor erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367749229" ID="ID_1580519177" MODIFIED="1522381931877" TEXT="instanz managen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522367902872" ID="ID_272084666" MODIFIED="1561827466124" TEXT="grundsätzlich immer">
|
|
<node CREATED="1522367561111" ID="ID_604859300" MODIFIED="1522381935331" TEXT="instanz-Ptr NULLen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522367573173" ID="ID_1825315724" MODIFIED="1522381938038" TEXT="Factory sperren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1525124188421" ID="ID_1086493226" MODIFIED="1525192911545" TEXT="Thema: statische Initialisierung">
|
|
<arrowlink COLOR="#9a97b5" DESTINATION="ID_1126260262" ENDARROW="Default" ENDINCLINATION="-1465;211;" ID="Arrow_ID_372705466" STARTARROW="None" STARTINCLINATION="-1025;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1525192915503" ID="ID_1930672036" MODIFIED="1525192926749" TEXT="Factory ist jetzt Meyer's Singleton">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1525192054281" ID="ID_1450620535" MODIFIED="1525192075199" TEXT="#1142 initialisation of static template members">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1525192963192" ID="ID_1702928731" MODIFIED="1533608414099" TEXT="ungeklärt: AppState-Factory-ctor mehrfach aufrerufen">
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node CREATED="1525192993716" ID="ID_1211448815" MODIFIED="1525193027234" TEXT="und zwar ein zweites mal vom GUI-Plugin">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1525193011555" ID="ID_822581772" MODIFIED="1525193186771" TEXT="ungefährlich, aber nicht sauber">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da es sich ja nur um die <i>Factory</i> handelt,
|
|
</p>
|
|
<p>
|
|
nicht um das AppState-Singleton selber, welches ja ohnehin nur von main.cpp
|
|
</p>
|
|
<p>
|
|
verwendet werden sollte. Aber das deutet darauf hin, daß irgend etwas mit der
|
|
</p>
|
|
<p>
|
|
Initialisierung von Statics "faul" ist, wenn shared objects dynamisch geladen werden.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522558319359" ID="ID_1023585478" MODIFIED="1522558353410" TEXT="Thema: Aufruf nach Zerstörung">
|
|
<arrowlink COLOR="#27a7a7" DESTINATION="ID_399844845" ENDARROW="Default" ENDINCLINATION="-36;283;" ID="Arrow_ID_1430148682" STARTARROW="None" STARTINCLINATION="104;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521160700669" HGAP="4" ID="ID_978221585" MODIFIED="1561827466127" TEXT="Dokumentation" VSHIFT="25">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521790595841" ID="ID_1874367277" MODIFIED="1521936684007" TEXT="Doku-Text im TiddlyWiki">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521790681557" ID="ID_1346970835" MODIFIED="1521936679674" TEXT="die generelle Haltung bezügl. Performance / Korrektheit">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790613318" ID="ID_506011313" MODIFIED="1521936677400" TEXT="Diskussion der Locking / Atomic-Problematik">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521885096858" ID="ID_1403195900" MODIFIED="1521885106977" TEXT="Benchmark-Zahlen dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790709017" ID="ID_1263887689" MODIFIED="1525124215458" TEXT="Doxygen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521790767697" ID="ID_1445751091" MODIFIED="1521936696493" TEXT="Grundsätzliches zu Singleton und Dependency-Injection (aktualisieren)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790800253" ID="ID_878208550" MODIFIED="1521946968361" TEXT="Eigenes Kapitel zum Thema Double-Checked Locking">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790816937" ID="ID_776249726" MODIFIED="1533608414100" TEXT="Grenzziehung zur Architektur">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521790858701" ID="ID_1382870211" MODIFIED="1521790870103" TEXT="Belange die hier nicht behandelt werden"/>
|
|
<node CREATED="1521790870898" ID="ID_662113030" MODIFIED="1521790886784">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Konsequenz: das ist <b>keine Library-Implementierung</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790951152" ID="ID_974126504" MODIFIED="1521946981024" TEXT="Semantik der Konfigurations-Varianten beschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521790992538" ID="ID_1892242381" MODIFIED="1521947767631" TEXT="die hier ausgeführte Analyse zusammenfassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521791026749" ID="ID_1199387367" MODIFIED="1525124215459" TEXT="Doku-Subsysteme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521791034972" ID="ID_1629095174" MODIFIED="1533608414101" TEXT="überlegen, wo das Architektur-Thema dargestellt werden sollte">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521962966238" ID="ID_1724029235" MODIFIED="1521962976832" TEXT="gehört in die Architektur-Sektion"/>
|
|
<node COLOR="#338800" CREATED="1521962977140" ID="ID_1121275609" MODIFIED="1521962995498" TEXT="Neue Seite "Subsystems" angelegt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521791058689" ID="ID_564899806" MODIFIED="1522025340181" TEXT="Hinweis auf die offene Flanke bei Emergency-Shutdown">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521929151045" ID="ID_1800182456" MODIFIED="1522025351449" TEXT="Doku-Seite für DependencyFactory anlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521929165380" ID="ID_15396392" MODIFIED="1521929185272" TEXT="kann in etwa der Content aus dem TiddlyWiki sein">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521963017631" ID="ID_380828830" MODIFIED="1521963032077" TEXT="Neue Seite angelegt und von The Inner Core verlinkt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521929186281" ID="ID_1078337367" MODIFIED="1522025355714" TEXT="ein, zwei Einleitungssätze dazu">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521929199799" ID="ID_507602296" MODIFIED="1522738826337" TEXT="Wichtig: die Benchmark-Daten hier auch darstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520722160591" ID="ID_135546699" MODIFIED="1561827466130" TEXT="Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521419576303" ID="ID_726128967" MODIFIED="1522042418343" TEXT="alte Tests portieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521418937870" ID="ID_906296527" MODIFIED="1522033081893" TEXT="Singleton_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521419045649" ID="ID_839295062" MODIFIED="1522035642960" TEXT="SingletonSubclass_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521419134046" ID="ID_1638082455" MODIFIED="1522037930919" TEXT="SingletonTestMock_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521419300765" ID="ID_417098537" MODIFIED="1522042501641" TEXT="DependencyFactory_test">
|
|
<linktarget COLOR="#b9274f" DESTINATION="ID_417098537" ENDARROW="Default" ENDINCLINATION="-118;36;" ID="Arrow_ID_606259386" SOURCE="ID_914313570" STARTARROW="Default" STARTINCLINATION="-127;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1521419730442" HGAP="42" ID="ID_657803548" MODIFIED="1533608414101" TEXT="nach der Umstellung etwas straffen" VSHIFT="-13">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522632317444" ID="ID_1018495070" MODIFIED="1522632325274" TEXT="ach was, zu faul...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521419563657" ID="ID_733291707" MODIFIED="1522034193646" TEXT="DependencyConfiguration_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521419590709" ID="ID_914313570" MODIFIED="1522042501641" TEXT="ziemlich redundant">
|
|
<arrowlink COLOR="#b9274f" DESTINATION="ID_417098537" ENDARROW="Default" ENDINCLINATION="-118;36;" ID="Arrow_ID_606259386" STARTARROW="Default" STARTINCLINATION="-127;0;"/>
|
|
<node CREATED="1521419624065" HGAP="29" ID="ID_477987875" MODIFIED="1533608414101" TEXT="weiterhin sinnvoll?" VSHIFT="14">
|
|
<node CREATED="1521419638943" ID="ID_717613154" MODIFIED="1521419705073" TEXT="TDD während der re-Implementirung"/>
|
|
<node CREATED="1521419657356" ID="ID_1381265753" MODIFIED="1521419674957" TEXT="der alte Test muß weiterhin laufen (ohne nachzudenken!)"/>
|
|
<node CREATED="1521419676825" ID="ID_92062482" MODIFIED="1521419693987" TEXT="mehr Tests schaden nie">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433819705" ID="ID_797347707" MODIFIED="1521433827896" TEXT="übernehmen und aufteilen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433807714" ID="ID_655174082" MODIFIED="1521433832327" TEXT="Assertions explizit machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433833942" ID="ID_841958834" MODIFIED="1521696534947" TEXT="Factory-Closure abdecken">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521696537522" ID="ID_1639668362" MODIFIED="1521696552680" TEXT="für subclass-Singleton">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521696547161" ID="ID_413219021" MODIFIED="1521696551785" TEXT="für Test-Mock">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433852660" ID="ID_1581010755" MODIFIED="1521433857543" TEXT="läuft">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033106576" ID="ID_278956866" MODIFIED="1525124215463" TEXT="weitere Tests...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die von der alten DependencyFactory abhängen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#15b89e" DESTINATION="ID_278956866" ENDARROW="Default" ENDINCLINATION="-6;80;" ID="Arrow_ID_1985884795" SOURCE="ID_513111416" STARTARROW="None" STARTINCLINATION="-88;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522033940685" ID="ID_447878554" MODIFIED="1522451818368" TEXT="media-access-mock-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033969821" ID="ID_1706164763" MODIFIED="1522451819727" TEXT="create-asset-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033977816" ID="ID_15822506" MODIFIED="1522451820734" TEXT="dependent-assets-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033997907" ID="ID_458476877" MODIFIED="1522451821737" TEXT="identity-of-assets-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034004825" ID="ID_1008413222" MODIFIED="1522451822955" TEXT="make-clip-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034011921" ID="ID_1809290651" MODIFIED="1522451823845" TEXT="ordering-of-assets-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034021470" ID="ID_466658369" MODIFIED="1522451824965" TEXT="builder-tool-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034029190" ID="ID_1418985959" MODIFIED="1522451825981" TEXT="testclip.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034035772" ID="ID_1574270320" MODIFIED="1522451827133" TEXT="mobject-interface-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034044775" ID="ID_984134175" MODIFIED="1522451828205" TEXT="mobject-ref-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034052507" ID="ID_1667049787" MODIFIED="1522451830519" TEXT="placement-hierarchy-test.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1520722155112" FOLDED="true" ID="ID_1512641426" MODIFIED="1563022719444" TEXT="Integration">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521160755182" ID="ID_678080556" MODIFIED="1522428573233" TEXT="Umbenennen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521160765588" ID="ID_1857896991" MODIFIED="1561827466133" TEXT="Konfig-Aufrufe anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522033578207" HGAP="18" ID="ID_252429770" MODIFIED="1525124215470" TEXT="Name für Freunschaft+" VSHIFT="-20">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522033614743" ID="ID_1110690522" MODIFIED="1533608414101" TEXT="friend class lib::InstanceHolder<TargetObj>;">
|
|
<node CREATED="1522033621114" ID="ID_1807735289" MODIFIED="1522033629872" TEXT="nicht so sexy">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1522035656233" ID="ID_678532992" MODIFIED="1522035672143" TEXT="und std::checked_deltet<TargetObj> auch noch">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522033635991" ID="ID_321432260" MODIFIED="1533608414102" TEXT="könnte das Depend selber sein?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522388820751" ID="ID_721931573" MODIFIED="1522388962542" TEXT="ist doch ehr ein irreführender Name">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn man nämlicht Lumiera's Lösung nicht genau kennt,
|
|
</p>
|
|
<p>
|
|
könnte sich das so lesen, als wäre Depend<X> ein Mixin,
|
|
</p>
|
|
<p>
|
|
welches einer Klasse <i>magisch</i> eine Dependency als protected-Feld zugänglich macht.
|
|
</p>
|
|
<p>
|
|
Und dann wäre es ziemlich pervasiv, sowas zum Freund zu erklären.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522388857786" ID="ID_1151074517" MODIFIED="1522389011363">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>DependencyFactory</b> ist viel besser geeignet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522110432870" ID="ID_1624172022" MODIFIED="1522558395556" TEXT="dann müßten alle Singletons an einer Stelle erzeugt werden">
|
|
<arrowlink COLOR="#5f8d94" DESTINATION="ID_1861060212" ENDARROW="Default" ENDINCLINATION="-566;0;" ID="Arrow_ID_319700222" STARTARROW="None" STARTINCLINATION="205;-440;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033193572" ID="ID_508353720" MODIFIED="1525124215471" TEXT="DependencyFactory">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522033199726" ID="ID_314595550" MODIFIED="1522445880917" TEXT="engine-config.h">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033210086" ID="ID_638295060" MODIFIED="1522445879580" TEXT="demo-gui-roundtrip.cpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033231644" ID="ID_1199449420" MODIFIED="1522445878005" TEXT="config-facade.h">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033250207" ID="ID_322012422" MODIFIED="1522445876212" TEXT="asset/db.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033810436" ID="ID_1074903860" MODIFIED="1522445875127" TEXT="assetmanager.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033264576" ID="ID_1266730565" MODIFIED="1522445874063" TEXT="stypemanager.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033697671" ID="ID_522765001" MODIFIED="1522445872867" TEXT="diagnostic-buffer-provider.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033733342" ID="ID_711202966" MODIFIED="1522445945626" TEXT="fake-configrules.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033740662" ID="ID_1194803087" MODIFIED="1522445974621" TEXT="dummy-session-connection.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033747205" ID="ID_1409425930" MODIFIED="1522446086935" TEXT="scope-locator.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033753484" ID="ID_1909328069" MODIFIED="1522446281045" TEXT="sess-manager-impl.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033760875" ID="ID_1097826895" MODIFIED="1522446426755" TEXT="output-director.hpp">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522034066988" ID="ID_513111416" MODIFIED="1522729509491" TEXT="alle Mock-Tests">
|
|
<arrowlink COLOR="#15b89e" DESTINATION="ID_278956866" ENDARROW="Default" ENDINCLINATION="-6;80;" ID="Arrow_ID_1985884795" STARTARROW="None" STARTINCLINATION="-88;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521858774321" FOLDED="true" ID="ID_302686020" MODIFIED="1563022715568" TEXT="aufräumen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1521858779614" ID="ID_62114860" MODIFIED="1521928808594" TEXT="was ist depend4test?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521928764171" ID="ID_507085354" MODIFIED="1521928798462" TEXT="die alte Testmock-Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521928773218" ID="ID_1837242179" MODIFIED="1522451811958" TEXT="nach Schwenken aller Unit-Tests wegfallend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521858791160" ID="ID_1863623429" MODIFIED="1521929094523" TEXT="brauchen wir DelStash noch?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521929071984" ID="ID_529951044" MODIFIED="1521929092199" TEXT="wird vom Advice-System genutzt"/>
|
|
<node CREATED="1521929080591" ID="ID_192438703" MODIFIED="1521929097694" TEXT="bleibt weiterhin notwendig">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521861040846" ID="ID_1297884815" MODIFIED="1531584013639" TEXT="brauchen wir singleton-ref?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1521928945937" ID="ID_1967326849" MODIFIED="1521929017586" TEXT="die alte (partielle) Lösung für externe Services">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521928963447" ID="ID_1493572426" MODIFIED="1521929015463" TEXT="ziemlich eng mit den Interface-Proxies verbandelt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521928978853" ID="ID_47671209" MODIFIED="1533608414103" TEXT="diese sollten auf Depend umgestellt werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522635397309" ID="ID_1630981728" MODIFIED="1522635457722" TEXT="SessionCommandService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635417932" ID="ID_826517015" MODIFIED="1522637771050" TEXT="DisplayService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635433910" ID="ID_578198662" MODIFIED="1522637772168" TEXT="GuiNotification">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635450269" ID="ID_609069219" MODIFIED="1522637773412" TEXT="DummyPlayerService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521929007449" ID="ID_451474924" MODIFIED="1522637778777" TEXT="danach kann es weg">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635350488" ID="ID_1673980887" MODIFIED="1531584013642" TEXT="InterfaceProxy auch umstellen?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522635366958" ID="ID_70940233" MODIFIED="1522639464220" TEXT="wäre jetzt ebenfalls denkbar">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522638768719" ID="ID_1027038623" MODIFIED="1533608414104" TEXT="InterfaceFacadeLink">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522638777486" ID="ID_1287650379" MODIFIED="1522638916886" TEXT="serivce-Handle"/>
|
|
<node CREATED="1522638783717" ID="ID_357133685" MODIFIED="1522638790235" TEXT="umgeht das Interface-system">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522638791268" ID="ID_965518210" MODIFIED="1522638800868" TEXT="tja, lib::Depend macht das jetzt auch">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522638812521" ID="ID_893221959" MODIFIED="1561827466138" TEXT="nur ein einziges mal verwendet">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522638830367" ID="ID_792298822" MODIFIED="1522638835178" TEXT="PlayService"/>
|
|
<node CREATED="1522638837022" ID="ID_362446492" MODIFIED="1522638876050">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den habe ich <b>nicht mehr</b> über das Interface-System gemappt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil mir das ganze C-gefrickel zu blöd geworden ist.
|
|
</p>
|
|
<p>
|
|
Also hat das hier Prototyp-Charakter!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522638877744" ID="ID_1175146695" MODIFIED="1522712862995" TEXT="sollte prototypisch-sauber umgestellt werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522712059423" ID="ID_885178924" MODIFIED="1561827466138" TEXT="komplett auf lib::Depend umstellen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522712083659" ID="ID_1397345256" MODIFIED="1522712851333" TEXT="das heißt: nicht einmal mehr die Fiktion einer Trennung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1522712827196" ID="ID_61159385" MODIFIED="1522712843093" TEXT="ein sauber gebautes C++ - Inteface ist Trennung genug">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522713332342" ID="ID_1078169696" MODIFIED="1522713348764" TEXT="der OutputDirector steuert nun diesen Service">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522638949038" ID="ID_1756362217" MODIFIED="1533608414106" TEXT="interfaceproxy - Accessor">
|
|
<linktarget COLOR="#68baaa" DESTINATION="ID_1756362217" ENDARROW="Default" ENDINCLINATION="32;1321;" ID="Arrow_ID_1797728654" SOURCE="ID_1293938610" STARTARROW="None" STARTINCLINATION="-288;-420;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522638978298" ID="ID_253383763" MODIFIED="1522638984645" TEXT="der Proxy selber bleibt wohl bestehen"/>
|
|
<node CREATED="1522638985329" ID="ID_1803368145" MODIFIED="1522638997699" TEXT="der Accessor ist wieder genau ein Access-handle"/>
|
|
<node COLOR="#338800" CREATED="1522639336921" ID="ID_1332611153" MODIFIED="1522716025758" TEXT="kann komplett durch lib::Depend ersetzt werden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522639301526" ID="ID_1959793943" MODIFIED="1533608414107" TEXT="InterfaceProxy umschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522639313964" ID="ID_620355867" MODIFIED="1522639322758" TEXT="er soll sich in lib::Depend einklinken"/>
|
|
<node CREATED="1522639904986" ID="ID_568095840" MODIFIED="1522639917092" TEXT="etwas wie den Holder brauchen wir weiterhin"/>
|
|
<node CREATED="1522640047991" ID="ID_965836148" MODIFIED="1561827466140" TEXT="wie funktioniert's?">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1522640064852" ID="ID_1332360368" MODIFIED="1522640101606">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Interface-<i>Anbieter</i> implementiert einen konkreten Proxy
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522640103854" ID="ID_904543861" MODIFIED="1522640126272" TEXT="dieser implementiert das Interface durch forwarden in das Interface-System"/>
|
|
<node CREATED="1522640127923" ID="ID_1407739777" MODIFIED="1522640137926" TEXT="dieser konkrete Proxy erbt von Holder"/>
|
|
<node CREATED="1522640145337" ID="ID_164293090" MODIFIED="1522640155883" TEXT="Holder ist auf das InstanceHandle getemplated"/>
|
|
<node CREATED="1522640166686" ID="ID_1356700504" MODIFIED="1522640234520" TEXT="der Holder instanziiert einen Statische Buffer für den Proxy als Meyer's Singleton"/>
|
|
<node CREATED="1522640235676" FOLDED="true" ID="ID_1807301195" MODIFIED="1561827483842" TEXT="der Holder hat statische open/close">
|
|
<node CREATED="1522640247947" ID="ID_1019392965" MODIFIED="1522640254990" TEXT="diese erzeugen/zerstören den Proxy"/>
|
|
<node CREATED="1522640255578" ID="ID_1613444847" MODIFIED="1522640262284" TEXT="und schalten jeweils den Accessor frei"/>
|
|
</node>
|
|
<node CREATED="1522640539147" ID="ID_1868996451" MODIFIED="1522640553196" TEXT="das InstanceHandle hat einen member FacadeLink"/>
|
|
<node CREATED="1522640554305" FOLDED="true" ID="ID_1413272395" MODIFIED="1561827483842" TEXT="dieser ist ein RAII-Handle für den Proxy">
|
|
<node CREATED="1522640572550" ID="ID_1609430700" MODIFIED="1522640579377" TEXT="ctor macht openProxy"/>
|
|
<node CREATED="1522640579965" ID="ID_1368405474" MODIFIED="1522640584304" TEXT="dtor macht closeProxy"/>
|
|
</node>
|
|
<node CREATED="1522640586812" ID="ID_1577947298" MODIFIED="1522640604677" TEXT="das InstanceHandle ist Member in der Service-Implementierung"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522640617752" ID="ID_312762900" MODIFIED="1561827466141" TEXT="Plan zum Umschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522640706787" FOLDED="true" ID="ID_1205995335" MODIFIED="1561827483842" TEXT="Idee-1">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522640624319" ID="ID_448652627" MODIFIED="1522640718658" TEXT="den Holder umbauen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1522640682079" ID="ID_263562862" MODIFIED="1522640697696" TEXT="er bekommt das DependInject::ServiceInstance-Handle"/>
|
|
<node CREATED="1522642839772" ID="ID_1686904789" MODIFIED="1522642870342" TEXT="OK aber nicht wirklich inspiriert">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1522642851003" ID="ID_1594923332" MODIFIED="1522642864813" TEXT="die verwirrende doppelte Indirektion bleibt"/>
|
|
</node>
|
|
<node CREATED="1522640758484" FOLDED="true" ID="ID_1080447818" MODIFIED="1561827483842" TEXT="Idee-2">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522640769123" ID="ID_628473221" MODIFIED="1522640801850" TEXT="InstanceHandle selber betreibt den Proxy als Service">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1522640803358" ID="ID_105578434" MODIFIED="1522640833493" TEXT="sein member FacadeLink wird die DependInject::ServiceInstance"/>
|
|
<node CREATED="1522640847752" ID="ID_951535107" MODIFIED="1522640870343" TEXT="Holder und Accessor fällt komplett weg">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1522642882751" FOLDED="true" ID="ID_1084473697" MODIFIED="1561827482934" TEXT="Gute Idee -- zukunftsfähig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522642898548" ID="ID_1128431348" MODIFIED="1522643775604" TEXT="InstanceHandle als Typ-Marker"/>
|
|
<node CREATED="1522642909755" ID="ID_880187850" MODIFIED="1522643775604" TEXT="damit vom eigentlichen Interface-System entkoppelt"/>
|
|
<node CREATED="1522642945462" ID="ID_1624080534" MODIFIED="1522643775604" TEXT="der konkrete Proxy könnte per SWIG generiert werden"/>
|
|
</node>
|
|
<node CREATED="1522640881187" FOLDED="true" ID="ID_1419416708" MODIFIED="1561827482934" TEXT="Frage: wie konstruiert man einen Proxy">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522641344691" ID="ID_1154911224" MODIFIED="1522641358813" TEXT="gegenwärtig: bekommt das InstanceHandle"/>
|
|
<node CREATED="1522641378263" ID="ID_1762905192" MODIFIED="1522641389641" TEXT="könnte aber direkt eine Interface-Ref sein"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522641405299" FOLDED="true" ID="ID_676190433" MODIFIED="1561827482934" TEXT="Proxy">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522641413586" FOLDED="true" ID="ID_1187300065" MODIFIED="1561827469160" TEXT="Anforderungen">
|
|
<linktarget COLOR="#86d29d" DESTINATION="ID_1187300065" ENDARROW="Default" ENDINCLINATION="-35;65;" ID="Arrow_ID_1735914452" SOURCE="ID_1212106242" STARTARROW="None" STARTINCLINATION="-135;-67;"/>
|
|
<node CREATED="1522641419769" ID="ID_1008132394" MODIFIED="1522641450457" TEXT="erbt vom Business-Interface"/>
|
|
<node CREATED="1522641451309" ID="ID_535550980" MODIFIED="1522641460551" TEXT="hällt Ref auf C-Interface"/>
|
|
<node CREATED="1522643854048" ID="ID_728832529" MODIFIED="1522643860851" TEXT="ist konstruierbar"/>
|
|
<node CREATED="1522643863687" ID="ID_1695236696" MODIFIED="1522643867842" TEXT="nicht kopierbar"/>
|
|
<node CREATED="1522641463059" ID="ID_487803821" MODIFIED="1522641471349" TEXT="lebt nur so lange das Interface offen ist"/>
|
|
</node>
|
|
<node COLOR="#0e0099" CREATED="1522649799320" FOLDED="true" ID="ID_1473698958" MODIFIED="1561827469161" TEXT="Ort der Definition">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522696074226" FOLDED="true" ID="ID_1811816913" MODIFIED="1561827469140" TEXT="Güterabwägung notwendig">
|
|
<node CREATED="1522696114852" ID="ID_550024261" MODIFIED="1522696125095" TEXT="Entkoppelung Serivce / Interface"/>
|
|
<node CREATED="1522696125987" ID="ID_387527816" MODIFIED="1522696135565" TEXT="Wartbarkeit des Binding-Codes"/>
|
|
<node CREATED="1522696172285" ID="ID_958011405" MODIFIED="1522696180623" TEXT="Komplexität der Implementierung"/>
|
|
</node>
|
|
<node CREATED="1522697094565" FOLDED="true" ID="ID_407823709" MODIFIED="1561827469140" TEXT="Wertung">
|
|
<node CREATED="1522697098420" ID="ID_640748324" MODIFIED="1522697195082" TEXT="Entkoppelung ist verpflichtend für Plug-Ins">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1522697126545" ID="ID_942767861" MODIFIED="1522697197851" TEXT="Wartbarkeit ist eine Frage der Binding-Technologie">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1522697141710" ID="ID_1821904602" MODIFIED="1522697200469" TEXT="Komplexität ist eine Folge der führenden Belange">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1522697220012" FOLDED="true" ID="ID_153609314" MODIFIED="1561827469140" TEXT="Fazit">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522697230906" ID="ID_1495746023" MODIFIED="1522697253419" TEXT="alle Bindings sind vom Instance-Handle zu entkoppeln"/>
|
|
<node CREATED="1522697255215" ID="ID_1841184306" MODIFIED="1522697273416" TEXT="für jedes Binding soll eine TranslationUnit frei wählbar sein"/>
|
|
<node COLOR="#338800" CREATED="1522697350106" ID="ID_138544872" MODIFIED="1522724906505" TEXT="Technik zur Entkoppelung benötigt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#0e0099" CREATED="1522649812255" FOLDED="true" ID="ID_624985973" MODIFIED="1561827469161" STYLE="fork">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Modus der Definition
|
|
</p>
|
|
<p>
|
|
und Instantiierung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#808080" STYLE="bezier" WIDTH="thin"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522697375430" FOLDED="true" ID="ID_712460375" MODIFIED="1561827469140" TEXT="Instantiierung">
|
|
<node COLOR="#338800" CREATED="1522697381141" ID="ID_855121513" MODIFIED="1522729342788" TEXT="gesteuert nur durch Lebensdauer des InstanceHandle">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522697396899" ID="ID_1172830820" MODIFIED="1522729342788" TEXT="Code der Proxy-Instantiierung in separater TU">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522697475153" FOLDED="true" ID="ID_520808733" MODIFIED="1561827469140" TEXT="Definition">
|
|
<node CREATED="1522697495790" ID="ID_1870975704" MODIFIED="1522729342788" TEXT="von Hand geschrieben">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1522697613893" ID="ID_1829346202" MODIFIED="1522729342788" TEXT="Idealerweise lediglich eigene TU">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1522729001386" ID="ID_242747417" MODIFIED="1522733826161" TEXT="ist mir bisher nicht gelungen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wir müssen immer, für jeden Proxy
|
|
</p>
|
|
<p>
|
|
explizit eine Template-Instaniierung triggern, und zwar für
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b49ca6" DESTINATION="ID_1547993807" ENDARROW="Default" ENDINCLINATION="10;-59;" ID="Arrow_ID_1421481593" STARTARROW="None" STARTINCLINATION="323;-44;"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522733831301" ID="ID_1741953995" MODIFIED="1522733846627" TEXT="Spezialisierung + explizite Template-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522697501541" ID="ID_793991584" MODIFIED="1522729342788" TEXT="Forwading-Implementation des Business-Interface">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522697646161" FOLDED="true" ID="ID_1020206021" MODIFIED="1561827469161" TEXT="Technologie">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522697675229" FOLDED="true" ID="ID_1605136526" MODIFIED="1561827469140" STYLE="fork" TEXT="Indirektion notwendig">
|
|
<node COLOR="#338800" CREATED="1522697690651" ID="ID_1244533717" MODIFIED="1522724892373" TEXT="Erzeugung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522697699297" ID="ID_891061833" MODIFIED="1522724893954" TEXT="Zerstörung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522697702521" ID="ID_1874387796" MODIFIED="1522724895488" TEXT="Zugriff auf Facade(Proxy)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522697743604" FOLDED="true" ID="ID_829814208" MODIFIED="1561827469141" TEXT="mögliche Lösungen">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1522697764121" FOLDED="true" ID="ID_809124789" MODIFIED="1522733895572" TEXT="PImpl">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522698166313" ID="ID_904988310" MODIFIED="1522698184466" TEXT="facade::Link hält einen smart-Ptr"/>
|
|
<node CREATED="1522698185030" ID="ID_53125514" MODIFIED="1522698208087" TEXT="auf die eigentliche DependInject::ServiceInstance"/>
|
|
<node CREATED="1522698222201" ID="ID_1341541114" MODIFIED="1522698292643" TEXT="facade::Link muß Methoden (ctor/dtor und operator) separat definieren"/>
|
|
<node CREATED="1522698295719" ID="ID_381014397" MODIFIED="1522698339173" TEXT="das ist effektiv die Lösung "separat definieren" + separate Storage"/>
|
|
</node>
|
|
<node CREATED="1522697803923" FOLDED="true" ID="ID_238110365" MODIFIED="1522733895572" TEXT="freie Funktionen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522698092963" ID="ID_433421738" MODIFIED="1522698105987" TEXT="ist die bisher bestehende Lösung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1522698013526" ID="ID_712885279" MODIFIED="1522698021465" TEXT="können selber komplett generisch sein"/>
|
|
<node CREATED="1522698022005" ID="ID_518407557" MODIFIED="1522698033855" TEXT="müssen jeweils explizit von einem Template instantiiert werden"/>
|
|
<node CREATED="1522698034563" ID="ID_1793485859" MODIFIED="1522698091426">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
brauchen eigenen Zugriffs-Mechanismus auf ein <i>weiteres</i> Handle-Objekt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522698124263" ID="ID_475034985" MODIFIED="1522698140464" TEXT="das ist effektiv ein PImpl, das aber auch noch gemanaged werden muß"/>
|
|
<node CREATED="1522729383029" ID="ID_212849140" MODIFIED="1522729398784" TEXT="Vorteil: erzeugen "nebenbei" die Template-Instantiierung">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522697773903" FOLDED="true" ID="ID_116063224" MODIFIED="1525124215489" TEXT="Methoden separat definieren">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1522698343480" ID="ID_1548420276" MODIFIED="1522733895572" TEXT="dafür sorgen, daß die Definitionen nur in der Proxy-Instantiierung (TU) sichtbar sind"/>
|
|
<node CREATED="1522698386810" ID="ID_1773412414" MODIFIED="1522733895572" TEXT="diese Definitionen müssen externe Linkage bekommen (d.h. nicht inline)"/>
|
|
<node CREATED="1522698437036" ID="ID_1400832405" MODIFIED="1522733895572" TEXT="Erzeugung ist automatisch, sofern dort das InstanceHandle-Template instantiiert wird"/>
|
|
<node CREATED="1522698892532" ID="ID_584280618" MODIFIED="1522733895572" TEXT="Fazit: in einer TU muß (nur) eine explizite Template-Instantiierung erfolgen"/>
|
|
<node COLOR="#338800" CREATED="1522699050727" FOLDED="true" ID="ID_1923832821" MODIFIED="1522733895572" TEXT="wie auch immer">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522699055062" FOLDED="true" ID="ID_1759934312" MODIFIED="1525124215488" TEXT="Spezialisierung Proxy<IHA> + Template Instanz dieser">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1522699225239" ID="ID_894223806" MODIFIED="1522733778687" TEXT="das ist praktisch die bestehende Lösung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1522699240684" ID="ID_600377865" MODIFIED="1522733778687" TEXT="wird dort nur indirekt über die Instanz der freinen Funktionen ausgelöet"/>
|
|
</node>
|
|
<node CREATED="1522699093017" FOLDED="true" ID="ID_471646453" MODIFIED="1522733778687" TEXT="Definition einer ungetemplateten Proxy-Klasse + CRTP">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522699211944" ID="ID_1925086643" MODIFIED="1522699223507" TEXT="geht das überhaupt?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1522702931486" ID="ID_2039076" MODIFIED="1522702953351" TEXT="CRTP-Klasse muß in allen anderen TU abstrakt bleiben"/>
|
|
<node CREATED="1522703026153" FOLDED="true" ID="ID_1981862674" MODIFIED="1525124215488" TEXT="Möglichkeiten">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522703031009" ID="ID_1131804681" MODIFIED="1522703033909" TEXT="PImpl"/>
|
|
<node CREATED="1522703258857" ID="ID_1322673347" MODIFIED="1522703371845" TEXT="Service-Impl (=Proxy)"/>
|
|
<node CREATED="1522703996867" FOLDED="true" ID="ID_690162584" MODIFIED="1525124215488" TEXT="Proxy ist Subklasse">
|
|
<node CREATED="1522704019688" ID="ID_1004073220" MODIFIED="1522704033386" TEXT="muß per Lambda erzeugt werden"/>
|
|
<node CREATED="1522704033950" ID="ID_1313113320" MODIFIED="1522704041464" TEXT="muß virtuellen dtor haben"/>
|
|
<node CREATED="1522704194912" ID="ID_317190411" MODIFIED="1522704592454" TEXT="Problem: konkrete Proxy-Klasse muß in ServiceInstance::activate">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...oder sogar den ctor, das ist egal --
|
|
</p>
|
|
<p>
|
|
denn das Problem ist, ctor (oder activate) werden aus <i>demjenigen</i> Kontext heraus aufgerufen,
|
|
</p>
|
|
<p>
|
|
der die Service-Implementierung startet und damit die Erzeugung des Proxy triggert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Dieser Kontext darf den konkreten Typ des Proxy aber genau nicht kennen (wegen Entkopplung)…
|
|
</p>
|
|
<p>
|
|
Genau aus diesem Grunde leiten wir ja ctor/dtor der ServiceInstance(Handle)-Klasse in eine ander TU um.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<b>Problem</b> ist nun, diese umgeleiteten Funktionsdefinitionen können <i>nur einen Typ</i> (Template-Parameter) bekommen, und dieser Typ wiederum muß -- zumindest als abstrakter Platzhalter -- in allen TU sichtbar sein.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1522709471957" ID="ID_170352206" MODIFIED="1522709540572" TEXT="scheint nicht lösbar">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522709550450" ID="ID_1653470424" MODIFIED="1522733671833" TEXT="konnte keine ganbare Lösung finden">
|
|
<linktarget COLOR="#4a2d79" DESTINATION="ID_1653470424" ENDARROW="Default" ENDINCLINATION="-1;58;" ID="Arrow_ID_362703203" SOURCE="ID_1800542023" STARTARROW="None" STARTINCLINATION="109;-22;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522709579398" FOLDED="true" ID="ID_1445259032" MODIFIED="1525124215488" TEXT="kann man spezialisieren und zugleich Instantiieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522720815569" ID="ID_1906873483" MODIFIED="1522733778687" TEXT="nein"/>
|
|
<node CREATED="1522720818625" ID="ID_693558811" MODIFIED="1522733778687" TEXT="wie schade">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522724948516" FOLDED="true" ID="ID_1547993807" MODIFIED="1525124215488" TEXT="explizite Instantiierung notwendig">
|
|
<linktarget COLOR="#b49ca6" DESTINATION="ID_1547993807" ENDARROW="Default" ENDINCLINATION="10;-59;" ID="Arrow_ID_1421481593" SOURCE="ID_242747417" STARTARROW="None" STARTINCLINATION="323;-44;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1522724966777" ID="ID_650754221" MODIFIED="1522733895572" TEXT="häßlich und umständlich"/>
|
|
<node CREATED="1522724973625" ID="ID_1016558302" MODIFIED="1522733895572" TEXT="Code dupliziert"/>
|
|
<node COLOR="#338800" CREATED="1522724977440" FOLDED="true" ID="ID_686663661" MODIFIED="1525124215488" TEXT="bessere Lösung?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522733470671" ID="ID_1296497133" MODIFIED="1522733895572" TEXT="nicht wirklich....">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1522733478510" ID="ID_1800542023" MODIFIED="1522733895572" TEXT="Proxy erbt per CRTP geht nicht">
|
|
<arrowlink COLOR="#4a2d79" DESTINATION="ID_1653470424" ENDARROW="Default" ENDINCLINATION="-1;58;" ID="Arrow_ID_362703203" STARTARROW="None" STARTINCLINATION="109;-22;"/>
|
|
</node>
|
|
<node CREATED="1522733542453" ID="ID_239191861" MODIFIED="1522733895572" TEXT="Proxy-Instantiierung triggert nicht InstanceHandle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
obwohl es das sollte.
|
|
</p>
|
|
<p>
|
|
Aber anscheinend macht der Compiler das nur partiell,
|
|
</p>
|
|
<p>
|
|
denn es wird ja nur eine const& an den ctor von Binding übergeben.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdings erscheint es mir nicht sinnvoll, hier mit Tricksereien zu arbeiten!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522733618506" ID="ID_1873321000" MODIFIED="1522733895572" TEXT="man könnte stattdesen Link instantiieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522733629233" ID="ID_424753876" MODIFIED="1522733895572" TEXT="Code-Duplizierung durch Typedefs beseitigt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522733866272" ID="ID_762156149" MODIFIED="1522734019934" TEXT="aktuelle Lösung erscheint adäquat">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sie ist zwar nicht schön -- aber was ist an einem Interface-Binding schon "schön"?
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Sie ist hinreichend wartbar, sofern man sie per copy-n-pate vervielfältigt.
|
|
</p>
|
|
<p>
|
|
Es wäre sogar denkbar, in diesen Rump eine generierte Proxy-Klasse zu kleben,
|
|
</p>
|
|
<p>
|
|
da nur wenige Variable erstetzt werden müßten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522649565217" ID="ID_1192073765" MODIFIED="1561827466150" TEXT="Probleme bei der Realisierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522649583511" ID="ID_709785832" MODIFIED="1522649600993" TEXT="Instancehandle muß jetzt die Proxy-Implementierung sehen"/>
|
|
<node CREATED="1522649601916" FOLDED="true" ID="ID_114261035" MODIFIED="1561827483842" TEXT="die beiden Seiten des Bindings sind damit fest verkoppelt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist ein konzeptionelles Problem.
|
|
</p>
|
|
<p>
|
|
Eigentlich möchte man durch ein Interface Entkoppelung erreichen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Nun ist es so, daß
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
das Binding BusinessInterface -> InterfaceSystem
|
|
</li>
|
|
<li>
|
|
InterfaceSystem -> Service-Implementierung
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
an der gleichen Stelle erfolgen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1522649701166" ID="ID_444680334" MODIFIED="1522649709173" TEXT="knock-out für das GUI">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node CREATED="1522649711165" ID="ID_1651731483" MODIFIED="1522649729254" TEXT="erzeugt zyklische ABI-Abhängigkeiten">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522649763142" ID="ID_1212106242" MODIFIED="1522649902016" TEXT="aber der Rest würde schön funktionieren">
|
|
<arrowlink COLOR="#86d29d" DESTINATION="ID_1187300065" ENDARROW="Default" ENDINCLINATION="-35;65;" ID="Arrow_ID_1735914452" STARTARROW="None" STARTINCLINATION="-135;-67;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709629935" ID="ID_151551561" MODIFIED="1522724915985" TEXT="Lösung zum Entkoppeln der Proxy-Definition">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709654308" ID="ID_1059248114" MODIFIED="1561827466151" TEXT="bestehenden Code umschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522709669498" FOLDED="true" ID="ID_9288802" MODIFIED="1561827483842" TEXT="alle bestehenden Proxies">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522635397309" ID="ID_590180071" MODIFIED="1522724921600" TEXT="SessionCommandService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635417932" ID="ID_1711611771" MODIFIED="1522724922888" TEXT="DisplayService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635433910" ID="ID_444280759" MODIFIED="1522724924183" TEXT="GuiNotification">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635450269" ID="ID_1963184158" MODIFIED="1522724925717" TEXT="DummyPlayerService">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709729297" FOLDED="true" ID="ID_1293938610" MODIFIED="1561827483842" TEXT="Facade-Accessoren auf lib::Depend umstellen">
|
|
<arrowlink COLOR="#68baaa" DESTINATION="ID_1756362217" ENDARROW="Default" ENDINCLINATION="32;1321;" ID="Arrow_ID_1797728654" STARTARROW="None" STARTINCLINATION="-288;-420;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522635397309" ID="ID_883916833" MODIFIED="1522710489037" TEXT="SessionCommand">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635417932" ID="ID_245882411" MODIFIED="1522710526832" TEXT="Display(Facade)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635433910" ID="ID_1703058328" MODIFIED="1522710636764" TEXT="GuiNotification">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522635450269" ID="ID_193152767" MODIFIED="1522710900353" TEXT="DummyPlayer">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522711261733" FOLDED="true" ID="ID_1953483085" MODIFIED="1561827482934" TEXT="Play(Facade)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522711269948" ID="ID_153188000" MODIFIED="1522711287118" TEXT="hängt aber an dem InterfaceFacadeLink">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709748015" ID="ID_44849308" MODIFIED="1522717910945" TEXT="bestehenden Accessor zurückbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709756798" ID="ID_1024028685" MODIFIED="1522717913716" TEXT="Header umorganisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522709763388" ID="ID_778622044" MODIFIED="1522728945187" TEXT="Doxygen-Doku aktualisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522033564057" FOLDED="true" ID="ID_1294295502" MODIFIED="1563022708690" TEXT="Nacharbeiten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522454023039" ID="ID_1828121921" MODIFIED="1525124215498" TEXT="Folge-Probleme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522454040500" ID="ID_1674154774" MODIFIED="1533608414118" TEXT="Architektur">
|
|
<node CREATED="1522454061873" ID="ID_1012349550" MODIFIED="1561827466157" TEXT="unklare statische Abhängigkeiten">
|
|
<node CREATED="1522454074760" FOLDED="true" ID="ID_1884600051" MODIFIED="1561827483842" TEXT="ClassLock">
|
|
<linktarget COLOR="#8195ac" DESTINATION="ID_1884600051" ENDARROW="Default" ENDINCLINATION="-604;0;" ID="Arrow_ID_648096672" SOURCE="ID_1287049121" STARTARROW="None" STARTINCLINATION="175;-122;"/>
|
|
<node CREATED="1522454289393" ID="ID_860238388" MODIFIED="1522454304036" TEXT="verwendet ein Meyers Singleton"/>
|
|
<node CREATED="1522454304576" ID="ID_692796029" MODIFIED="1522454312395" TEXT="und damit statische Init"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522454152941" FOLDED="true" ID="ID_1003385410" MODIFIED="1561827483843" TEXT="lib::Depend">
|
|
<arrowlink COLOR="#487bba" DESTINATION="ID_399844845" ENDARROW="Default" ENDINCLINATION="237;509;" ID="Arrow_ID_1393532861" STARTARROW="None" STARTINCLINATION="733;-537;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522454265837" ID="ID_405478687" MODIFIED="1522454275983" TEXT="braucht ClassLock bis zum bitteren Ende"/>
|
|
<node CREATED="1522454276667" ID="ID_1140029140" MODIFIED="1522454286502" TEXT="selbst wenn es nur darum geht, einen Fehler zu produzieren"/>
|
|
<node COLOR="#338800" CREATED="1522557434769" ID="ID_726345477" MODIFIED="1522557447919" TEXT="habe beide nun mit einem ZombieCheck geschützt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522557456894" ID="ID_627428103" MODIFIED="1522557498811">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und lib::Depend so umarrangiert,
|
|
</p>
|
|
<p>
|
|
daß re-entrant-Aufrufe während dem dtor erlaubt sind
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522454146645" FOLDED="true" ID="ID_818640049" MODIFIED="1563022698843" TEXT="Advice-System">
|
|
<arrowlink DESTINATION="ID_1843874673" ENDARROW="Default" ENDINCLINATION="-398;-418;" ID="Arrow_ID_908178206" STARTARROW="None" STARTINCLINATION="1004;0;"/>
|
|
<linktarget COLOR="#7a8fa9" DESTINATION="ID_818640049" ENDARROW="Default" ENDINCLINATION="-384;-20;" ID="Arrow_ID_1167388040" SOURCE="ID_1527905225" STARTARROW="None" STARTINCLINATION="309;-116;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1522454318558" ID="ID_65008261" MODIFIED="1522454338494" TEXT="braucht sicht selbst beim Runterfahren">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1522455443139" FOLDED="true" ID="ID_57531429" MODIFIED="1561827482935" TEXT="Pfad...">
|
|
<node CREATED="1522455359030" ID="ID_1748706225" MODIFIED="1522455463636" TEXT="~AdviceSystem"/>
|
|
<node CREATED="1522455363486" ID="ID_1789501340" MODIFIED="1522455366137" TEXT="DelStash"/>
|
|
<node CREATED="1522455375636" ID="ID_890323979" MODIFIED="1522455397132" TEXT="Provision<X>::releaseAdviceData"/>
|
|
<node CREATED="1522455412007" ID="ID_1942444713" MODIFIED="1522455423217" TEXT="AdviceLink::releaseBuffer()"/>
|
|
<node CREATED="1522455439131" ID="ID_1655592437" MODIFIED="1522455440982" TEXT="aSys().releaseBuffer(buff, siz)"/>
|
|
<node CREATED="1522455488220" ID="ID_817525837" MODIFIED="1522455490927" TEXT="Tadaaaa!"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522557127755" FOLDED="true" ID="ID_842175492" MODIFIED="1561827482935" TEXT="das ist grenzwertig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522557139721" ID="ID_1248571887" MODIFIED="1522557151307" TEXT="es handelt sich um eine re-entrance">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1522557152331" ID="ID_1546957816" MODIFIED="1522557415704">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
so wie das Advice-System geschrieben ist,
|
|
</p>
|
|
<p>
|
|
kann und muß man das "durchwinken"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
denn grundsätzlich ist das ganze Advice-System bewußt "billig" implementiert;
|
|
</p>
|
|
<p>
|
|
Verbesserungen später willkommen....
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Der Destructor räumt alle AdviceProvisions weg.
|
|
</p>
|
|
<p>
|
|
Diese werden in einen statischen Kontext geschoben, damit sie unabhängig vom Advisor weiterleben.
|
|
</p>
|
|
<p>
|
|
Daher müssen wir aus diesem statischen Kontext heraus wieder zurück in's AdviceSystem kommen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Alternative wäre, eine komplett spezielle De-Allokations-Routine zu schreiben,
|
|
</p>
|
|
<p>
|
|
welche die Datenstrukturen direkt traversiert und freigibt, und dann die Provisions
|
|
</p>
|
|
<p>
|
|
abfischt und ebenfalls alles wegwirft. Machbar, erscheint aber im Mißverhältnis
|
|
</p>
|
|
<p>
|
|
zum Level der gesamten übrigen Implementierung (welche nämlich um einiges
|
|
</p>
|
|
<p>
|
|
elaborierter sein könnte, incl. Verwendung von Atomics und einem besseren
|
|
</p>
|
|
<p>
|
|
Memory-Management.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Aber wie gesagt, das ganze Advice-System ist eine Skizze
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522454344402" ID="ID_1823464628" MODIFIED="1561827466161" TEXT="Singletons">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1522454381692" ID="ID_1785213595" MODIFIED="1522454381692" TEXT="wurden bisher praktisch gar nicht runtergefahren"/>
|
|
<node CREATED="1522454384941" FOLDED="true" ID="ID_1849825340" MODIFIED="1561827483843" TEXT="zwar pro-Forma schon">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522454395011" ID="ID_1147769502" MODIFIED="1522454420012" TEXT="aber die Storage blieb stehen"/>
|
|
<node CREATED="1522454407666" ID="ID_284304272" MODIFIED="1522454412948" TEXT="und so ist es nie aufgefallen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522455572377" FOLDED="true" ID="ID_995968267" MODIFIED="1561827483843" TEXT="Policy ist klar">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522455589150" ID="ID_720232530" MODIFIED="1522455637085" TEXT="Kein Service darf aus dem dtor eine Dependency ziehen!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1522455619290" ID="ID_1340742552" MODIFIED="1522455634839" TEXT="im Zweifelsfalle ist ON_SHUTDOWN zu verwenden!">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1522454132616" ID="ID_1054219137" MODIFIED="1561827466162" TEXT="brauchen wir einen Basis-Layer?">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522455499003" ID="ID_323278727" MODIFIED="1522547122649" TEXT="vermutlich ja">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522547104318" ID="ID_1075985632" MODIFIED="1522547119436" TEXT="nein besser nicht">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1522455507937" FOLDED="true" ID="ID_1029197196" MODIFIED="1561827483843" TEXT="für wen?">
|
|
<linktarget COLOR="#512c6f" DESTINATION="ID_1029197196" ENDARROW="Default" ENDINCLINATION="-299;0;" ID="Arrow_ID_845867084" SOURCE="ID_22169859" STARTARROW="None" STARTINCLINATION="1419;0;"/>
|
|
<node CREATED="1522455514361" ID="ID_1288380071" MODIFIED="1522455518148" TEXT="ClassLock"/>
|
|
<node CREATED="1522455519448" ID="ID_77194477" MODIFIED="1522455527347" TEXT="Application-Object?"/>
|
|
<node CREATED="1522455527838" ID="ID_483432379" MODIFIED="1522455530186" TEXT="Nobug?"/>
|
|
</node>
|
|
<node CREATED="1522455653525" FOLDED="true" ID="ID_1606025045" MODIFIED="1561827483843" TEXT="wie?">
|
|
<node CREATED="1522455656181" FOLDED="true" ID="ID_1878626771" MODIFIED="1561827482935" TEXT="Schwartz-Counter">
|
|
<linktarget COLOR="#b12341" DESTINATION="ID_1878626771" ENDARROW="Default" ENDINCLINATION="166;90;" ID="Arrow_ID_1822166267" SOURCE="ID_695551107" STARTARROW="None" STARTINCLINATION="385;46;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1522557054805" ID="ID_618759088" MODIFIED="1522557106032" TEXT="nein, besser gleich ganz wegwerfen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522557070059" ID="ID_286421321" MODIFIED="1522557102288" TEXT="Meyer's Singleton + ZombieCheck">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522455662692" ID="ID_402293175" MODIFIED="1522455685565" TEXT="und zwar richtig implementiert">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522455672003" ID="ID_1633730200" MODIFIED="1522455677646" TEXT="mit Atomic"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522454162939" ID="ID_867445269" MODIFIED="1533608414127" TEXT="Subklassen-Konfig">
|
|
<node CREATED="1522454176426" ID="ID_964380935" MODIFIED="1522454188772" TEXT="muß jetzt in den Provider-Scope"/>
|
|
<node CREATED="1522454189359" ID="ID_1178508604" MODIFIED="1522454200306" TEXT="dieser ist meist nicht so offensichtlich klar"/>
|
|
<node COLOR="#338800" CREATED="1522454200902" ID="ID_1367664577" MODIFIED="1561827466164" TEXT="ConfigRules">
|
|
<linktarget COLOR="#8fbeb3" DESTINATION="ID_1367664577" ENDARROW="Default" ENDINCLINATION="-268;0;" ID="Arrow_ID_1637829369" SOURCE="ID_1789329281" STARTARROW="None" STARTINCLINATION="26;-32;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522454211157" ID="ID_1826864875" MODIFIED="1522454217672" TEXT="Subclass MockConfigRules"/>
|
|
<node CREATED="1522454218267" ID="ID_1085608506" MODIFIED="1522628399085" TEXT="in die ConfigManager-Implementierung verelgt"/>
|
|
<node CREATED="1522454239657" ID="ID_746728834" MODIFIED="1522628416235" TEXT="passiert nun ON_GLOBAL_INIT"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522018567685" ID="ID_1619059123" MODIFIED="1525124215499" TEXT="Frage: was ist mit AppState?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1522018581283" ID="ID_132446315" MODIFIED="1533608414128" TEXT="macht es Sinn, das via Depend zugänglich zu machen?">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1522630308841" ID="ID_1688145864" MODIFIED="1522630349227" TEXT="Ja">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1522630312898" ID="ID_23962719" MODIFIED="1522630325291" TEXT="Wird zwar von lumiera::Config hochgezogen"/>
|
|
<node CREATED="1522630325999" ID="ID_976681959" MODIFIED="1522630344624" TEXT="...welches aber selber schon per lib::Depend instantiiert wird"/>
|
|
</node>
|
|
<node CREATED="1522018593697" ID="ID_1730197219" MODIFIED="1522018623361" TEXT="ist bisher ein Meyer's Singleton"/>
|
|
<node CREATED="1522018623861" ID="ID_1923633930" MODIFIED="1522018631776" TEXT="aber lebt bereits im globalen Speicher"/>
|
|
<node CREATED="1522630364690" ID="ID_1442746804" MODIFIED="1522630460073" TEXT="ABER: LifecycleRegistry muß Meyer's Singleton bleiben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil Nobug-Init ON_BASIC_INIT braucht,
|
|
</p>
|
|
<p>
|
|
und lib::Depend wiederum von Nobug-Init abhängig ist.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Also würde DependencyFactory<LifecycleRegistry> aufgerufen,
|
|
</p>
|
|
<p>
|
|
bevor es statisch initialisiert sein kann...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522630297899" ID="ID_365546675" MODIFIED="1522630305978" TEXT="umgestellt auf lib::Depend">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521433694233" ID="ID_1951071885" MODIFIED="1525124215500" STYLE="fork" TEXT="Nebenbei: Schwartz-Counter in ClassLock ablösen">
|
|
<arrowlink COLOR="#735d7e" DESTINATION="ID_715588139" ENDARROW="Default" ENDINCLINATION="1087;0;" ID="Arrow_ID_1384015103" STARTARROW="None" STARTINCLINATION="-84;86;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1521433723421" ID="ID_1813539288" MODIFIED="1522557016686" TEXT="Meyers Singleton ist seit C++11 wasserdicht">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1521433748650" ID="ID_1831581678" MODIFIED="1522557016686">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und heute würde ich den Code <i>so</i> nicht mehr schreiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node COLOR="#734e81" CREATED="1522451891933" ID="ID_695551107" MODIFIED="1522558416047" TEXT="...und er ist jetzt sogar kamputt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
genauer:
|
|
</p>
|
|
<p>
|
|
er ist nicht kaputt, sondern hat sehr gut funktioniert und diesen Unfug festgestellt.
|
|
</p>
|
|
<p>
|
|
Nämlich daß unser lib::Depend ein ClassLock braucht, um einen Fehler zu melden.
|
|
</p>
|
|
<p>
|
|
Das ist, für sich betrachtet, eigentlich unvermeidlich, aber verlangt dann auch
|
|
</p>
|
|
<p>
|
|
nach einer grundlegenden Lösung. D.h. einem <i>echten</i> Schwartz-Counter.
|
|
</p>
|
|
<p>
|
|
Nicht einem, der in einem Meyer's Singleton steckt...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#b12341" DESTINATION="ID_1878626771" ENDARROW="Default" ENDINCLINATION="166;90;" ID="Arrow_ID_1822166267" STARTARROW="None" STARTINCLINATION="385;46;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1521160792856" FOLDED="true" ID="ID_367925099" MODIFIED="1563022707025" TEXT="System läuft wie zuvor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522457229331" ID="ID_1130290094" MODIFIED="1522632193064" TEXT="Test-Suite">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522457238099" ID="ID_1287049121" MODIFIED="1522597557304" TEXT="ClassLock schlägt Alarm">
|
|
<arrowlink COLOR="#8195ac" DESTINATION="ID_1884600051" ENDARROW="Default" ENDINCLINATION="-604;0;" ID="Arrow_ID_648096672" STARTARROW="None" STARTINCLINATION="175;-122;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522457377743" ID="ID_157728376" MODIFIED="1522628243174" TEXT="DefsManager_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522630494375" ID="ID_787599487" MODIFIED="1533608414128" TEXT="PlacementHierarchy_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522632143740" ID="ID_1275561066" MODIFIED="1522632156461" TEXT="<atomic> includiert stdbool.h"/>
|
|
<node CREATED="1522632157338" ID="ID_4818535" MODIFIED="1522632168332" TEXT="und der macht #define false false"/>
|
|
<node CREATED="1522632168896" ID="ID_547171089" MODIFIED="1522632176011" TEXT="der Test hat #ifdef false"/>
|
|
<node CREATED="1522632177543" ID="ID_319056454" MODIFIED="1522632185383" TEXT="Hurgha">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522632197852" ID="ID_453425962" MODIFIED="1522632208940" TEXT="GRÜÜÜÜÜÜÜN">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522457303466" ID="ID_28369083" MODIFIED="1522597732907" TEXT="Advice-System verpfuscht">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1522457315568" ID="ID_1527905225" MODIFIED="1522628482100" TEXT="Policy-Verletzung">
|
|
<arrowlink COLOR="#7a8fa9" DESTINATION="ID_818640049" ENDARROW="Default" ENDINCLINATION="-384;-20;" ID="Arrow_ID_1167388040" STARTARROW="None" STARTINCLINATION="309;-116;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522597569180" ID="ID_602663488" MODIFIED="1522597663372" TEXT="naja... nicht schön aber OK">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es ruft sich selbst rekursiv auf, via Depend<AdviceSystem>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1522597604367" ID="ID_1036644185" MODIFIED="1522597629034" TEXT="Alternative wäre aufwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nämlich eine ganz spezielle, dedzierte Aufräum-Routine schreiben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522597631464" ID="ID_1772415968" MODIFIED="1522597644885" TEXT="...und dazu ist das Advice-System zu experimentell"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522457395749" ID="ID_1439882391" MODIFIED="1522628434994" TEXT="Subclass-Singleton">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522457406523" ID="ID_715525481" MODIFIED="1522628426366" TEXT="wer ist schuld?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522628298319" ID="ID_1789329281" MODIFIED="1522628490770" TEXT="ein Nebeneffekt der Konfiguration für ConfigResolver">
|
|
<arrowlink COLOR="#8fbeb3" DESTINATION="ID_1367664577" ENDARROW="Default" ENDINCLINATION="-268;0;" ID="Arrow_ID_1637829369" STARTARROW="None" STARTINCLINATION="26;-32;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515975745485" ID="ID_132088730" MODIFIED="1515976000614" TEXT="Konzept">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1515975966400" ID="ID_1072605894" MODIFIED="1515975968459" TEXT="man hat ein statisches Front-End, d.h. by-name access"/>
|
|
<node CREATED="1515975976014" ID="ID_842891656" MODIFIED="1515975977346" TEXT="hinter dem liegt eine Factory"/>
|
|
<node CREATED="1515975984502" ID="ID_65481597" MODIFIED="1515975985545" TEXT="die Instanz kann von innen her wieder geschlossen werden"/>
|
|
<node CREATED="1515975995564" ID="ID_1901876074" MODIFIED="1515975996512" TEXT="wenn geschlossen, dann Fehler werfen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515976632168" ID="ID_346073460" MODIFIED="1515976637675" TEXT="Verdrahtung">
|
|
<node CREATED="1522738962198" ID="ID_66084476" MODIFIED="1522738989254" TEXT="per ctor-Parameter bei Services"/>
|
|
<node CREATED="1522738949663" ID="ID_1169687839" MODIFIED="1522738958530" TEXT="per closure"/>
|
|
<node CREATED="1522738993353" ID="ID_134172826" MODIFIED="1522739006692" TEXT="per rekursivem Depend + Lifecycle"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515975646354" ID="ID_1049835373" MODIFIED="1561827466167" TEXT="Singleton">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1515976424292" ID="ID_357830540" MODIFIED="1515976443809" TEXT="meist gut genug">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1515976448409" FOLDED="true" ID="ID_775751243" MODIFIED="1563022778225" TEXT="Probleme">
|
|
<node CREATED="1515976471557" ID="ID_1775190424" MODIFIED="1515976477336" TEXT="Lebenszyklus tricky"/>
|
|
<node CREATED="1515976478852" ID="ID_443463816" MODIFIED="1515976504093" TEXT="API / Subklasse"/>
|
|
<node CREATED="1515976504801" ID="ID_1385819621" MODIFIED="1515976664450" TEXT="Test/Mocking">
|
|
<arrowlink COLOR="#c1a9ac" DESTINATION="ID_896967532" ENDARROW="Default" ENDINCLINATION="46;-116;" ID="Arrow_ID_618937075" STARTARROW="None" STARTINCLINATION="-41;116;"/>
|
|
</node>
|
|
<node CREATED="1515976514776" ID="ID_1223148072" MODIFIED="1515976595813" TEXT="Themen vermischt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1515976519135" ID="ID_39360808" MODIFIED="1515976524490" TEXT="Service-Zugang"/>
|
|
<node CREATED="1515976525150" ID="ID_55041678" MODIFIED="1515976530322" TEXT="on-demand creation"/>
|
|
<node CREATED="1515976545956" ID="ID_1469471746" MODIFIED="1515976549743" TEXT="Lebenszyklus"/>
|
|
<node CREATED="1515976550427" ID="ID_321725023" MODIFIED="1515976560934" TEXT="Konfiguration / Parametrisierung"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1515975600368" ID="ID_896967532" MODIFIED="1515976656307" TEXT="für Unit-Tests">
|
|
<linktarget COLOR="#c1a9ac" DESTINATION="ID_896967532" ENDARROW="Default" ENDINCLINATION="46;-116;" ID="Arrow_ID_618937075" SOURCE="ID_1385819621" STARTARROW="None" STARTINCLINATION="-41;116;"/>
|
|
<node COLOR="#338800" CREATED="1522506758042" ID="ID_1422898694" MODIFIED="1522506783584" TEXT="DependInject<I>::Local<MOC>">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563022290903" ID="ID_1738614427" MODIFIED="1563022298518" TEXT="Logik/Informations-Technik">
|
|
<node CREATED="1563022305566" ID="ID_1375417763" MODIFIED="1563028982708">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das «<b>Regel</b>-System»
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563029003092" ID="ID_1788007006" MODIFIED="1563029014836" TEXT="...ist bisher nicht mehr als eine Schnappsidee">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563022311632" ID="ID_1353415142" MODIFIED="1563028970867">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das «<b>Advice</b>-System»
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563022363974" ID="ID_290527164" MODIFIED="1563022368517" TEXT="Konzept">
|
|
<node CREATED="1563022369373" ID="ID_201969563" MODIFIED="1563022372857" TEXT="von 2010"/>
|
|
<node CREATED="1563022373578" ID="ID_1190645627" MODIFIED="1576282357966" TEXT="immer noch experimentell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auch in 2019...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
nur einige sporadische Use-Cases
|
|
</li>
|
|
<li>
|
|
ich halte es aber weiterhin für wichtig
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563022416308" ID="ID_1045079282" MODIFIED="1563022427519">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein <b>Whiteboard-System</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563022428253" ID="ID_488828433" MODIFIED="1563022438478" TEXT="geplante Erweiterung: Unifikation">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563022526728" ID="ID_1836336225" MODIFIED="1563028919215" TEXT="Features">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1563022531695" ID="ID_1537850929" MODIFIED="1563022538906" TEXT="Topic">
|
|
<node COLOR="#338800" CREATED="1563022540464" ID="ID_1729592768" MODIFIED="1563022542831" TEXT="getypt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022543998" ID="ID_1378204754" MODIFIED="1563022562327" TEXT="ground-atom">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022569367" ID="ID_912699059" MODIFIED="1563022575513" TEXT="Advice setzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022582735" ID="ID_249193090" MODIFIED="1563022586647" TEXT="Advice überschreiben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022576324" ID="ID_756916431" MODIFIED="1563022581713" TEXT="Advice zurückziehen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563022612700" FOLDED="true" ID="ID_1996378025" MODIFIED="1575240116524" TEXT="Vorliegen von Advice feststellen">
|
|
<linktarget COLOR="#1dba57" DESTINATION="ID_1996378025" ENDARROW="Default" ENDINCLINATION="3933;-460;" ID="Arrow_ID_1546347584" SOURCE="ID_1908316447" STARTARROW="None" STARTINCLINATION="2753;244;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563023237085" ID="ID_1601131217" MODIFIED="1563023251307" TEXT="genauer: ein dediziertes Binding"/>
|
|
<node CREATED="1563023252134" ID="ID_1294314783" MODIFIED="1563023257630" TEXT="nicht die default-Lösung"/>
|
|
<node CREATED="1563023271763" ID="ID_807996870" MODIFIED="1563023274919" TEXT="sinnvoll?">
|
|
<node CREATED="1563023275863" ID="ID_309537458" MODIFIED="1563023285142" TEXT="ja: das Advice-System ist inhärent stateful"/>
|
|
<node CREATED="1563023286238" ID="ID_1249260795" MODIFIED="1563023304193" TEXT="man muß es ja nicht nutzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....denn es gibt die default-Lösung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563023660812" ID="ID_1579367227" MODIFIED="1563028899851" TEXT="Implementierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1563023667023" ID="ID_1893665226" MODIFIED="1563028901796" TEXT="trivial">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563023671305" ID="ID_70860178" MODIFIED="1563023709037" TEXT="Request und Provision erben beide von PointOfAdvice"/>
|
|
<node CREATED="1563023710113" ID="ID_208212985" MODIFIED="1563023724579" TEXT="dort kann man auf Vorliegen einer NULL-Lösung testen"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1563023728681" ID="ID_1738823249" MODIFIED="1563028903194" TEXT="Unit-Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1563023769944" ID="ID_621456362" MODIFIED="1563028904417" TEXT="AdviceSituations_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1563023774448" ID="ID_139010445" MODIFIED="1563023779163" TEXT="bisher reiner Platzhalter"/>
|
|
<node CREATED="1563023779807" ID="ID_871541450" MODIFIED="1563028909666" TEXT="umfunktionieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
im Sinne des Erfinders...
|
|
</p>
|
|
<p>
|
|
bloß jetzt etwas abstrakter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563022446403" ID="ID_705506377" MODIFIED="1563022449971" TEXT="Implementierung">
|
|
<node CREATED="1563022451864" ID="ID_1018435620" MODIFIED="1563022457829" TEXT="globales Singleton"/>
|
|
<node CREATED="1563022462513" ID="ID_774294960" MODIFIED="1563022475492" TEXT="global gelockte Binding-Hashtable"/>
|
|
<node CREATED="1563022479454" ID="ID_184511843" MODIFIED="1563022496031" TEXT="Zugrif auf Advice ist "wild", ohne Locking">
|
|
<node CREATED="1563022500900" ID="ID_1591934024" MODIFIED="1563022507279" TEXT="via Pointer"/>
|
|
<node CREATED="1563022509564" ID="ID_1679754158" MODIFIED="1563022512540" TEXT="daher atomar"/>
|
|
<node CREATED="1563022513810" ID="ID_283300133" MODIFIED="1563022521780" TEXT="aber ohne Zustellungs-Garantie"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563022664127" ID="ID_1843874673" MODIFIED="1563022698843" TEXT="Probleme">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1843874673" ENDARROW="Default" ENDINCLINATION="-398;-418;" ID="Arrow_ID_908178206" SOURCE="ID_818640049" STARTARROW="None" STARTINCLINATION="1004;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1522457000411" FOLDED="true" ID="ID_736034555" MODIFIED="1563022234022" TEXT="Basis-System">
|
|
<linktarget COLOR="#af98b6" DESTINATION="ID_736034555" ENDARROW="Default" ENDINCLINATION="2208;-356;" ID="Arrow_ID_1927977085" SOURCE="ID_1228603701" STARTARROW="None" STARTINCLINATION="448;721;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522457035478" ID="ID_1692167558" MODIFIED="1522556857858" TEXT="#1133 dependable base system">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1522457044789" ID="ID_22169859" MODIFIED="1522457177939" TEXT="für einige minimale Einrichtungen">
|
|
<arrowlink COLOR="#512c6f" DESTINATION="ID_1029197196" ENDARROW="Default" ENDINCLINATION="-299;0;" ID="Arrow_ID_845867084" STARTARROW="None" STARTINCLINATION="1419;0;"/>
|
|
</node>
|
|
<node CREATED="1522506451269" ID="ID_55500881" MODIFIED="1522506467912" TEXT="Anforderungen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522506486504" ID="ID_1878547223" MODIFIED="1522547691142" TEXT="Scope jeweils für einen Payload-Typ"/>
|
|
<node CREATED="1522506518348" ID="ID_1014457759" MODIFIED="1522547692821" TEXT="gemeinsame statische Storage für diesen Typ"/>
|
|
<node CREATED="1522506636907" ID="ID_662985730" MODIFIED="1522547695756" TEXT="ctor/dtor für Payload werden aufgerufen">
|
|
<node CREATED="1522511826327" ID="ID_200801018" MODIFIED="1522511828746" TEXT="ctor">
|
|
<node CREATED="1522518918379" ID="ID_261980616" MODIFIED="1522518931653" TEXT="bevor Payload benötigt wird"/>
|
|
</node>
|
|
<node CREATED="1522511829358" ID="ID_509925407" MODIFIED="1522511830546" TEXT="dtor">
|
|
<node CREATED="1522518935777" ID="ID_1823418824" MODIFIED="1522518941700" TEXT=""möglichst spät""/>
|
|
<node CREATED="1522518942263" ID="ID_203967064" MODIFIED="1522518945211" TEXT="aber zuverlässig"/>
|
|
</node>
|
|
<node CREATED="1522514043309" ID="ID_1380359037" MODIFIED="1522514045656" TEXT="wann?">
|
|
<node CREATED="1522514050796" ID="ID_191668372" MODIFIED="1522514056079" TEXT="pro Typ">
|
|
<node CREATED="1522518875353" ID="ID_1629001557" MODIFIED="1522518882228" TEXT="ist das überhaupt möglich?"/>
|
|
<node CREATED="1522518882744" ID="ID_1818509600" MODIFIED="1522518901851" TEXT="läuft wieder auf ein Template-generiertes Static hinaus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522514056835" ID="ID_1693314028" MODIFIED="1522514067974" TEXT="für alle DependableBase">
|
|
<node CREATED="1522514071649" ID="ID_433197904" MODIFIED="1522514079988" TEXT="erfordert DelStash"/>
|
|
<node CREATED="1522514086711" ID="ID_1216342984" MODIFIED="1522514117422" TEXT="an einem sicheren Ort"/>
|
|
<node CREATED="1522514120075" ID="ID_664406309" MODIFIED="1522514130012" TEXT="Idee: shared_ptr hierfür">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1522514148983" ID="ID_1331551985" MODIFIED="1522514165872" TEXT="jede neue DependableBase registriert sich"/>
|
|
<node CREATED="1522514307456" ID="ID_930138927" MODIFIED="1522514332529" TEXT="Problem: Deregistrierung von Einträgen aus shared libs">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1522541153861" ID="ID_1598087575" MODIFIED="1522541200548" TEXT="Problem: muß auch jeden einzelnen ctor tracken">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522506685708" ID="ID_172729748" MODIFIED="1522547698341" TEXT="...allerdings über einen Refcount für den Scope"/>
|
|
<node CREATED="1522506808180" ID="ID_962156028" MODIFIED="1522547700284" TEXT="Refcount verwendet Atomics"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522518973331" ID="ID_136789565" MODIFIED="1522518988634" TEXT="Design-Dilemma">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1522519009127" ID="ID_989945730" MODIFIED="1522519024864" TEXT="einfache Statics "sollten" lokal funktionieren"/>
|
|
<node CREATED="1522519025972" ID="ID_714585131" MODIFIED="1522519142036" TEXT="das Problem ist, wenn man sich auf externe Statics abstützt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das kann ziemlich indirekt passieren.
|
|
</p>
|
|
<p>
|
|
Beispiel ist das ClassLock. Das ist ein Front-End, und verwendet verdeckt wieder einen Static.
|
|
</p>
|
|
<p>
|
|
Und genau <i>dafür</i> gibt es anscheinend keine Garantieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1522541262254" ID="ID_1609622536" MODIFIED="1522541279648" TEXT="genauer: wenn man sich auf on-demand (local) statics abstützt"/>
|
|
<node CREATED="1522541280331" ID="ID_296029834" MODIFIED="1522541319853">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
C++ hällt die Erzeugungs/Zerstörungs-Reihenfolge <b>exakt</b> ein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522541321043" ID="ID_966332775" MODIFIED="1522541356223">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wenn das local static <i>später erzeugt</i> wird, wird es <b>vor</b>  dem Hauptobjekt zerstört
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522519161785" ID="ID_608910503" MODIFIED="1522519198800" TEXT="aus Gründen der Code-Organisation will man aber nicht immer alles in ein Objekt packen"/>
|
|
<node CREATED="1522519253645" ID="ID_1316230973" MODIFIED="1522519267958" TEXT="aber eine wirklich wasserdichte, genersche Lösung ist komplex bis unmöglich"/>
|
|
<node CREATED="1522519269002" ID="ID_1313794115" MODIFIED="1522519283292" TEXT="und statt einer halb-wasserdichten Lösung könnte man ja einfache Statics verwenden"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1522519308709" ID="ID_1997666438" MODIFIED="1522547255792" TEXT="Beschluß">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1522547261520" ID="ID_539336828" MODIFIED="1522547285145" TEXT="das ist insgesamt eine schlechte Idee">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1522547285877" ID="ID_1921668956" MODIFIED="1525124102526">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Statische Initialisierung funktioniert <b>präzise</b>, korrekt und <b>zuverlässig</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#9e9bae" DESTINATION="ID_1126260262" ENDARROW="Default" ENDINCLINATION="-1485;213;" ID="Arrow_ID_1269745634" STARTARROW="None" STARTINCLINATION="-1534;0;"/>
|
|
</node>
|
|
<node CREATED="1522547330726" ID="ID_994306275" MODIFIED="1522547749968" TEXT="C++ stellt das eigens sicher -- man muß es nur erst mal verstehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der Aufruf von Konstrukturen statischer Objekte konstituiert eine (dynamische) Reihenfolge.
|
|
</p>
|
|
<p>
|
|
Desktuktoren werden exakt rückwärts in dieser Reihenfolge aufgerufen.
|
|
</p>
|
|
<p>
|
|
Statische Objektfelder werden vor der ersten Verwendung der Klassen<b>definition</b>  initialisiert
|
|
</p>
|
|
<p>
|
|
Dagegen Funktions-lokale statische Variablen werden initialisiert, wenn der Kontrollfluß sie zum ersten mal berührt.
|
|
</p>
|
|
<p>
|
|
Wenn ein Konstruktor ein statisches Feld verwendet, dann wird dieses Feld vor dem Konstruktor erzeugt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Beachte: in jedem dieser Fälle wird auch die o.g. Reihenfolge konstituiert.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<u>Corollar</u>: wenn man ein Meyer's Singleton erst indirekt aus dem Implementierungs-Code verwendet,
|
|
</p>
|
|
<p>
|
|
so wird es garantiert zerstört, <i>bevor</i> der Destruktor des aufrufenden Objekts läuft.
|
|
</p>
|
|
<p>
|
|
Hallo ClassLock...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1522547752788" ID="ID_1333812920" MODIFIED="1522547762343" TEXT="eine handgeschriebene Lösung kann da nicht besser sein"/>
|
|
<node CREATED="1522547763547" ID="ID_1065493509" MODIFIED="1522547771413" TEXT="und verschiebt nur das Problem nach hinten"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522457113044" ID="ID_1913798256" MODIFIED="1522547725898" TEXT="umzustellen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1522457119491" ID="ID_715588139" MODIFIED="1522547714913" TEXT="ClassLock">
|
|
<linktarget COLOR="#735d7e" DESTINATION="ID_715588139" ENDARROW="Default" ENDINCLINATION="1087;0;" ID="Arrow_ID_1384015103" SOURCE="ID_1951071885" STARTARROW="None" STARTINCLINATION="-84;86;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1522457132025" ID="ID_828796576" MODIFIED="1522547718346" TEXT="Applikation-Objekt?">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522547772617" ID="ID_671236738" MODIFIED="1522556847447" TEXT="besser nur einen Zombie-Check bereitstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482524535575" ID="ID_387248900" MODIFIED="1557498707236" TEXT="Extension-System"/>
|
|
<node CREATED="1482524569705" ID="ID_1815572475" MODIFIED="1557498707236" TEXT="Parametrisierung"/>
|
|
</node>
|
|
<node CREATED="1448314890907" ID="ID_411012156" MODIFIED="1557498707236" POSITION="right" TEXT="Session">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1481688464060" ID="ID_53574817" MODIFIED="1557498707236" TEXT="Architektur">
|
|
<node CREATED="1481688469507" ID="ID_1691953889" MODIFIED="1557498707236" TEXT="Session-Subsystem">
|
|
<node CREATED="1481688478057" ID="ID_1082882066" MODIFIED="1557498707236" TEXT="äquivalent zum ProcDispatcher"/>
|
|
<node CREATED="1481688490000" ID="ID_579694361" MODIFIED="1557498707236" TEXT="koordiniert die Abläufe in Proc"/>
|
|
</node>
|
|
<node CREATED="1481688500943" ID="ID_1821833408" MODIFIED="1557498707236" TEXT="Session ist eine interne Datenstruktur">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1484377665971" HGAP="28" ID="ID_641757454" MODIFIED="1557498707236" TEXT="Logik" VSHIFT="5">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1538939499138" ID="ID_367201519" MODIFIED="1557498707236" TEXT="open Session">
|
|
<node CREATED="1538939507425" ID="ID_389830085" MODIFIED="1557498707236" TEXT="new Session">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1477784813895" ID="ID_1478381189" MODIFIED="1557498707236">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Aufgabe</u>: <i><font color="#821b58" size="4">produce dummy content</font></i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#f9b709" DESTINATION="ID_1478381189" ENDARROW="Default" ENDINCLINATION="-1009;-357;" ID="Arrow_ID_1072548081" SOURCE="ID_635303062" STARTARROW="None" STARTINCLINATION="-87;103;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538939511688" ID="ID_936661226" MODIFIED="1557498707236" TEXT="existing Session"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481688517437" HGAP="24" ID="ID_241232196" MODIFIED="1557498707236" TEXT="Lifecycle" VSHIFT="8">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1481688521532" ID="ID_1825349679" MODIFIED="1557498707236" TEXT="Session startet on demand"/>
|
|
<node CREATED="1481688529539" ID="ID_1972961763" MODIFIED="1557498707236" TEXT="SessionManager ist zuständig"/>
|
|
<node CREATED="1481688544921" ID="ID_1934560784" MODIFIED="1557498707236" TEXT="wenn Session geladen, ist ProcDispatcher freigegeben"/>
|
|
<node CREATED="1481688562830" ID="ID_708961458" MODIFIED="1557498707236" TEXT="SessionSubsystem startet processing loop im ProcDispatcher"/>
|
|
<node CREATED="1481777252497" FOLDED="true" ID="ID_1789585729" MODIFIED="1557498707236" TEXT="Shutdown">
|
|
<linktarget COLOR="#5a97df" DESTINATION="ID_1789585729" ENDARROW="Default" ENDINCLINATION="3225;0;" ID="Arrow_ID_1930701586" SOURCE="ID_1392452935" STARTARROW="None" STARTINCLINATION="2096;-122;"/>
|
|
<node CREATED="1481777297635" ID="ID_483368010" MODIFIED="1557498707236" TEXT="Deadlock-Gefahr">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1481777308978" ID="ID_1380229085" MODIFIED="1557498707236" TEXT="Lebensdauer der Session-Datenstruktur">
|
|
<node CREATED="1481777328479" ID="ID_1668359018" MODIFIED="1557498707236" TEXT="unabhängig vom Session-Subsystem">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1481777343548" ID="ID_354877994" MODIFIED="1557498707236" TEXT="irgendwann post main()"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534025083017" ID="ID_1484082332" MODIFIED="1557498707236" TEXT="weiterlaufende Render-Prozesse">
|
|
<linktarget COLOR="#eb4053" DESTINATION="ID_1484082332" ENDARROW="Default" ENDINCLINATION="568;0;" ID="Arrow_ID_936372806" SOURCE="ID_1126518975" STARTARROW="Default" STARTINCLINATION="291;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481777355747" ID="ID_1804595708" MODIFIED="1557498707236" TEXT="Subsystem->end">
|
|
<node CREATED="1481777368330" ID="ID_1933237483" MODIFIED="1557498707236" TEXT="Halte-Nachricht"/>
|
|
<node COLOR="#338800" CREATED="1481777374801" ID="ID_1844558240" MODIFIED="1557498707236" TEXT="sicherstellen, daß Loop anhält">
|
|
<arrowlink COLOR="#10f1a2" DESTINATION="ID_1748096848" ENDARROW="Default" ENDINCLINATION="-480;-82;" ID="Arrow_ID_506637666" STARTARROW="None" STARTINCLINATION="-200;38;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1483654823454" ID="ID_397283548" MODIFIED="1557498707236" TEXT="shutdown -> requireAction"/>
|
|
<node CREATED="1483654831773" ID="ID_911489519" MODIFIED="1557498707236" TEXT="shutdown-Trigger macht Notify"/>
|
|
<node CREATED="1483654846083" ID="ID_1926442698" MODIFIED="1557498707236" TEXT="Loop-Thread wacht auf"/>
|
|
<node CREATED="1483654853850" ID="ID_934617670" MODIFIED="1557498707236" TEXT="...und fällt aus der Loop heraus"/>
|
|
</node>
|
|
<node CREATED="1481777397542" ID="ID_1147135932" MODIFIED="1557498707236" TEXT="DispatcherLoop stirbt"/>
|
|
<node CREATED="1481777410972" ID="ID_457965735" MODIFIED="1557498707236" TEXT="sigTerm"/>
|
|
<node CREATED="1483927907096" ID="ID_1366384241" MODIFIED="1557498707236" TEXT="destruktor setzt auch PImpl auf NULL">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1483927920718" ID="ID_409709261" MODIFIED="1557498707236" TEXT="niemand sonst faßt den PImpl an"/>
|
|
<node CREATED="1483927929773" ID="ID_1082393310" MODIFIED="1557498707237" TEXT="atomar wg. Lock auf ProcDispatcher"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533401481917" HGAP="31" ID="ID_1634540822" MODIFIED="1557498707237" TEXT="Struktur" VSHIFT="-19">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1533918273704" ID="ID_1490841818" MODIFIED="1557498707237" TEXT="Modell">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1533918279368" FOLDED="true" ID="ID_90099848" MODIFIED="1557498707237" TEXT="Assets">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1533918370708" ID="ID_1044798440" MODIFIED="1557498707237" TEXT="Arten">
|
|
<node CREATED="1533918396480" ID="ID_1371207426" MODIFIED="1557498707237" TEXT="Media"/>
|
|
<node CREATED="1533918387145" ID="ID_421009475" MODIFIED="1557498707237" TEXT="Proc"/>
|
|
<node CREATED="1533918391201" ID="ID_1099238975" MODIFIED="1557498707237" TEXT="Struct"/>
|
|
<node CREATED="1533918403071" ID="ID_277977903" MODIFIED="1557498707237" TEXT="Meta"/>
|
|
</node>
|
|
<node CREATED="1533918425908" ID="ID_1069430929" MODIFIED="1557498707237" TEXT="Einordnung">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534001954612" ID="ID_1527156035" MODIFIED="1557498707237" TEXT="Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534001984536" ID="ID_1186986383" MODIFIED="1557498707237" TEXT="#1156 clarify distinction between asset::Struct and asset::Meta">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534002074828" ID="ID_867232883" MODIFIED="1557498707237" TEXT="Asymetrie in asset::Category">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1534002102456" ID="ID_101543995" MODIFIED="1557498707237" TEXT="benutzer-orientiert"/>
|
|
<node CREATED="1534002106999" ID="ID_354946108" MODIFIED="1557498707237" TEXT="GUI ist aber noch nicht gebaut"/>
|
|
<node CREATED="1534002113086" ID="ID_1894075831" MODIFIED="1576282357965" TEXT="Audio und Video werden eigens unterschieden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...obwohl die betreffenden Assets in die Kategorie "Medien" fallen,
|
|
</p>
|
|
<p>
|
|
und wir einen eigenen StreamType definieren wollen, also explizit die Art der Medien offen lassen.
|
|
</p>
|
|
<p>
|
|
Ganz prominent fehlt hier also z.B: MIDI
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1534002180893" ID="ID_1074039128" MODIFIED="1557498707237" TEXT="dafür erscheint die Unterscheidung STRUCT vs. META schwammig"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1534002037961" ID="ID_95419141" MODIFIED="1557498707237" TEXT="Erzeugung und Lebenszyklus">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1534002202098" ID="ID_1411648485" MODIFIED="1557498707237" TEXT="diese Auto-Regisierung"/>
|
|
<node CREATED="1534002225888" ID="ID_138566211" MODIFIED="1576282357965" TEXT="smart-Ptr als Handle nicht immer sinnvoll">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nämlich genau <i>nicht</i> für alle Assets,
|
|
</p>
|
|
<p>
|
|
die Aufgrund von Klassifikationen automatisch bereits existieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1534024950739" ID="ID_1395279965" MODIFIED="1557498707237" TEXT="Races und mögliche Kollisionen überall">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1534025017601" ID="ID_1126518975" MODIFIED="1557498707237" TEXT="Zusammenhang mit dem Session-Lebenszyklus">
|
|
<arrowlink COLOR="#eb4053" DESTINATION="ID_1484082332" ENDARROW="Default" ENDINCLINATION="568;0;" ID="Arrow_ID_936372806" STARTARROW="Default" STARTINCLINATION="291;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533918431595" ID="ID_1121251191" MODIFIED="1561827466181" TEXT="ErrorLog(Asset)">
|
|
<linktarget COLOR="#68788a" DESTINATION="ID_1121251191" ENDARROW="Default" ENDINCLINATION="-1644;0;" ID="Arrow_ID_146013003" SOURCE="ID_1117749960" STARTARROW="None" STARTINCLINATION="-4766;280;"/>
|
|
<node CREATED="1533997520937" ID="ID_130549036" MODIFIED="1533997523524" TEXT="Typ">
|
|
<node CREATED="1533918806369" ID="ID_1198682609" MODIFIED="1533918809694" TEXT="Media">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1533918810848" ID="ID_29240989" MODIFIED="1533918815271" TEXT="Struct">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1533918821511" ID="ID_1150910919" MODIFIED="1533997535081" TEXT="Meta">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1533919635505" ID="ID_353835069" MODIFIED="1533919642476" TEXT="paßt soweit schon"/>
|
|
<node CREATED="1533920004719" ID="ID_402802807" MODIFIED="1576282357964" TEXT="was heißt hier "immutable"?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Meta-Assets sind per Definition <i>"immutable"</i><br />Es gibt einen Builder
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533994326945" ID="ID_1821159631" MODIFIED="1533994327255" TEXT="Eigenschaften des Log"/>
|
|
<node CREATED="1533994327584" ID="ID_780339362" MODIFIED="1533994784549" TEXT="Filter, Persistenz, Warnschwellen, Weiterleitung"/>
|
|
<node CREATED="1533994328152" ID="ID_538198315" MODIFIED="1533994328390" TEXT="können bei bestehendem Log nicht geändert werden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533997546077" ID="ID_1270326369" MODIFIED="1533997549209" TEXT="Rolle">
|
|
<node CREATED="1533997550413" ID="ID_1832028422" MODIFIED="1533997561821">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>das</i> ErrorLog
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533997846989" ID="ID_1324960272" MODIFIED="1533997854911" TEXT="zunächst nur Platzhalter">
|
|
<node CREATED="1533997938232" ID="ID_40537012" MODIFIED="1576282357964" TEXT="brauche EntryID<ErrorLog>">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....weil hier ein allgemeines Schema entsteht:
|
|
</p>
|
|
<p>
|
|
jede Aktion, die in das UI "reflektiert" wird, erfolgt, indem man eine Nachricht
|
|
</p>
|
|
<p>
|
|
über den UI-Bus schickt, an einen Empfänger mit bekannter ID.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533997855707" ID="ID_663263517" MODIFIED="1533997862414" TEXT="nomineller Empfänger"/>
|
|
<node CREATED="1533997863858" ID="ID_680229716" MODIFIED="1533997880164" TEXT="entspricht dem UI">
|
|
<node CREATED="1533997895182" ID="ID_1179742637" MODIFIED="1533997924871">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dort gibt es eine <b>ErrorLogView</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533997901765" ID="ID_361019548" MODIFIED="1576202124808">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und den Controller: <b>NotificationHub</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#a9aac1" DESTINATION="ID_70134302" ENDARROW="Default" ENDINCLINATION="-1984;0;" ID="Arrow_ID_1885125683" STARTARROW="None" STARTINCLINATION="807;-66;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533997881703" ID="ID_405103584" MODIFIED="1533997890166" TEXT="Persistenz">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533997570242" ID="ID_503070656" MODIFIED="1533997575269" TEXT="spezielle Detail-Logs">
|
|
<node CREATED="1534002311748" ID="ID_440257353" MODIFIED="1534002317208" TEXT="geplant/Idee">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533997581280" ID="ID_398592361" MODIFIED="1533997591029" TEXT="Idee: Verallgemeinerung auf Logs">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1533997595735" ID="ID_459951978" MODIFIED="1576282357963" TEXT="selbstreferentielle Struktur">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist diese Idee, daß eine Struktur sich selbst meta-repräsentiert;
|
|
</p>
|
|
<p>
|
|
dadurch werden Meta-Operationen auf gleiche Ebene gestellt wie normale Struktur-Manipulationen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533997603741" ID="ID_1980534712" MODIFIED="1576282357963" TEXT="die Command und Event-Logs könnten repräsentiert sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dadruch würden History-Operationen wie
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
undo
|
|
</li>
|
|
<li>
|
|
redo
|
|
</li>
|
|
<li>
|
|
repeat command
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
...zu ganz normalen Manipulationen der Session, würden ihrerseits geloggt und historisiert
|
|
</p>
|
|
<p>
|
|
und verlieren ihren <i>magischen Charakter</i> außerhalb der Event-Sourcing-Struktur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533918281880" ID="ID_1584868520" MODIFIED="1557498707237" TEXT="MObject"/>
|
|
</node>
|
|
<node CREATED="1674160453319" ID="ID_1069058254" MODIFIED="1674160457633" TEXT="Fragen der Anordnung">
|
|
<node CREATED="1674160465628" ID="ID_1715063705" MODIFIED="1674160468831" TEXT="Konventionen"/>
|
|
<node CREATED="1674160469453" ID="ID_299990959" MODIFIED="1674160474856" TEXT="möglicher Spielraum">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1674160530502" ID="ID_949776360" MODIFIED="1674160554933" TEXT="Thema: Content auf nested-Tracks">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1674160565696" ID="ID_915488068" MODIFIED="1674160570917" TEXT="typische Erwartung">
|
|
<node CREATED="1674160572143" ID="ID_846540731" MODIFIED="1674160579754" TEXT="Content ist nur auf Leaf-Tracks"/>
|
|
<node CREATED="1674160581694" ID="ID_1996064052" MODIFIED="1674160601189" TEXT="sobald sub-Tracks auftreten, wird Content auf diese nach unten verschoben"/>
|
|
<node CREATED="1674160613610" ID="ID_1409730860" MODIFIED="1674161308527">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
1/2023: unklar — <i>wer macht das?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#8a4d65" DESTINATION="ID_1828648487" ENDARROW="Default" ENDINCLINATION="-2734;159;" ID="Arrow_ID_502951484" STARTARROW="None" STARTINCLINATION="-1113;-73;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1674160475478" ID="ID_1934740344" MODIFIED="1674160478839" TEXT="Wechselwirkungen">
|
|
<node CREATED="1674160479667" ID="ID_1846459378" MODIFIED="1674160484151" TEXT="mit UI-Mechanik">
|
|
<node CREATED="1674160486844" ID="ID_73340930" LINK="#ID_1440303749" MODIFIED="1674160516391" TEXT="Expand / Collapse"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1533401497075" FOLDED="true" ID="ID_598742497" MODIFIED="1557498707237" TEXT="Struktur-Änderungen">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401543765" ID="ID_1439915831" MODIFIED="1557498707237" TEXT="erkennen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1533401549900" ID="ID_98267055" MODIFIED="1557498707237" TEXT="Builder?"/>
|
|
</node>
|
|
<node CREATED="1533401523656" ID="ID_1710492737" MODIFIED="1557498707237" TEXT="Diff-Generierung">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401384155" ID="ID_1106740084" MODIFIED="1557498707237" TEXT="#1153 define foundation for live diff updates Session -> UI">
|
|
<linktarget COLOR="#a47f9a" DESTINATION="ID_1106740084" ENDARROW="Default" ENDINCLINATION="2561;-1079;" ID="Arrow_ID_1276188897" SOURCE="ID_1494781570" STARTARROW="None" STARTINCLINATION="1703;327;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401567737" ID="ID_464225987" MODIFIED="1557498707237" TEXT="populationDiff">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401584887" ID="ID_181123777" MODIFIED="1557498707237" TEXT="aktuellen Zustand reflektieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533401596470" ID="ID_1892595651" MODIFIED="1557498707237" TEXT="vorläufig: hart gecodet">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539270417847" ID="ID_1555798999" MODIFIED="1576203555715" TEXT="korrekte Diff-Struktur">
|
|
<linktarget COLOR="#cbada9" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="1135;-119;" ID="Arrow_ID_46239762" SOURCE="ID_1136748343" STARTARROW="None" STARTINCLINATION="-408;50;"/>
|
|
<linktarget COLOR="#d47366" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="713;-263;" ID="Arrow_ID_971172326" SOURCE="ID_1387553695" STARTARROW="None" STARTINCLINATION="-1999;120;"/>
|
|
<linktarget COLOR="#d47366" DESTINATION="ID_1555798999" ENDARROW="Default" ENDINCLINATION="590;-127;" ID="Arrow_ID_308349501" SOURCE="ID_1435731309" STARTARROW="None" STARTINCLINATION="915;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1539270427702" ID="ID_1895500225" MODIFIED="1557498707237" TEXT="der Diff muß gewisse Regeln einhalten"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1539270457106" ID="ID_1865797145" MODIFIED="1557498707237" TEXT="diese sind implizit und lokal">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1539382866228" ID="ID_961794575" MODIFIED="1557498707237" TEXT="Timeline">
|
|
<node CREATED="1539386837229" ID="ID_563098407" MODIFIED="1557498707237" TEXT="sofort bei Population...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539382950953" ID="ID_150037135" MODIFIED="1557498707237" TEXT="ID + Record"/>
|
|
<node CREATED="1539382957680" ID="ID_1525067830" MODIFIED="1557498707237" TEXT="Attribut ATTR_fork -> ID + Record"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1539388046730" ID="ID_1028444200" MODIFIED="1557498707237" TEXT="Entscheidung: besser so">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1539388094636" ID="ID_545613641" MODIFIED="1557498707237" TEXT="Alternative wäre...">
|
|
<node CREATED="1539388104018" ID="ID_1338813705" MODIFIED="1557498707237" TEXT="erst mal BOTTOM- Track-ID verwenden"/>
|
|
<node CREATED="1539388120696" ID="ID_532223861" MODIFIED="1557498707237" TEXT="dann Track-Attibut zuweisen"/>
|
|
<node CREATED="1539388127375" ID="ID_91044288" MODIFIED="1557498707237" TEXT="ggfs schon bestehende Objekte werkegeln"/>
|
|
<node CREATED="1539388139030" ID="ID_1167639326" MODIFIED="1557498707237" TEXT="würde funkionieren, aber...">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539388158555" ID="ID_1745880313" MODIFIED="1557498707237" TEXT="besser geleich Exception werfen">
|
|
<arrowlink COLOR="#ea3f19" DESTINATION="ID_946219609" ENDARROW="Default" ENDINCLINATION="305;-104;" ID="Arrow_ID_22622466" STARTARROW="None" STARTINCLINATION="-367;13;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541547600640" HGAP="79" ID="ID_659707505" MODIFIED="1560172942629" TEXT="Element-IDs müssen eindeutig sein" VSHIFT="10">
|
|
<arrowlink COLOR="#c9876a" DESTINATION="ID_1850412206" ENDARROW="Default" ENDINCLINATION="369;179;" ID="Arrow_ID_1229280605" STARTARROW="None" STARTINCLINATION="586;-203;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1541547743885" ID="ID_1112550435" MODIFIED="1557498707237" TEXT="wegen UI-Bus-Routing"/>
|
|
<node CREATED="1541547751020" ID="ID_566590492" MODIFIED="1557498707237" TEXT="Aber: Attribute werden lokal erzeugt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1539270417847" ID="ID_946219609" MODIFIED="1557498707237" TEXT="Reaktion auf Diff-Fehler">
|
|
<linktarget COLOR="#d47366" DESTINATION="ID_946219609" ENDARROW="Default" ENDINCLINATION="713;-263;" ID="Arrow_ID_1085344706" SOURCE="ID_19523487" STARTARROW="Default" STARTINCLINATION="-1999;120;"/>
|
|
<linktarget COLOR="#ea3f19" DESTINATION="ID_946219609" ENDARROW="Default" ENDINCLINATION="305;-104;" ID="Arrow_ID_22622466" SOURCE="ID_1745880313" STARTARROW="None" STARTINCLINATION="-367;13;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1533400671533" HGAP="45" ID="ID_1357977461" MODIFIED="1557498707237" TEXT="Command-Ausführung" VSHIFT="-27">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1533400693522" ID="ID_217032156" MODIFIED="1557498707237" TEXT="Commands sollen geloggt werden">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1533400707072" ID="ID_1192893155" MODIFIED="1557498707237" TEXT="#211 handling pattern for dispatch">
|
|
<linktarget COLOR="#ca91c2" DESTINATION="ID_1192893155" ENDARROW="Default" ENDINCLINATION="1415;0;" ID="Arrow_ID_207842771" SOURCE="ID_1072134705" STARTARROW="None" STARTINCLINATION="2581;0;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node CREATED="1533400727749" ID="ID_345730150" MODIFIED="1557498707237" TEXT="wartet auf Storage-Backend-Entscheidung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533400742979" HGAP="21" ID="ID_748308949" MODIFIED="1557498707237" TEXT="vorläufiger Hack" VSHIFT="15">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1533400757737" ID="ID_1656760024" MODIFIED="1557498707237" TEXT="Präfix "test" vor CommandID">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1533400770320" ID="ID_1945470515" MODIFIED="1557498707237" TEXT="solche Commands werden vom Dispatcher direkt ausgeführt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481778538165" FOLDED="true" HGAP="37" ID="ID_522398894" MODIFIED="1561827466184" TEXT="ProcDispatcher" VSHIFT="12">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481826274018" HGAP="18" ID="ID_1916296972" MODIFIED="1518487921096" TEXT="Requirements" VSHIFT="-7">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481826329819" ID="ID_1238318698" MODIFIED="1518487921096" TEXT="enqueue commands concurrently">
|
|
<node CREATED="1481827297122" ID="ID_860095678" MODIFIED="1518487921096" TEXT="FIFO for regular commands"/>
|
|
<node CREATED="1481827312024" ID="ID_850193431" MODIFIED="1518487921096" TEXT="LIFO for priority requests">
|
|
<node CREATED="1482712100745" ID="ID_1387300775" MODIFIED="1518487921096" TEXT="vorerst nicht implementiert">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481826431861" ID="ID_328583048" MODIFIED="1518487921096" TEXT="process sequentially"/>
|
|
<node CREATED="1481826441884" ID="ID_952327020" MODIFIED="1518487921096" TEXT="until queue is empty"/>
|
|
<node CREATED="1481826997930" ID="ID_576341056" MODIFIED="1518487921096" TEXT="provide a check point">
|
|
<node CREATED="1481827040748" ID="ID_406205627" MODIFIED="1518487921096" TEXT="when">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1481827019615" ID="ID_1169845292" MODIFIED="1518487921096" TEXT="after each command"/>
|
|
<node CREATED="1481827024942" ID="ID_137101226" MODIFIED="1518487921096" TEXT="after each builder run"/>
|
|
</node>
|
|
<node CREATED="1481827051787" ID="ID_1911969568" MODIFIED="1518487921096" TEXT="why">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1483747048432" ID="ID_1165337571" MODIFIED="1518487921096" TEXT="to ensure sane state logic"/>
|
|
<node CREATED="1483747065326" ID="ID_896973402" MODIFIED="1576282357962" TEXT="allow to wait for disabled state">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...necessary when closing the session;
|
|
</p>
|
|
<p>
|
|
we need to wait for the current command or builder run to be completed
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481827548073" ID="ID_690689259" MODIFIED="1576282357962" TEXT="manage entries">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...noch nicht implementiert 1/17
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1481827558336" ID="ID_1026688096" MODIFIED="1518487921096" TEXT="match current session"/>
|
|
<node CREATED="1481827647491" ID="ID_1849886325" MODIFIED="1518487921096" TEXT="aggregate similar"/>
|
|
<node CREATED="1481827652539" ID="ID_313823253" MODIFIED="1518487921096" TEXT="supersede"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481917572639" FOLDED="true" HGAP="74" ID="ID_190109346" MODIFIED="1561827466189" TEXT="operational..." VSHIFT="-27">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1481917612602" ID="ID_567971228" MODIFIED="1518487921096" TEXT="Loop läuft stets, aber blockt ggfs"/>
|
|
<node CREATED="1481917641910" ID="ID_1157396234" MODIFIED="1518487921096" TEXT="anfänglich idle --> schlafen"/>
|
|
<node CREATED="1481918441020" ID="ID_584625018" MODIFIED="1518487921096" TEXT="Command-Queue wird ohne Verzögerung abgearbeitet"/>
|
|
<node CREATED="1481918465680" ID="ID_973127249" MODIFIED="1518487921096" TEXT="Builder startet">
|
|
<node CREATED="1481918475295" ID="ID_1997533333" MODIFIED="1518487921096" TEXT="nach kurzer Idle-Periode"/>
|
|
<node CREATED="1481918481102" ID="ID_335740959" MODIFIED="1518487921096" TEXT="nach längerer Command-Abarbeitung"/>
|
|
</node>
|
|
<node CREATED="1481917691047" ID="ID_714937554" MODIFIED="1518487921096" TEXT="Änderung der Umstände">
|
|
<node CREATED="1481917700998" ID="ID_470084004" MODIFIED="1518487921096" TEXT="kommt stets über Interface"/>
|
|
<node CREATED="1481917726683" ID="ID_962119246" MODIFIED="1518487921096" TEXT="weckt den Loop-Thread auf"/>
|
|
<node CREATED="1481917766837" ID="ID_1794908304" MODIFIED="1576282357961" TEXT="ist atomar (locking)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Guard beim Zugang über das Interface
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1481918074269" ID="ID_1984339005" MODIFIED="1518487921097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>nur sie</i> ist atomar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481918117831" ID="ID_924462902" MODIFIED="1518487921097" TEXT="asynchron">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1481918130245" ID="ID_1624017067" MODIFIED="1518487921097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>nur ein Thread</b> für Commands und Builder
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#171ccb" DESTINATION="ID_1214851922" ENDARROW="Default" ENDINCLINATION="53;-5;" ID="Arrow_ID_1745317422" STARTARROW="None" STARTINCLINATION="42;2;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1481918174199" ID="ID_364234189" MODIFIED="1518487921097" TEXT="essentiell für Konsitenz der Session"/>
|
|
<node CREATED="1481918181254" ID="ID_1313994065" MODIFIED="1518487921097" TEXT="stellt bereits sicher, daß der Builder blockt"/>
|
|
</node>
|
|
<node CREATED="1481918194356" ID="ID_1233041580" MODIFIED="1518487921097" TEXT="einfügen neuer Commands"/>
|
|
<node CREATED="1481918273490" ID="ID_1214851922" MODIFIED="1518487921097" TEXT="nächstes Command starten">
|
|
<arrowlink COLOR="#010de6" DESTINATION="ID_1857790160" ENDARROW="Default" ENDINCLINATION="86;0;" ID="Arrow_ID_1735750125" STARTARROW="Default" STARTINCLINATION="127;3;"/>
|
|
<linktarget COLOR="#171ccb" DESTINATION="ID_1214851922" ENDARROW="Default" ENDINCLINATION="53;-5;" ID="Arrow_ID_1745317422" SOURCE="ID_1624017067" STARTARROW="None" STARTINCLINATION="42;2;"/>
|
|
</node>
|
|
<node CREATED="1481918291351" ID="ID_1857790160" MODIFIED="1518487921097" TEXT="Builder-Lauf initiieren">
|
|
<linktarget COLOR="#010de6" DESTINATION="ID_1857790160" ENDARROW="Default" ENDINCLINATION="86;0;" ID="Arrow_ID_1735750125" SOURCE="ID_1214851922" STARTARROW="Default" STARTINCLINATION="127;3;"/>
|
|
</node>
|
|
<node CREATED="1481918212722" ID="ID_1376599707" MODIFIED="1518487921097" TEXT="Shutdown-Triggger"/>
|
|
<node CREATED="1481918222577" ID="ID_1588368762" MODIFIED="1518487921097" TEXT="Sperre setzen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481918517018" HGAP="11" ID="ID_916331172" MODIFIED="1518487921097" TEXT="Sperre" VSHIFT="8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481918524673" ID="ID_1705856370" MODIFIED="1518487921097" TEXT="verhindert Command- und Builder-start">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1481918547182" ID="ID_920627724" MODIFIED="1518487921097" TEXT="bestehende Commands / Builder-Läufe werden noch abgeschlossen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481920722100" ID="ID_1378897740" MODIFIED="1531584182083" TEXT="SessionManager muß auf Sperre warten">
|
|
<linktarget COLOR="#5a97df" DESTINATION="ID_1378897740" ENDARROW="Default" ENDINCLINATION="2126;95;" ID="Arrow_ID_1446486242" SOURCE="ID_284397306" STARTARROW="None" STARTINCLINATION="2592;-81;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481926040310" ID="ID_667460598" MODIFIED="1518487921097" TEXT="Deadlock wenn der Session-Thread selber auf diese Sperre wartet">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1482197251133" ID="ID_1245878337" MODIFIED="1518487921097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ticket <font color="#e90426">#1054</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482197270202" ID="ID_221875120" MODIFIED="1518487921097" TEXT="neues API auf unserem Thread-Wrapper schaffen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1482197280297" ID="ID_1142010083" MODIFIED="1518487921097" TEXT="rein technisch bereits heute möglich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482197292263" ID="ID_669497196" MODIFIED="1576282357960" TEXT="jeder Lumiera-Thread speichert "self" in thread local storage">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und "self" == LumieraThrea* == "handle" (im Wrapper).
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
D.h. solange der Wrapper lebt (!), kann er selber leicht feststellen, ob die aktuelle Ausführung
|
|
</p>
|
|
<p>
|
|
auch in einem Thread stattfindet, der
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
von unserem Threadpool gestartet wurde
|
|
</li>
|
|
<li>
|
|
ein Thread-Handle hat, das mit dem Handle dieses Wrappers identisch ist.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Das Schöne bei diesem Ansatz ist, daß man dafür weder das Handle exponieren muß,
|
|
</p>
|
|
<p>
|
|
noch irgendwelche komischen Policies aufmachen. Solange es das Objekt gibt, klappt das.
|
|
</p>
|
|
<p>
|
|
OO rocks!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481828583551" HGAP="148" ID="ID_436508747" MODIFIED="1518487921097" TEXT="Aufbau" VSHIFT="-35">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481828611347" ID="ID_160907866" MODIFIED="1518487921097" TEXT="Front-End"/>
|
|
<node CREATED="1481828614827" ID="ID_1752707995" MODIFIED="1518487921097" TEXT="DispatcherLoop PImpl"/>
|
|
<node CREATED="1481828624042" ID="ID_1970372601" MODIFIED="1518487921097" TEXT="Looper für Schleifen-Logik"/>
|
|
<node CREATED="1481828639584" ID="ID_1344182776" MODIFIED="1518487921097" TEXT="CommandQueue"/>
|
|
</node>
|
|
<node CREATED="1481778549940" FOLDED="true" HGAP="50" ID="ID_676848252" MODIFIED="1561827466194" TEXT="DispatcherLoop" VSHIFT="1">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481778741546" ID="ID_684867533" MODIFIED="1518487921097" TEXT="öffnet Session-Interface">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481778565298" ID="ID_1803510423" MODIFIED="1518487921097" TEXT="Schleifen-Logik">
|
|
<node CREATED="1481778570153" ID="ID_6904207" MODIFIED="1518487921097" TEXT="beruht auf CondVar / wait"/>
|
|
<node CREATED="1481831352239" ID="ID_947882756" MODIFIED="1518487921097" TEXT="Looper-Hilfskomponente"/>
|
|
<node CREATED="1481831372092" ID="ID_411828431" MODIFIED="1518487921097" TEXT="muß...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1481831398297" ID="ID_1100709659" MODIFIED="1518487921097" TEXT="aufwachen wenn Commands anstehen"/>
|
|
<node CREATED="1481831722406" ID="ID_462123533" MODIFIED="1518487921097" TEXT="aufwachen wenn Checkpoint"/>
|
|
<node CREATED="1481831408415" ID="ID_1091888781" MODIFIED="1518487921097" TEXT="aufwachen bei Shutdown"/>
|
|
<node CREATED="1481831432220" ID="ID_1256743195" MODIFIED="1518487921097" TEXT="Shutdown-Flag verwalten"/>
|
|
<node CREATED="1481831886448" ID="ID_1022163658" MODIFIED="1518487921097" TEXT="Betriebszustand">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1481831945472" ID="ID_756400184" MODIFIED="1518487921097" TEXT="arbeitend"/>
|
|
<node CREATED="1481831948240" ID="ID_349500680" MODIFIED="1518487921097" TEXT="Leerlauf"/>
|
|
<node CREATED="1481831950160" ID="ID_602481733" MODIFIED="1518487921097" TEXT="gesperrt"/>
|
|
<node CREATED="1481831965253" ID="ID_1644273707" MODIFIED="1518487921097" TEXT="sterbend"/>
|
|
</node>
|
|
<node CREATED="1481831638089" ID="ID_209292609" MODIFIED="1518487921097" TEXT="Builder steuern">
|
|
<arrowlink COLOR="#5242a4" DESTINATION="ID_1311208726" ENDARROW="Default" ENDINCLINATION="2;-45;" ID="Arrow_ID_313252247" STARTARROW="None" STARTINCLINATION="-186;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481831642376" ID="ID_1301681872" MODIFIED="1518487921097" TEXT="Checkpoint bieten">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482365008444" ID="ID_1520027430" MODIFIED="1518487921097" TEXT="warum">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1482365012947" ID="ID_10844185" MODIFIED="1518487921097" TEXT="um zuverlässig anhalten zu können"/>
|
|
<node CREATED="1482712199900" ID="ID_1990071363" MODIFIED="1518487921097" TEXT="Checkpoint == Zustand ausgeglichen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482712212930" ID="ID_1065088226" MODIFIED="1518487921097" TEXT="das heißt">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1482712227048" ID="ID_172281578" MODIFIED="1518487921097" TEXT="keine schwebenden Zustandsänderungen"/>
|
|
<node CREATED="1482712235016" ID="ID_943771142" MODIFIED="1518487921097" TEXT="Alle zustands-Relevanten Änderungen sind ausgewertet"/>
|
|
<node CREATED="1482712250461" ID="ID_610930154" MODIFIED="1518487921097" TEXT="alle Prädikate spiegeln den wirklichen Zustand wider"/>
|
|
<node CREATED="1482712261876" ID="ID_47966817" MODIFIED="1518487921097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Kontrollfluß ist <i>nicht</i> in einer Arbeitsfunktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481831747042" ID="ID_134003952" MODIFIED="1576282357960" TEXT="sperrbar sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und dann nur noch
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
auf Shutdown reagieren
|
|
</li>
|
|
<li>
|
|
mitbekommen wenn die Sperre aufgehoben wird
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1481778590790" ID="ID_1748096848" MODIFIED="1538871175327" TEXT="Anhalten">
|
|
<linktarget COLOR="#10f1a2" DESTINATION="ID_1748096848" ENDARROW="Default" ENDINCLINATION="-480;-82;" ID="Arrow_ID_506637666" SOURCE="ID_1844558240" STARTARROW="None" STARTINCLINATION="-200;38;"/>
|
|
<node CREATED="1481778666820" ID="ID_1860590145" MODIFIED="1518487921097" TEXT="Trigger-Variable im Looper">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1481917462421" ID="ID_200909201" MODIFIED="1518487921097" TEXT="shutdown-Trigger ebenda">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1481917478412" ID="ID_594556769" MODIFIED="1518487921097" TEXT="kombiniert enabled und shutdown">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481778708207" FOLDED="true" HGAP="50" ID="ID_1311208726" MODIFIED="1561827466199" TEXT="Builder-Steuerung">
|
|
<linktarget COLOR="#5242a4" DESTINATION="ID_1311208726" ENDARROW="Default" ENDINCLINATION="2;-45;" ID="Arrow_ID_313252247" SOURCE="ID_209292609" STARTARROW="None" STARTINCLINATION="-186;-13;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481828478741" ID="ID_1706868067" MODIFIED="1518487921097" TEXT="Hysterese"/>
|
|
<node CREATED="1481828498618" ID="ID_321199314" MODIFIED="1518487921097" TEXT="nach neuem Command, mit kleiner Verzögerung"/>
|
|
<node CREATED="1481828520176" ID="ID_239973202" MODIFIED="1518487921097" TEXT="bei voller Schlange mit Toleranzschwelle"/>
|
|
<node CREATED="1481828568129" ID="ID_295162940" MODIFIED="1518487921097" TEXT="Builder-Lauf ist monolithisch"/>
|
|
<node CREATED="1481928858318" ID="ID_1695005029" MODIFIED="1518487921097" TEXT="verdecken...">
|
|
<node CREATED="1481928864549" ID="ID_515765693" MODIFIED="1518487921097" TEXT="wenn gesperrt"/>
|
|
<node CREATED="1481928867893" ID="ID_1200076817" MODIFIED="1518487921097" TEXT="wenn in Shutdown"/>
|
|
</node>
|
|
<node CREATED="1481928874500" ID="ID_73724471" MODIFIED="1518487921097" TEXT="idle-timeout">
|
|
<node CREATED="1481928882723" ID="ID_770033134" MODIFIED="1518487921097" TEXT="dynamisch steuern">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481928888035" ID="ID_927205346" MODIFIED="1518487921097" TEXT="kurz, wenn der Builder laufen muß">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481928913687" ID="ID_696704157" MODIFIED="1518487921097" TEXT="lang sonst">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1481928939300" ID="ID_1625916543" MODIFIED="1518487921097" TEXT="kein Timeout wenn gesperrt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1481928958233" ID="ID_350657817" MODIFIED="1518487921097" TEXT="Builder-Lauf erzwingen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1481928966167" ID="ID_1511723472" MODIFIED="1518487921097" TEXT="wenn lange Timeout-Spanne überschritten"/>
|
|
<node CREATED="1481928978223" ID="ID_106761868" MODIFIED="1518487921097" TEXT="Implementierung erfordert Zeitmessung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1482365133332" ID="ID_99275973" MODIFIED="1518487921097" TEXT="moderne / zeitgemäße Implementierung">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1482365613228" ID="ID_1195899391" MODIFIED="1518487921097">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>billig:</i> unsere Zeit-Lib nutzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482430715396" ID="ID_1005651794" MODIFIED="1518487921098" TEXT="nicht besonders schön">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1482430724019" ID="ID_880234680" MODIFIED="1518487921098" TEXT="sollte mit std::chrono integrieren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482202066204" HGAP="23" ID="ID_41541843" MODIFIED="1518487921098" TEXT="Lösungnsansatz" VSHIFT="16">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1482202080675" ID="ID_12774028" MODIFIED="1518487921098" TEXT="CommandQueue muß helfen und dirty-state verwalten">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1482202099752" ID="ID_434677221" MODIFIED="1518487921098" TEXT="geht, weil sie weiß, wann ein Command wirklich läuft"/>
|
|
<node CREATED="1482202114630" ID="ID_1833945556" MODIFIED="1518487921098" TEXT="unschön, weil wir nun massive Kopplung haben"/>
|
|
</node>
|
|
<node CREATED="1482202127252" ID="ID_1720469294" MODIFIED="1518487921098" TEXT="Looper in State-machine verwandeln">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482202136235" ID="ID_239151488" MODIFIED="1518487921098" TEXT="schwierig">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1482202142818" ID="ID_1412852448" MODIFIED="1518487921098" TEXT="benötigt Hilfe von der DispatcherLoop">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1482202156416" ID="ID_1161547825" MODIFIED="1518487921098" TEXT="geht aber: nach jedem WHILE-Durchlauf">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482202165423" ID="ID_1845799711" MODIFIED="1518487921098" TEXT="schaut sauberer aus">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1482202187620" ID="ID_259250017" MODIFIED="1518487921098" TEXT="geht das überhaupt">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1482375716922" ID="ID_1702615812" MODIFIED="1518487921098" TEXT="ja">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
<node CREATED="1482375724321" ID="ID_218202011" MODIFIED="1518487921098" TEXT="einfacher trap-door-Mechanismus">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1482375737327" ID="ID_1980564250" MODIFIED="1518487921098" TEXT="tendentiell bereits schwer zu verstehen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1482202207242" ID="ID_1287224856" MODIFIED="1518487921098" TEXT="Test">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1482202211049" ID="ID_1159832087" MODIFIED="1518487921098" TEXT="komplexen Ablauf als Szenario durchspielen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1482375826635" ID="ID_1275445978" MODIFIED="1518487921098" TEXT="beinhaltet auch einen Timeout">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1482202223536" ID="ID_374030732" MODIFIED="1518487921098">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Logik im Looper auf Basis
|
|
</p>
|
|
<p>
|
|
generischer Überlegungen implementiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1482202243253" ID="ID_1342399342" MODIFIED="1518487921098" TEXT="verhält er sich dann richtig">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1533401628689" HGAP="7" ID="ID_36032481" MODIFIED="1557498707237" TEXT="Builder" VSHIFT="9">
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#435e98" CREATED="1533401646479" ID="ID_305001887" MODIFIED="1557498707237" TEXT="das große wartende MEGA-Integrations-Thema">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1680563617807" ID="ID_1592313170" MODIFIED="1680563626215" TEXT="vorläufig...">
|
|
<node CREATED="1680563627851" ID="ID_804147257" MODIFIED="1680563627851" TEXT="Fake-build: einfacher Clip">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_804147257" ENDARROW="Default" ENDINCLINATION="-696;77;" ID="Arrow_ID_521000760" SOURCE="ID_573821275" STARTARROW="None" STARTINCLINATION="-206;21;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1448314932726" ID="ID_669869188" MODIFIED="1557498707237" POSITION="right" TEXT="Render">
|
|
<icon BUILTIN="stop"/>
|
|
<node CREATED="1512923568305" ID="ID_1329323311" MODIFIED="1557498707237" TEXT="Player">
|
|
<node CREATED="1512923658341" ID="ID_1855109590" MODIFIED="1557498707237" TEXT="Interface">
|
|
<node CREATED="1681597122589" ID="ID_1328094537" MODIFIED="1681597126593" TEXT="Spec">
|
|
<node CREATED="1681597127282" ID="ID_761595186" MODIFIED="1681597130528" TEXT="Timings">
|
|
<node CREATED="1681597133168" ID="ID_1308926052" MODIFIED="1681597148947">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zeitmaß für <i>diesen </i>Wiedergabevorgang
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681597167602" ID="ID_205208976" MODIFIED="1681597182099" TEXT="playbackUrgency = {ASAP,NICE,TIMEBOUND}"/>
|
|
<node CREATED="1681597212993" ID="ID_615732474" MODIFIED="1681597273762" TEXT="scheduledDelivery(nur TIMEBOUND) ≔ »wall clock time« des Grid-Ursprungs"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512923661892" ID="ID_1580804608" MODIFIED="1557498707237" TEXT="Control">
|
|
<node CREATED="1681685173232" ID="ID_1497274477" MODIFIED="1681685179516" TEXT="Play-controller"/>
|
|
<node CREATED="1681685180222" ID="ID_1922002466" MODIFIED="1681685183138" TEXT="Play-Process"/>
|
|
<node CREATED="1681685183696" ID="ID_453528685" MODIFIED="1681685186032" TEXT="CalcStream">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681685187803" ID="ID_1654025761" MODIFIED="1681685196333" TEXT="Umbau 4/23">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681685197444" ID="ID_1313231227" MODIFIED="1681685335962" TEXT="kann man CalcStream move-only machen?">
|
|
<linktarget COLOR="#e0804f" DESTINATION="ID_1313231227" ENDARROW="Default" ENDINCLINATION="2513;164;" ID="Arrow_ID_861540006" SOURCE="ID_439004499" STARTARROW="None" STARTINCLINATION="676;-84;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512923672275" ID="ID_1369059082" MODIFIED="1557498707237" TEXT="Wiring"/>
|
|
<node CREATED="1512923682530" ID="ID_1204903801" MODIFIED="1557498707237" TEXT="Planning">
|
|
<node CREATED="1512925214070" ID="ID_491842947" MODIFIED="1557498707237" TEXT="1.Entwurf">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1512925217693" ID="ID_704714253" MODIFIED="1681837087287" TEXT="war seit 2012 steckengeblieben...">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1512925253328" HGAP="42" ID="ID_946385163" MODIFIED="1681168718652" TEXT="JobTicket" VSHIFT="-4">
|
|
<arrowlink COLOR="#82597c" DESTINATION="ID_922277724" ENDARROW="Default" ENDINCLINATION="43;-81;" ID="Arrow_ID_941233317" STARTARROW="None" STARTINCLINATION="-124;34;"/>
|
|
<node CREATED="1681166276225" ID="ID_1126956080" MODIFIED="1681168794426" TEXT="Konzept: Execution-Plan für ein (Segment, ModelPort)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gedacht als ein strukturelles Verzeichnis oder eine Facade, die gleichermaßen für die Planung und die Ausführung nutzbar ist; dadurch sind beide Belange von der Struktur des low-level-Model entkoppelt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1681167308878" ID="ID_43374924" MODIFIED="1681167532633" TEXT="Entwicklungs-Stand">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#435e98" CREATED="1681167354768" ID="ID_728804120" MODIFIED="1681167483523" TEXT="seit 2012">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681167362351" ID="ID_1740546811" MODIFIED="1681167371954" TEXT="Konzept und Struktur definiert"/>
|
|
<node CREATED="1681167383228" ID="ID_1536175314" MODIFIED="1681167401168" TEXT="noch gänzlich unklar wie die Auswertung / Job-Konstruktion funktionieren soll"/>
|
|
<node CREATED="1681167406089" ID="ID_1405586078" MODIFIED="1681167443145" TEXT="begründet durch die ebenfalls seinerzeit nur skizzierte Arbeitsweise der ProcNode"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681167868332" ID="ID_1179827139" MODIFIED="1681167938418">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>unklar</u>: <font face="Monospaced" color="#43226f">JobTicket::startExploration()</font> — wie wird die eigentliche Planung eingefädelt?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681167470153" ID="ID_1806361283" MODIFIED="1681167480840" TEXT="PlaybackVerticalSlice">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839381459" ID="ID_697548050" MODIFIED="1681839536316" TEXT="im ersten Schritt: mit der neuen Struktur ohne Monaden nutzbar machen">
|
|
<arrowlink COLOR="#fe80b2" DESTINATION="ID_310889374" ENDARROW="Default" ENDINCLINATION="-503;-32;" ID="Arrow_ID_1927639949" STARTARROW="None" STARTINCLINATION="230;9;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512925246057" ID="ID_181262071" MODIFIED="1561827466200" TEXT="JobPlanning">
|
|
<linktarget COLOR="#5379b5" DESTINATION="ID_181262071" ENDARROW="Default" ENDINCLINATION="-150;-386;" ID="Arrow_ID_1786254694" SOURCE="ID_1543264108" STARTARROW="Default" STARTINCLINATION="-1298;0;"/>
|
|
<node CREATED="1535892806131" ID="ID_513357674" MODIFIED="1535892890103" TEXT="könnte eine Monade sein.....?">
|
|
<arrowlink COLOR="#6c79a2" DESTINATION="ID_1502143527" ENDARROW="Default" ENDINCLINATION="-522;742;" ID="Arrow_ID_616092581" STARTARROW="None" STARTINCLINATION="238;0;"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1535891554587" ID="ID_185594200" MODIFIED="1535891663091" TEXT="entwerfe einen IterExplorer">
|
|
<arrowlink COLOR="#625975" DESTINATION="ID_409327286" ENDARROW="Default" ENDINCLINATION="-843;1771;" ID="Arrow_ID_86323098" STARTARROW="None" STARTINCLINATION="-493;-1123;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680567733451" ID="ID_896127270" MODIFIED="1680568264374" TEXT="Kritik / Refactoring Monaden">
|
|
<linktarget COLOR="#bf3473" DESTINATION="ID_896127270" ENDARROW="Default" ENDINCLINATION="-1310;-138;" ID="Arrow_ID_1052952035" SOURCE="ID_30857289" STARTARROW="None" STARTINCLINATION="-424;31;"/>
|
|
<linktarget COLOR="#f42f34" DESTINATION="ID_896127270" ENDARROW="Default" ENDINCLINATION="-1096;-80;" ID="Arrow_ID_1764912075" SOURCE="ID_1805461369" STARTARROW="None" STARTINCLINATION="-511;24;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#a51558" CREATED="1680568362230" ID="ID_1855480415" MODIFIED="1680568445542" TEXT="Problem: Code selbst für micht nicht mehr verständlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das liegt genau daran, daß die Monaten auf eine rein-abstrakte strukturelle Eigenschaft hin abstrahieren, welche nicht in der Natur der verhandelten Dinge verwurzelt ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1680568453218" FOLDED="true" ID="ID_1951039343" MODIFIED="1681511763512" TEXT="was passiert in job-planning.hpp?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681007533926" ID="ID_282014609" MODIFIED="1681007543121" TEXT="der schrittweise Planungsmechanismus">
|
|
<node CREATED="1681007545653" ID="ID_1444648679" MODIFIED="1681007547984" TEXT="gegeben....">
|
|
<node CREATED="1681076758382" ID="ID_1270706413" MODIFIED="1681076762624" TEXT="ein JobTicket"/>
|
|
<node CREATED="1681076774890" ID="ID_402478510" MODIFIED="1681076778189" TEXT="Timings"/>
|
|
<node CREATED="1681076778945" ID="ID_460925627" MODIFIED="1681076788146" TEXT="ein TimeAnchor"/>
|
|
</node>
|
|
<node CREATED="1681077108429" ID="ID_176137428" MODIFIED="1681077120991" TEXT="für jeden Chunk...">
|
|
<node CREATED="1681077129282" ID="ID_1894061712" MODIFIED="1681086711663" TEXT="erzeuge JobPlanningSequence">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">  void </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">  CalcPlanContinuation::performJobPlanningChunk(FrameCnt nextStartFrame) </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">  { </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    TimeAnchor refPoint(timings_, nextStartFrame); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    JobPlanningSequence jobs = dispatcher_.onCalcStream(modelPort_, channel_) </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">                                          .establishNextJobs(refPoint); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    Job nextChunkOfPlanning = buildFollowUpJobFrom (refPoint); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">    UNIMPLEMENTED ("the actual meat: access the scheduler and fed those jobs"); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2" color="#431818">  } </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#5478ca" DESTINATION="ID_1894061712" ENDARROW="Default" ENDINCLINATION="252;-178;" ID="Arrow_ID_1478605615" SOURCE="ID_789025207" STARTARROW="None" STARTINCLINATION="312;-20;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681077176827" ID="ID_728712867" MODIFIED="1681077182993" TEXT="FrameCoord des Ankerpunktes"/>
|
|
<node CREATED="1681077183565" ID="ID_96294471" MODIFIED="1681077188182" TEXT="Referenz auf den Dispatcher"/>
|
|
</node>
|
|
<node CREATED="1681089094840" ID="ID_573422091" MODIFIED="1681089145775" TEXT="hier steigen wir direkt in die Monaden-Kacke ein">
|
|
<arrowlink COLOR="#983ab0" DESTINATION="ID_256520127" ENDARROW="Default" ENDINCLINATION="34;-147;" ID="Arrow_ID_1652427615" STARTARROW="None" STARTINCLINATION="-162;10;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681076854338" ID="ID_137032068" MODIFIED="1681076861563" TEXT="für jeden Schritt...">
|
|
<node CREATED="1681076862694" ID="ID_474923430" MODIFIED="1681076918874" TEXT="baue aus TimeAnchor + offset ⟼ FrameCoord"/>
|
|
<node CREATED="1681076958274" ID="ID_1344252073" MODIFIED="1681076960709" TEXT="FrameCoord">
|
|
<node CREATED="1681076962646" MODIFIED="1681076962646" TEXT="TimeVar absoluteNominalTime;"/>
|
|
<node CREATED="1681076962646" MODIFIED="1681076962646" TEXT="FrameCnt absoluteFrameNumber;"/>
|
|
<node CREATED="1681076962646" ID="ID_1729128720" MODIFIED="1681076962646" TEXT="TimeVar absoluteRealDeadline;"/>
|
|
<node CREATED="1681076962646" ID="ID_1261272955" MODIFIED="1681076962646" TEXT="ModelPort modelPort;"/>
|
|
<node CREATED="1681076962646" ID="ID_1120839302" MODIFIED="1681076962646" TEXT="uint channelNr;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681079892096" ID="ID_1253755992" MODIFIED="1681079896243" TEXT="Fortsetzung">
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681082667504" ID="ID_547789227" MODIFIED="1681082717761" TEXT="CalcPlanContinuation">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1681086511956" ID="ID_456223503" MODIFIED="1681086520396" TEXT="ist selber eine JobClosure"/>
|
|
<node CREATED="1681086553182" ID="ID_789025207" MODIFIED="1681086615083" TEXT="invokeJobOperation() ⟹ performJobPlanningChunk">
|
|
<arrowlink COLOR="#5478ca" DESTINATION="ID_1894061712" ENDARROW="Default" ENDINCLINATION="252;-178;" ID="Arrow_ID_1478605615" STARTARROW="None" STARTINCLINATION="312;-20;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1681082677502" ID="ID_1891825875" MODIFIED="1681082693386" TEXT="hier steckt die Planungs-Logik">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681089112917" ID="ID_256520127" MODIFIED="1681511734896" TEXT="was machen die Monaden hier?">
|
|
<linktarget COLOR="#983ab0" DESTINATION="ID_256520127" ENDARROW="Default" ENDINCLINATION="34;-147;" ID="Arrow_ID_1652427615" SOURCE="ID_573422091" STARTARROW="None" STARTINCLINATION="-162;10;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681089212896" ID="ID_337268997" MODIFIED="1681170523138" TEXT="JobPlanningSequence">
|
|
<linktarget COLOR="#b4597c" DESTINATION="ID_337268997" ENDARROW="Default" ENDINCLINATION="18;60;" ID="Arrow_ID_311262374" SOURCE="ID_1034254567" STARTARROW="None" STARTINCLINATION="-177;-12;"/>
|
|
<node CREATED="1681089218823" ID="ID_1821180666" MODIFIED="1681089224250" TEXT="ist eine Monade"/>
|
|
<node CREATED="1681089225590" ID="ID_871607291" MODIFIED="1681089236449" TEXT="stellt eine Sequenz geplanter Jobs dar"/>
|
|
</node>
|
|
<node CREATED="1681089479948" ID="ID_1765132212" MODIFIED="1681089502583" TEXT="der Typ-Kommentar über JobPlanningSequence ist aufschlußreich">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681089505401" ID="ID_462054221" MODIFIED="1681089555850" TEXT="so gut es sein kann">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Hier zeigt sich das ganze Elend mit den Monaden: man muß dazu einen Leitfaden schreiben, anstatt daß sie sich selber erklären würden....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681089566409" ID="ID_1085499553" MODIFIED="1681089893458" TEXT="zweifelhaft dicht gepackter »Twist«">
|
|
<node CREATED="1681089582543" ID="ID_965789758" MODIFIED="1681089609623" TEXT="einerseits eine Sequenz von JobPlanning-elementen"/>
|
|
<node CREATED="1681089611728" ID="ID_601644157" MODIFIED="1681089620757" TEXT="die dann aber wohl direkt konvertibel sind als Jobs"/>
|
|
<node CREATED="1681089660421" ID="ID_1491590859" MODIFIED="1681089670283" TEXT="aber die partielle Auswertung ist zugleich ein Planungs-Zustand"/>
|
|
<node CREATED="1681089690115" ID="ID_815917928" MODIFIED="1681089727285">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" color="#d93278">expandPrerequisites</font> ist die Planungs-Operation und wird monadisch gebunden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681089744497" ID="ID_745863442" MODIFIED="1681089764956" TEXT="die Auswertung wird ge-seeded mit dem PlanningStepGenerator">
|
|
<node CREATED="1681089768902" ID="ID_1690425506" MODIFIED="1681089775563" TEXT="dieser erzeugt die Chunk-Struktur"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681089920298" ID="ID_923180973" MODIFIED="1681089925797" TEXT="unklare Nomenklatur">
|
|
<node CREATED="1681089943279" ID="ID_1215377203" MODIFIED="1681089946735" TEXT="Job"/>
|
|
<node CREATED="1681089940175" ID="ID_1162115878" MODIFIED="1681089942779" TEXT="JobPlanning">
|
|
<node CREATED="1681166025286" ID="ID_253282433" MODIFIED="1681166036328" TEXT="zentrale Status-View"/>
|
|
<node CREATED="1681166037181" ID="ID_1967937878" MODIFIED="1681166042520" TEXT="referenziert ">
|
|
<node CREATED="1681166052921" ID="ID_877761223" MODIFIED="1681166053958" TEXT="JobTicket::ExplorationState"/>
|
|
<node CREATED="1681166054906" ID="ID_112460186" MODIFIED="1681166060733" TEXT="FrameCoord"/>
|
|
</node>
|
|
<node CREATED="1681166081679" ID="ID_81862434" MODIFIED="1681166129475">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist eine <b>State-Core</b> ( IterStateWrapper)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681166151117" ID="ID_1918457721" MODIFIED="1681166159224" TEXT="reduziertbar in einen Job"/>
|
|
</node>
|
|
<node CREATED="1681090084033" ID="ID_1968751118" MODIFIED="1681090086992" TEXT="PlanningState">
|
|
<node CREATED="1681170422864" ID="ID_1201866301" MODIFIED="1681170455125" TEXT="State-core-Iterator über JobPlanning"/>
|
|
<node CREATED="1681170485540" ID="ID_1034254567" MODIFIED="1681170530962" TEXT="Verhältnis zu JobPlanningSequence ist verwirrend">
|
|
<arrowlink COLOR="#b4597c" DESTINATION="ID_337268997" ENDARROW="Default" ENDINCLINATION="18;60;" ID="Arrow_ID_311262374" STARTARROW="None" STARTINCLINATION="-177;-12;"/>
|
|
<node CREATED="1681170600989" ID="ID_1127702818" MODIFIED="1681170615896" TEXT="es ist das Gleiche (nur nicht explizit dargestellt)"/>
|
|
<node CREATED="1681170616675" ID="ID_1213917365" MODIFIED="1681170632880" TEXT="liegt daran, daß wir hier »Monaden« nicht als Typklassen darstellen können"/>
|
|
<node CREATED="1681170713246" ID="ID_678111828" MODIFIED="1681170747342" TEXT="C++ kennt keine partiell ausgewerteten rekursiven Typen"/>
|
|
<node CREATED="1681170750345" ID="ID_1806882257" MODIFIED="1681170768613" TEXT="JobPlanningSequence ist die fertig entfaltete Monade">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1681170811599" ID="ID_1363589659" MODIFIED="1681171010232">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#8d2828" face="Monospaced">SIG_expandPrerequisites</font>
|
|
</p>
|
|
<p>
|
|
  ⟹ per flatMap wird daraus ein <font face="Monospaced">PlanningState</font> ≔ <font face="Monospaced">IterStateWrapper<JobPlanning></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681171032503" ID="ID_1088269383" MODIFIED="1681171110306" TEXT="Kritik: unklar was hier „state“ meint">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1681171111745" ID="ID_261557469" MODIFIED="1681171124803" TEXT="state: die StateCore, also JobPlanning"/>
|
|
<node COLOR="#d62a6d" CREATED="1681171170505" HGAP="29" ID="ID_519174430" MODIFIED="1681171183560" TEXT="≠" VSHIFT="1">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
</node>
|
|
<node CREATED="1681171125559" ID="ID_150888686" MODIFIED="1681171143401" TEXT="state: die partielle Auswertung des Iterators, also PlanningState"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681090089907" ID="ID_1553722580" MODIFIED="1681090094599" TEXT="PlanningStepGenerator"/>
|
|
<node CREATED="1681090112749" ID="ID_528965729" MODIFIED="1681090113644" TEXT="ExpandedPlanningSequence">
|
|
<node CREATED="1681090118071" ID="ID_600100783" MODIFIED="1681090127602" TEXT="Ergebnistyp der FlatMap-Operation"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681171685380" ID="ID_1860128661" MODIFIED="1681511730984" TEXT="wann / wie findet die eigentliche Planung(Auswertung) statt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681171733502" ID="ID_433565768" MODIFIED="1681171751420" TEXT="expandPrerequisites(JobPlanning) wird monadisch gebunden (flatMap)"/>
|
|
<node CREATED="1681171757291" ID="ID_1142053734" MODIFIED="1681171885232">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Strategy: <font face="Monospaced" color="#3c41a3">lib::iter_explorer::RecursiveSelfIntegration</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1681172265271" ID="ID_770724358" MODIFIED="1681172273681" TEXT="zOMG">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1681172281924" ID="ID_687991393" MODIFIED="1681179573174" TEXT="wertet depth-first aus bis zur Hülle (Blatt-Ebene)"/>
|
|
<node CREATED="1681229060538" ID="ID_1426518727" MODIFIED="1681229100966" TEXT="verlagert Memory-Management per Extension-Point in den Payload-Typ"/>
|
|
<node CREATED="1681229106153" ID="ID_1596284582" MODIFIED="1681229132603" TEXT="tatsächlich durchgereicht bis JobTicket::ExecutionState::push(subExploration)"/>
|
|
</node>
|
|
<node CREATED="1681229139349" ID="ID_149981075" MODIFIED="1681229216355">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
⟹ die Auswertung und Organisation findet in <font color="#3f2257" face="Monospaced"><b>JobTicket::ExecutionState</b></font>  statt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681249113814" HGAP="12" ID="ID_1134987645" MODIFIED="1681249480677" VSHIFT="4">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Monaden allein <b>leisten nicht</b> was hier benötigt wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681249199658" ID="ID_1832498470" MODIFIED="1681249214440">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wir brauchen nämlich <b>rekursive Entfaltung</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681249215248" ID="ID_515933435" MODIFIED="1681249303525">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Monad-bind <i>transformiert</i> und <i>expandiert</i> — jeweils nur einmal
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1681249520544" ID="ID_1957142208" MODIFIED="1681249556650">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man <i>kann </i>die Tiefensuche extra noch hinzufügen — als <b>Komplikation</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681250256733" ID="ID_591477947" MODIFIED="1681250471971">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dagegen das TreeExplorer::expand() ist <i><b>keine</b> monadische Operation</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....und zwar in mehrerlei Hinsicht....
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
es wird in der Grundform nur explizit ausgelöst
|
|
</li>
|
|
<li>
|
|
expandierte und nicht expandierte Werte können sich mischen
|
|
</li>
|
|
<li>
|
|
Quell- und Ausgabe-Werte der Expander-Funktion müssen kompatibel sein
|
|
</li>
|
|
<li>
|
|
expandAll() bietet Auswertung-bis-zur-Erschöpfung, exponiert aber auch <b>alle Zwischenwerte</b>
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681179592836" ID="ID_1534441402" MODIFIED="1681179596322" TEXT="Umbau-Planung">
|
|
<node CREATED="1681179609394" ID="ID_655076663" MODIFIED="1681184137895" TEXT="Idee: JobPlanning direkt als StateCore nutzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681183957626" ID="ID_1460327799" MODIFIED="1681183981602" TEXT="Layer-1: Startpunkte für Planning-Chunk"/>
|
|
<node CREATED="1681183982950" ID="ID_1134560942" MODIFIED="1681184074926" TEXT="Layer-2: Startpunkte in JobTickets übersetzen"/>
|
|
<node CREATED="1681184077058" ID="ID_1263780584" MODIFIED="1681184086844" TEXT="--Expander--"/>
|
|
<node CREATED="1681184116172" ID="ID_1292319298" MODIFIED="1681184131382" TEXT="Layer-3: Leaf-Tickets in Jobs übersetzen"/>
|
|
</node>
|
|
<node CREATED="1681179675524" ID="ID_1631190283" MODIFIED="1681179928963" TEXT="Custom-Allokator möglich: IterStack<ResIter> spezialisieren!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">    template<class SRC> </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">    struct _DecoratorTraits<SRC,   enable_if<is_StateCore<SRC>>> </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">      { </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">        using SrcVal  = typename CoreYield<SRC>::value_type; </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">        using SrcIter = iter_explorer::IterableDecorator<SrcVal, SRC>; </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" color="#5b232b">      }; </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681181487438" ID="ID_1162267066" MODIFIED="1681250532522" TEXT="Frage: Memory-Footprint?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681229228809" ID="ID_208607615" MODIFIED="1681229238435" TEXT="auch die bestehende Lösung braucht einen Stack"/>
|
|
<node CREATED="1681229243414" ID="ID_1553851683" MODIFIED="1681229405236" TEXT="dieser ist aber „pfiffig“ in der Linked-List-Datenstruktur versteckt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und die Auswirkungen können kaum sinnvoll vorhergesagt oder bewertet werden
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
da wir die Datenstruktur nicht beliebig austauschen können
|
|
</li>
|
|
<li>
|
|
da sie mit dem Allokations-Schema verwoben ist
|
|
</li>
|
|
<li>
|
|
da die erziehlbare Cache-Locality von den Anforderungen der <i>konkreten Render-Pipeline</i> abhängt
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681238369393" ID="ID_423908789" MODIFIED="1681238451197" TEXT="Maßgabe: Job-Planung muß lediglich »abgespielt« werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
initial gibt es eine Allokation im AllocationCluster — ab diesem Teil soll die Planung weitgehend ohne „bewegliche Teile“ ablaufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681250556444" ID="ID_1991482624" MODIFIED="1681511717857" TEXT="Grundlegendes Auswertungs-Schema">
|
|
<icon BUILTIN="yes"/>
|
|
<node COLOR="#435e98" CREATED="1681250582708" ID="ID_1884826569" MODIFIED="1681511406548" TEXT="auf welcher Ebene wird die fortschreitende Planung angesetzt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681250669452" ID="ID_1404510345" MODIFIED="1681511443549" TEXT="darüber">
|
|
<arrowlink COLOR="#68678a" DESTINATION="ID_1399425577" ENDARROW="Default" ENDINCLINATION="-321;0;" ID="Arrow_ID_26789445" STARTARROW="None" STARTINCLINATION="-435;100;"/>
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681250697202" ID="ID_591609787" MODIFIED="1681250718160" TEXT="die Pipeline beschreibt die fortlaufende Job-Planung lückenlos"/>
|
|
<node CREATED="1681250769368" ID="ID_772063728" MODIFIED="1681250784298" TEXT="ein separater Taktgeber ist darüber gesetzt..."/>
|
|
<node CREATED="1681250785294" ID="ID_1717449216" MODIFIED="1681250805743" TEXT="...und entnimmt jeweils einen »chunk« an Planung"/>
|
|
</node>
|
|
<node CREATED="1681250684195" ID="ID_1446227888" MODIFIED="1681511427222" TEXT="darunter">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1681250819275" ID="ID_92926923" MODIFIED="1681250835367" TEXT="der »chunk«-Taktgeber ist die Basis der Pipeline"/>
|
|
<node CREATED="1681250837199" ID="ID_947581885" MODIFIED="1681250885117" TEXT="jeder Schritt wird einmal monadisch entfaltet ⟶ Jobs für einen »chunk«"/>
|
|
<node CREATED="1681250898279" ID="ID_1453593011" MODIFIED="1681250924584" TEXT="der Konsument erkennt das Ende eines Chunk — und pflanzt sich dann fort"/>
|
|
</node>
|
|
<node CREATED="1681250688531" ID="ID_1904669959" MODIFIED="1681511427227" TEXT="separat">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1681250972125" ID="ID_492221110" MODIFIED="1681250991302" TEXT="ein separater Dispatcher-Mechanismus konstruiert für jeden »chunk« eine Pipeline"/>
|
|
<node CREATED="1681251006417" ID="ID_115424466" MODIFIED="1681251032211" TEXT="der Planungs-Job konsumiert und wertet diese aus und generiert Jobs"/>
|
|
<node CREATED="1681251047923" ID="ID_1020628588" MODIFIED="1681251058990" TEXT="die Limitierung auf einen Chunk steckt in der Pipeline selber"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681344133719" FOLDED="true" ID="ID_642967019" MODIFIED="1681424266741" TEXT="Diskussion">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1681344155430" ID="ID_1775975727" MODIFIED="1681344193644" TEXT="Separation of Concerns ⟹ spricht für die reine lückenlose Job-Planung"/>
|
|
<node CREATED="1681344197504" ID="ID_1110233377" MODIFIED="1681344469258" TEXT="das wirft das Problem auf: Invariante Time-Anchor ≡ alles bis dahin geregelt">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1681344478491" ID="ID_159991195" MODIFIED="1681344551872">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie erkennt man dies <i>von „oben“ ?</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1681344561975" ID="ID_658725827" MODIFIED="1681344574018" TEXT="was heißt „vollständig geregelt“?"/>
|
|
<node CREATED="1681346552301" ID="ID_322305817" MODIFIED="1681346617402" TEXT="zunächst nur aus dem Planning-Chunk heraus explizit klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es heißt, daß die top-level-Jobs bis <= der nächsten Deadline komplett entfaltet wurden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681346714903" ID="ID_1742816164" MODIFIED="1681346731768" TEXT="würde bevorzugen, wenn die Deadline-Bestimmung ein lokales Detail bleibt">
|
|
<node CREATED="1681346762329" ID="ID_1402655083" MODIFIED="1681424061932" TEXT="Deadlines kann man nur mit Kenntnis der Dependencies festsetzen">
|
|
<arrowlink COLOR="#544b67" DESTINATION="ID_1191577011" ENDARROW="Default" ENDINCLINATION="22;-64;" ID="Arrow_ID_370847933" STARTARROW="None" STARTINCLINATION="-378;15;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1681347374347" ID="ID_594073373" MODIFIED="1681347486789" TEXT="⟹ wirft die Frage auf, wie Dependencies fesgesetzt und aktualisiert werden">
|
|
<arrowlink COLOR="#9c738a" DESTINATION="ID_444443795" ENDARROW="Default" ENDINCLINATION="-1256;-1009;" ID="Arrow_ID_1047384894" STARTARROW="None" STARTINCLINATION="-902;35;"/>
|
|
<node CREATED="1681347495927" ID="ID_972266761" MODIFIED="1681347856721" TEXT="Modell-1: beim Planen vorsortieren">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1681347551175" ID="ID_875180659" MODIFIED="1681347563377" TEXT="bereits beim Planen wird ein Dependency-Graph aufgebaut"/>
|
|
<node CREATED="1681347564398" ID="ID_131120619" MODIFIED="1681347579368" TEXT="dieser wird dann traversiert, und die Deadlines werden rückwärts festgesetzt"/>
|
|
</node>
|
|
<node CREATED="1681347514525" ID="ID_80362345" MODIFIED="1681347859365" TEXT="Modell-2: dynamisch konstituieren">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681347582164" ID="ID_278867248" MODIFIED="1681347600077" TEXT="den Jobs werden nur lokale Dependency-Beziehungen mitgegeben"/>
|
|
<node CREATED="1681347600785" ID="ID_48999687" MODIFIED="1681347611164" TEXT="außerdem bekommt jeder Job ein zunächst grobes Zeitfenster mit"/>
|
|
<node CREATED="1681347612232" ID="ID_1374144549" MODIFIED="1681347633816" TEXT="der Scheduler justiert die Zeitfenster dynamisch nach"/>
|
|
<node CREATED="1681347634500" ID="ID_1442392443" MODIFIED="1681347652126" TEXT="erst dadurch ergibt sich der globale Dependency-Graph als transitive Hülle der Zeit-Sequenz"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681347681541" ID="ID_488964253" MODIFIED="1681396325874" TEXT="Modell-2 sieht richtig aus (ist aber auch anspruchsvoller)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es sieht für mich dennoch nach dem erstrebenswerten Ansatz aus, da der Scheduler ja dynamisch nachjustieren soll, und daher ohnehin so eine Aktuaisierung der Zeitfenster machen muß; zudem würde diese Berechnung und Steuerung nur intern im Scheduler stattfinden, und auch der Dispatch-Schritt wäre noch im Wesentlichen deklarativ — er würde nur eine heuristische Grob-Bestimmung der Zeitfenster vornehmen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1681398912107" ID="ID_845962402" MODIFIED="1681399086045" TEXT="Dependencies müssen eigens repräsentiert werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn im JobTicket sind sie zwar explizit vorhanden, dieses ist aber nicht konkret instantiiert und gilt für ein ganze Segment; mithin fehlt die Verbindung von einer Dependency zu dem konkreten Job, welcher diese Dependency realisiert. Im Gegensatz dazu ist <i>während dem Dispatch-Schritt</i> diese Information implizit vorhanden, denn für den Dispatch wird genau das JobTicket interpretiert, und die konkreten Jobs werden von diesem abgeleitet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681399099426" ID="ID_932754835" MODIFIED="1681399195400" TEXT="Diesem Dilemma kann man aber grundsätzlich nicht entgehen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entweder, man verzichtet auf ein dynamisches Nachjustieren und läßt die einmal eingefädelten Berechnungen <i>einfach laufen</i> — oder man muß für jede einzelne Berechnungkette die gesamte Dependency-Struktur <i>duplizieren und im Speicher halten.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1681399845455" ID="ID_688481230" MODIFIED="1681399868776" TEXT="man kann aber limitieren, was überhaupt repräsentiert wird">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1681399885521" ID="ID_1877681787" MODIFIED="1681399906234" TEXT="nur was einen tangiblen Effekt auf eine konkrete Berechnung hat"/>
|
|
<node CREATED="1681399906895" ID="ID_772103901" MODIFIED="1681399920265" TEXT="denn dieses muß ohnehin mit dieser konkreten Berechnung verlinkt sein"/>
|
|
<node CREATED="1681399949945" ID="ID_1604564614" MODIFIED="1681422135919">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und man kann Nachfolger <i>benachrichtigen, </i>statt Vorgänger zu <i>suchen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681422192014" ID="ID_686946668" MODIFIED="1681422278056" TEXT="⟹ Verhalten und Benachrichtigungen planen — ohne Dependencies explizit zu repräsentieren">
|
|
<arrowlink COLOR="#7c2e36" DESTINATION="ID_964028347" ENDARROW="Default" ENDINCLINATION="1221;-42;" ID="Arrow_ID_727391713" STARTARROW="None" STARTINCLINATION="-29;337;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681422781457" ID="ID_1191577011" MODIFIED="1681424052805" TEXT="1-step lookahead ausnutzen">
|
|
<linktarget COLOR="#544b67" DESTINATION="ID_1191577011" ENDARROW="Default" ENDINCLINATION="22;-64;" ID="Arrow_ID_370847933" SOURCE="ID_1402655083" STARTARROW="None" STARTINCLINATION="-378;15;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681422798726" ID="ID_679404345" MODIFIED="1681422879620" TEXT="das bekommen wir durch den Iterator „for free“">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da man einen Lumiera-Forward-Iterator aktiv weiterschalten muß, aber stets auf das <i>aktuelle Element</i> zugreifen kann...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681422914837" ID="ID_709137224" MODIFIED="1681423016221" TEXT="ein »Chunk« wird beendet wenn ein Job mit späterer Deadline auftaucht"/>
|
|
<node CREATED="1681423023681" ID="ID_618849588" MODIFIED="1681423071566" TEXT="⟹ das JobPlanning-Element muß ein Zeitfenster offenlegen">
|
|
<node CREATED="1681423079642" ID="ID_1790757865" MODIFIED="1681423118955" TEXT="Zeitpunkt der Planungs-Wiedervorlage ≠ Deadline"/>
|
|
<node CREATED="1681423128755" ID="ID_1032383879" MODIFIED="1681423175009" TEXT="Jeder Planungs-»Chunk« hat eine abgedeckte Zeitspanne"/>
|
|
<node CREATED="1681423190299" ID="ID_1808919355" MODIFIED="1681423731839" TEXT="Prinzipiell ist die »Chunk«-Einteilung beliebig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...solange ein Planungs-»Chunk« hinreichend weit vor dem Ende seiner abgedeckten Zeitspanne aufgebaut wird; das Planungsintervall könnte sogar dynamisch reguliert werden, wichtig ist nur, einen Mindest-Vorlauf vor der tatsächlich abgedeckten Zeitspanne einzuhalten, so daß idealerweise der nächste Planungs-»Chunk« bereits stattfindet, noch bevor die Deadlines für den Vorgänger ganz abgelaufen sind. Denn unter diesen Umständen müßte nicht einmal ein vollständiger Dependency-Tree in einem Chunk abgearbeitet werden, solange nur die geplanten Jobs rechtzeitig in der Scheduler-Queue sind. Tatsächlich aber tritt in unserem Iterator-Mechanismus der top-level Planungsschritt als erstes auf, und damit springt jeweils die Deadline um eine ganze Frame-Dauer in die Zukunft — dies wäre dann in jedem Fall ein ganz klares Signal, um das Überschreiten des zu planenden Zeitspanne zu erkennen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681423752401" ID="ID_1703609923" MODIFIED="1681423762827" TEXT="Fazit">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1681423765518" ID="ID_1399425577" MODIFIED="1681424264776" TEXT="wir können komplett trennen und die Pipeline ist nur noch die reine Planung">
|
|
<linktarget COLOR="#68678a" DESTINATION="ID_1399425577" ENDARROW="Default" ENDINCLINATION="-321;0;" ID="Arrow_ID_26789445" SOURCE="ID_1404510345" STARTARROW="None" STARTINCLINATION="-435;100;"/>
|
|
</node>
|
|
<node CREATED="1681423785083" ID="ID_83395390" MODIFIED="1681423811754" TEXT="das JobPlanning muß ein Zeitfenster sichtbar machen; das genügt zur Planungs-Steuerung"/>
|
|
<node CREATED="1681423881164" ID="ID_947885657" MODIFIED="1681423903640" TEXT="die Job-Deskriptor-Datenstruktur wird erweitert, so daß sie Scheduler-Actions beinhaltet"/>
|
|
<node CREATED="1681423904443" ID="ID_1758639000" MODIFIED="1681423917165" TEXT="über diese Actions werden Dependency-Checks vorgeplant"/>
|
|
<node CREATED="1681423933821" ID="ID_1904536434" MODIFIED="1681423983716" TEXT="der Dispatcher sitzt darüber und dient nur als »Chunk«-Taktgeber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681424304209" HGAP="-38" ID="ID_722224370" MODIFIED="1681424867599" TEXT="Umbau-Schritte" VSHIFT="21">
|
|
<edge STYLE="linear"/>
|
|
<icon BUILTIN="flag-pink"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424329079" ID="ID_292995208" MODIFIED="1681424826118" STYLE="bubble" TEXT="die Monaden enthalten keine substantielle Logik und können einfach weggeworfen werden">
|
|
<edge COLOR="#725330"/>
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424351736" ID="ID_141256625" MODIFIED="1681424826119" STYLE="bubble" TEXT="JobPlanning bleibt als Front-End/Strategy/StateCore erhalten (später zu prüfen)">
|
|
<edge COLOR="#725330"/>
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424610628" ID="ID_1888344503" MODIFIED="1681426106281" STYLE="bubble" TEXT="Dispatcher so umschreiben, daß er einen CalcDriver verwendet">
|
|
<edge COLOR="#725330"/>
|
|
<arrowlink COLOR="#f4fec9" DESTINATION="ID_1928295133" ENDARROW="Default" ENDINCLINATION="-1068;-69;" ID="Arrow_ID_362199078" STARTARROW="None" STARTINCLINATION="1381;58;"/>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424692274" ID="ID_1926192234" MODIFIED="1681425384986" STYLE="bubble" TEXT="Setup für scheduler::Action anlegen">
|
|
<edge COLOR="#725330"/>
|
|
<arrowlink COLOR="#f4fec9" DESTINATION="ID_688439359" ENDARROW="Default" ENDINCLINATION="-522;-149;" ID="Arrow_ID_1352278228" STARTARROW="None" STARTINCLINATION="1598;114;"/>
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424715326" ID="ID_566775911" MODIFIED="1681425341556" STYLE="bubble" TEXT="Job-Datenstruktur neu konzipieren">
|
|
<edge COLOR="#725330"/>
|
|
<arrowlink COLOR="#f4fec9" DESTINATION="ID_274575596" ENDARROW="Default" ENDINCLINATION="-522;-149;" ID="Arrow_ID_1673610733" STARTARROW="None" STARTINCLINATION="1598;114;"/>
|
|
<icon BUILTIN="full-5"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681424909356" ID="ID_1912461724" MODIFIED="1681424960719" TEXT="Monaden-basierten IterExplorer zurückbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681424933809" ID="ID_377619970" MODIFIED="1681424958374" TEXT="Umbenennen: TreeExplorer ⟼ IterExplorer">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681082793383" ID="ID_1314381934" MODIFIED="1681082807141" TEXT="Kritik Scheduler-Interface">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1681082814380" ID="ID_1475292843" MODIFIED="1681082839540" TEXT="wir dachten damals...">
|
|
<node CREATED="1681082840320" ID="ID_1603095908" MODIFIED="1681082845676" TEXT="C ist einfach"/>
|
|
<node CREATED="1681082846479" ID="ID_1336295362" MODIFIED="1681082850571" TEXT="deshalb ist es schnell"/>
|
|
<node CREATED="1681082851148" ID="ID_563185801" MODIFIED="1681082863297" TEXT="deshalb ist es gut für die Aufgabe"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681082876300" ID="ID_743791679" MODIFIED="1681082888427" TEXT="das ist eine Mystifikation">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1681082889754" ID="ID_1911631905" MODIFIED="1681082903428" TEXT="tatsächlich gibt es performante Verarbeitungsmuster"/>
|
|
<node CREATED="1681082905864" ID="ID_1034659086" MODIFIED="1681082913243" TEXT="genauso wichtig ist aber klarer Code">
|
|
<node CREATED="1681082918734" ID="ID_1433754376" MODIFIED="1681082946174" TEXT="für den Menschen"/>
|
|
<node CREATED="1681082932051" ID="ID_545301338" MODIFIED="1681082936956" TEXT="für den Optimizer"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1681082963560" ID="ID_1172337937" MODIFIED="1681083058271" TEXT="nicht eine Sprache (C) oder eine Datenstruktur (LinkedList) ist substantiell „performant“">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990061" CREATED="1681083085671" ID="ID_670283864" MODIFIED="1681083328001" TEXT="Convey's Law">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681083093846" ID="ID_1045820854" MODIFIED="1681083294169" TEXT="der Scheduler ist eine denkbar ungünstige Schnittstelle zwischen verschiedenen Design-Stilen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681083267223" ID="ID_1330479674" MODIFIED="1681083294171" TEXT="die Schnittstelle liegt an einer Grenze der Kopetenzen — nicht einer Grenze der Domänen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681083159662" ID="ID_860686341" MODIFIED="1681083294170" TEXT="die Aufteilung in Session und Engine ⟹ zu einfaches mentales Modell">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681083619609" ID="ID_1647785356" MODIFIED="1681083636070" TEXT="Bessere Lösung">
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681083639877" ID="ID_358030802" LINK="#ID_1372752844" MODIFIED="1681951396709" TEXT="klare performance-orientierte Datenstrukturen schaffen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681083683663" ID="ID_135955742" MODIFIED="1681084106386" TEXT="Job ⟼ Deskriptor(value, stateful)"/>
|
|
<node CREATED="1681083725400" ID="ID_201198910" MODIFIED="1681084115121" TEXT="JobFunktor ⟼ Strategy(reference, shared)"/>
|
|
<node CREATED="1681083935037" ID="ID_951868878" MODIFIED="1681084147700" TEXT="Activity ⟼ Verb(symbolic, algebraic)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681083656587" ID="ID_994543902" MODIFIED="1681084305066" TEXT="diese durchgängig im gesamten Scheduler verwenden">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681084260162" ID="ID_1346463753" MODIFIED="1681084305067">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Scheduler-Interface ist ein <b>Gefahrenübergang</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681084307651" ID="ID_876302640" MODIFIED="1681084319241" TEXT="Scheduler in zwei Layer zerlegen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681084330224" ID="ID_799114403" MODIFIED="1681084338824" TEXT="Eigentliche Schnittstellen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681084340127" ID="ID_396373123" LINK="#ID_1855109590" MODIFIED="1681085948888" TEXT="Interface: Player">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1681085755729" ID="ID_859410938" LINK="#ID_667166448" MODIFIED="1681085948889" TEXT="Interface: Render Toolkit">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681511517424" ID="ID_1109133019" MODIFIED="1681511570233" TEXT="Aufteilung des eigentlichen Planungsvorgangs">
|
|
<node CREATED="1681511579310" ID="ID_1531444492" MODIFIED="1681511599329" TEXT="JobTicket stellt on-demand die Dependencies bereit"/>
|
|
<node CREATED="1681511631477" ID="ID_972174517" MODIFIED="1681511657301" TEXT="die Planungs-»Mechanik« wird in JobPlanning übersetzt"/>
|
|
<node CREATED="1681511601097" ID="ID_964028347" MODIFIED="1681511694671" TEXT="daraus werden aber direkt einzel-Beziehungen für den Scheduler gebaut">
|
|
<linktarget COLOR="#7c2e36" DESTINATION="ID_964028347" ENDARROW="Default" ENDINCLINATION="1221;-42;" ID="Arrow_ID_727391713" SOURCE="ID_686946668" STARTARROW="None" STARTINCLINATION="-29;337;"/>
|
|
</node>
|
|
<node CREATED="1681513765614" ID="ID_1274319760" MODIFIED="1681515077439" TEXT="Aufbau">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1681513770238" HGAP="30" ID="ID_1755305963" MODIFIED="1681514318606" TEXT="Play-Service">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_80916607" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1602613098" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<node CREATED="1681520404028" ID="ID_139747553" MODIFIED="1681520414735" TEXT="konfiguriert Modus und Timings"/>
|
|
<node CREATED="1681520421034" ID="ID_1253264357" MODIFIED="1681520442787" TEXT="verbindet ModelPorts ⟼ output-connection"/>
|
|
<node CREATED="1681520449253" ID="ID_616433102" MODIFIED="1681520472992" TEXT="resultierende RenderConfig ⟹ PlayProcess"/>
|
|
</node>
|
|
<node CREATED="1681513866097" HGAP="30" ID="ID_80916607" MODIFIED="1681514389653" TEXT="PlayProcess" VSHIFT="-1">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_1732223894" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1129120203" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_80916607" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1602613098" SOURCE="ID_1755305963" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<node CREATED="1681520521181" ID="ID_127137475" MODIFIED="1681520530807" TEXT="verwendet gegebenen Render-Configurator"/>
|
|
<node CREATED="1681520531323" ID="ID_741530178" MODIFIED="1681520580039" TEXT="erstellt daraus die Feeds + CalcStreams"/>
|
|
</node>
|
|
<node CREATED="1681513775661" HGAP="30" ID="ID_1732223894" MODIFIED="1681515122691" TEXT="Engine-Service">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_1709285340" ENDARROW="Default" ENDINCLINATION="-55;-7;" ID="Arrow_ID_1166695691" STARTARROW="None" STARTINCLINATION="-42;8;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_1732223894" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1129120203" SOURCE="ID_80916607" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<node CREATED="1681520606402" ID="ID_833200775" MODIFIED="1681520624991" TEXT="Initiiert CalcStream(s)"/>
|
|
<node CREATED="1681520779187" ID="ID_809350382" MODIFIED="1681520811410" TEXT="verdrahtet dazu einen Dispatcher"/>
|
|
<node CREATED="1681520822876" ID="ID_4022163" MODIFIED="1681521853518" TEXT="erstellt ein RenderDrive mit Output"/>
|
|
</node>
|
|
<node CREATED="1681513782908" HGAP="30" ID="ID_1709285340" MODIFIED="1681515121003" TEXT="CalcStream">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_1418303343" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1246156345" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_1709285340" ENDARROW="Default" ENDINCLINATION="-55;-7;" ID="Arrow_ID_1166695691" SOURCE="ID_1732223894" STARTARROW="None" STARTINCLINATION="-42;8;"/>
|
|
<node CREATED="1681520869358" ID="ID_248036437" MODIFIED="1681521862197" TEXT="betreibt den RenderDrive"/>
|
|
<node CREATED="1681520874613" ID="ID_1197599470" MODIFIED="1681520883624" TEXT="dieser ist intern mit dem Dispatcher verdrahtet"/>
|
|
</node>
|
|
<node CREATED="1681513790253" HGAP="30" ID="ID_1418303343" MODIFIED="1681515151463" TEXT="Dispatcher">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_786643460" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_876462297" STARTARROW="None" STARTINCLINATION="-29;7;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_1418303343" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1246156345" SOURCE="ID_1709285340" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<node CREATED="1681520888910" ID="ID_1891724948" MODIFIED="1681520896702" TEXT="ist angesiedelt in der Fixture"/>
|
|
<node CREATED="1681520912952" ID="ID_1717997829" MODIFIED="1681520920398" TEXT="bietet Anbindung an ein Frame-Grid"/>
|
|
<node CREATED="1681520921575" ID="ID_1652151815" MODIFIED="1681520933542" TEXT="bietet Anbindung an die JobTicket(s)"/>
|
|
</node>
|
|
<node CREATED="1681513796795" HGAP="30" ID="ID_786643460" MODIFIED="1681521871090" TEXT="RenderDrive">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_947997771" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_364168275" STARTARROW="None" STARTINCLINATION="-24;5;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_786643460" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_876462297" SOURCE="ID_1418303343" STARTARROW="None" STARTINCLINATION="-29;7;"/>
|
|
<node CREATED="1681520948109" ID="ID_1974741811" MODIFIED="1681520958397" TEXT="der aktive Nutzer des Dispatcher-Interfaces"/>
|
|
<node CREATED="1681520997813" ID="ID_1498779054" MODIFIED="1681521034522" TEXT="re-aktiviert sich fortlaufend selbst"/>
|
|
<node CREATED="1681521035833" ID="ID_744901458" MODIFIED="1681521051722" TEXT="ist verdrahtet mit der EngineFacade"/>
|
|
<node CREATED="1681521090001" ID="ID_1206046554" MODIFIED="1681521101922" TEXT="erstellt und betreibt die JobPlanning-Pipeline"/>
|
|
</node>
|
|
<node CREATED="1681513815536" HGAP="30" ID="ID_947997771" MODIFIED="1681515143216" TEXT="JobPlanning">
|
|
<arrowlink COLOR="#5e5972" DESTINATION="ID_839385817" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1889540359" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_947997771" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_364168275" SOURCE="ID_786643460" STARTARROW="None" STARTINCLINATION="-24;5;"/>
|
|
<node CREATED="1681521107332" ID="ID_764418758" MODIFIED="1681521118625" TEXT="konkrete StateCore mit allen aktiven Verdrahtungen"/>
|
|
<node CREATED="1681521122833" ID="ID_479512654" MODIFIED="1681521129047" TEXT="wird wie ein Cursor navigiert"/>
|
|
<node CREATED="1681521246771" ID="ID_1361044565" MODIFIED="1681521267392" TEXT="bewegt sich auf Basis von JobTicket-Konfigurationen"/>
|
|
<node CREATED="1681521294153" ID="ID_718588107" MODIFIED="1681521306565" TEXT="Mittel der Bewegung ist der JobTIcket::ExplorationState"/>
|
|
</node>
|
|
<node CREATED="1681513818806" HGAP="30" ID="ID_839385817" MODIFIED="1681514365078" TEXT="JobTicket">
|
|
<linktarget COLOR="#5e5972" DESTINATION="ID_839385817" ENDARROW="Default" ENDINCLINATION="-60;-5;" ID="Arrow_ID_1889540359" SOURCE="ID_947997771" STARTARROW="None" STARTINCLINATION="-23;5;"/>
|
|
<node CREATED="1681521333950" ID="ID_1882410873" MODIFIED="1681521341316" TEXT="ist ein passiver Bauplan"/>
|
|
<node CREATED="1681521341799" ID="ID_1831867258" MODIFIED="1681521349882" TEXT="wird on-demand konkretisiert"/>
|
|
<node CREATED="1681521357484" ID="ID_633522131" MODIFIED="1681521366470" TEXT="kolaboriert mit einem aktiven ExplorationState"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681168811429" ID="ID_72728251" MODIFIED="1681168821401" TEXT="Aufräum-Arbeiten">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681519830697" ID="ID_1168919012" MODIFIED="1681519846021" TEXT="Nomenklatur unscharf">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1681519851664" ID="ID_1426982855" MODIFIED="1681519854742" TEXT="Engine-Service">
|
|
<node CREATED="1681519855695" ID="ID_1479404578" MODIFIED="1681519922674" TEXT="„die Renderengine“ ⟷ »renderConfig«"/>
|
|
<node CREATED="1681519892562" ID="ID_1833190140" MODIFIED="1681519916866" TEXT="die gleiche Closure heißt aber auch »engineCallback«"/>
|
|
</node>
|
|
<node CREATED="1681596404095" ID="ID_582234271" MODIFIED="1681596416421" TEXT="„nominal time“">
|
|
<node CREATED="1681596418090" ID="ID_1704128775" MODIFIED="1681596439782" TEXT="die Bedeutung von „nominal“ ist zweifelhaft"/>
|
|
<node CREATED="1681596470078" ID="ID_184267509" MODIFIED="1681596498936" TEXT="es ist nicht »wall clock time« — aber welche Zeitachse ist es dann?"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681168823213" ID="ID_70139544" MODIFIED="1681168829891" TEXT="LinkedElements">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681168834655" ID="ID_775810104" MODIFIED="1681168886034" TEXT="Kompatibilität mit STL verifizieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1681168847009" ID="ID_394142249" MODIFIED="1681168879417" TEXT="sehe schon: man kann es als std::stack nutzen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681168860231" ID="ID_1896352742" MODIFIED="1681168874166" TEXT="was ist mit dem Allocator? ist der Standard-konform?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681168890963" ID="ID_734971500" MODIFIED="1681168935363" TEXT="varargs durch variadic-templates ersetzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verwendet noch den pre-C++11-Stil mit explizit ausgewalzten Template-Spezialisierungen für 1...5 Argumente
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681168945643" ID="ID_927049684" MODIFIED="1681168962346" TEXT="Verhältnis zum AllocationCluster klären">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681168963297" ID="ID_16461379" MODIFIED="1681168972656" TEXT="warum wird der hier explizit referenziert?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681169265752" ID="ID_388188594" MODIFIED="1681169268100" TEXT="JobTicket">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681169270184" ID="ID_778864690" MODIFIED="1681169283728" TEXT="die schon gecodete Logik sieht sehr nach Skizze aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681169286078" ID="ID_514995150" MODIFIED="1681169634256" TEXT="Datenstrukturen konsistent?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
requirement_ als (single)linked-List <i>RLY?</i>
|
|
</li>
|
|
<li>
|
|
SubTicketStack wirklich schon gut durchdacht? Funktionsweise?
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681169607062" ID="ID_62995786" MODIFIED="1681169631536" TEXT="Auswertungs-Logik mit pullNext() / push()">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681425106274" ID="ID_897788253" LINK="#ID_274575596" MODIFIED="1681425285122" TEXT="engine::Job und engine::Activity neu konzipieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681007001033" ID="ID_777825192" MODIFIED="1681007003617" TEXT="Dispatcher">
|
|
<node CREATED="1681007004517" ID="ID_1144293741" MODIFIED="1681007079690" TEXT="Interface ist skizziert">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681007017379" ID="ID_1043419721" MODIFIED="1681007024046" TEXT="zwei von drei Operationen sind klar">
|
|
<node CREATED="1681007281927" ID="ID_1103925874" MODIFIED="1681007293626" TEXT="JobBuilder konstruieren (Innere Klasse mit Rückreferenz)"/>
|
|
<node CREATED="1681007297495" ID="ID_839377934" MODIFIED="1681007348145">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Impl: <font face="Monospaced" color="#232d7c">JobBuilder::relativeFrameLocation (TimeAnchor&, FrameCnt)</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1681007367996" ID="ID_443275992" MODIFIED="1681007420359" TEXT="callback in Dispatcher::locateRelative()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">      /** core dispatcher operation: based on the coordinates of a reference point, </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">       *  establish binding frame number, nominal time and real (wall clock) deadline. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">       * @return new FrameCoord record (copy), with the nominal time, frame number </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">       *         and deadline adjusted in accordance to the given frame offset. </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">       */ </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">      virtual FrameCoord locateRelative (FrameCoord const&, FrameCnt frameOffset)  =0; </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681007375147" ID="ID_78887544" MODIFIED="1681007379315" TEXT="konkrete Impl fehlt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681007024520" ID="ID_387260351" MODIFIED="1681007033261" TEXT="es gibt dispatcher-interface-test.cpp">
|
|
<node CREATED="1681007105255" ID="ID_1477266939" MODIFIED="1681007112555" TEXT="compiliert"/>
|
|
<node CREATED="1681007136643" ID="ID_1804418785" MODIFIED="1681007149302" TEXT="halbfertig und partiell auskommentiert"/>
|
|
<node CREATED="1681007112998" ID="ID_534129946" MODIFIED="1681007156292" TEXT="läuft (vermutlich) noch überhaupt nicht"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681007034731" ID="ID_380471864" MODIFIED="1681007071540" TEXT="Implementierung (dispatcher-table) nur gestubbed">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681425423695" ID="ID_1928295133" MODIFIED="1681685384037" TEXT="Reorganisation : RenderDrive verwenden">
|
|
<linktarget COLOR="#f4fec9" DESTINATION="ID_1928295133" ENDARROW="Default" ENDINCLINATION="-1068;-69;" ID="Arrow_ID_362199078" SOURCE="ID_1888344503" STARTARROW="None" STARTINCLINATION="1381;58;"/>
|
|
<linktarget COLOR="#ffe4c9" DESTINATION="ID_1928295133" ENDARROW="Default" ENDINCLINATION="-724;353;" ID="Arrow_ID_1773297165" SOURCE="ID_845968912" STARTARROW="None" STARTINCLINATION="-257;23;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681597653622" ID="ID_1608883275" MODIFIED="1681597683317" TEXT="Eigenschaften">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...erschlossen aus den bestehenden Strukturen + der neuen Intention
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#5b280f" CREATED="1681597684802" ID="ID_1406063015" MODIFIED="1681683228188" TEXT="kleines Value-Parameter-Objekt">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1681598452915" ID="ID_573477354" MODIFIED="1681598473868" TEXT="ist der aktive Kern im Calcstream"/>
|
|
<node CREATED="1681598513826" ID="ID_1817819165" MODIFIED="1681598599379" TEXT="konstituiert eine Prozeß-Instanz-Identität"/>
|
|
<node CREATED="1681683275337" ID="ID_1515003010" MODIFIED="1681683297990" TEXT="berwirkt repetitive Selbst-Aktivierung"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681598877348" ID="ID_789757597" MODIFIED="1681683172391" TEXT="zu klären">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1681598885498" ID="ID_1614960356" MODIFIED="1681598899763" TEXT="Redundanz / Überschneidung mit dem CalcStream">
|
|
<node CREATED="1681598901535" ID="ID_1286823970" MODIFIED="1681599043639" TEXT="beide haben auffällig ähnliche Eigenschaften">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
repräsentieren eine parameter-basierte Instanz-Identität
|
|
</li>
|
|
<li>
|
|
sind jeweils voll kopierbare Wertobjekte
|
|
</li>
|
|
<li>
|
|
benötigen zudem eine Dependency-Injection
|
|
</li>
|
|
<li>
|
|
gespeichert im Play-Process und damit in der »Prozess-Tafel«
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681599056122" ID="ID_458680948" MODIFIED="1681646642507" TEXT="Unterscheidung aus logischen/semantsichen Gründen eingeführt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Der CalcStream ist eben das, also ein Organisationsmerkmal bzw. die Identität eines Teilprozesses
|
|
</li>
|
|
<li>
|
|
Der RenderDrive soll ein zyklischer Mechanismus sein, und als JobFunctor genutzt werden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681599191305" ID="ID_1167449829" MODIFIED="1681599208482" TEXT="benötigte Dependency-Injection ">
|
|
<node CREATED="1681599223716" ID="ID_86738790" MODIFIED="1681599346318" TEXT="Timings (impliziert Frame-Grid)"/>
|
|
<node CREATED="1681599210089" ID="ID_684433972" MODIFIED="1681599218026" TEXT="Zugang zum Dispatcher"/>
|
|
<node CREATED="1681599257945" ID="ID_733064533" MODIFIED="1681599268652" TEXT="Zugang zum Scheduler"/>
|
|
</node>
|
|
<node CREATED="1681646460442" ID="ID_866977884" MODIFIED="1681646477449" TEXT="multiplicity and usage structure">
|
|
<node CREATED="1681646502158" ID="ID_1554914113" MODIFIED="1681646512969" TEXT="die Planungs-Pipeline wird strikt sequentiell bespielt"/>
|
|
<node CREATED="1681646532062" ID="ID_1383559792" MODIFIED="1681646551375" TEXT="es gibt nur einen Drive pro CalcStream"/>
|
|
<node CREATED="1681646829918" ID="ID_284324155" MODIFIED="1681646835657" TEXT="nur minimlae bewegliche Teile"/>
|
|
<node CREATED="1681646836533" ID="ID_1000053188" MODIFIED="1681646846261" TEXT="könnte im Heap sitzen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681646866174" ID="ID_246853832" MODIFIED="1681646885323" TEXT="⟹ Struktur">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681646891090" ID="ID_1766076946" MODIFIED="1681683127682" TEXT="non-copyable Heap-alloziert">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681646907319" ID="ID_682236351" MODIFIED="1681683367234" TEXT="wird per smart-ptr gemanaged">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681683094086" ID="ID_1384696790" MODIFIED="1681690034337" TEXT="beherbergt die Planungs-Pipeline">
|
|
<arrowlink COLOR="#fd4259" DESTINATION="ID_1735556854" ENDARROW="Default" ENDINCLINATION="20;-71;" ID="Arrow_ID_91051045" STARTARROW="None" STARTINCLINATION="-206;16;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681646916186" ID="ID_806901618" MODIFIED="1681683127683" TEXT="wird erstellt aus">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681646926897" ID="ID_1301053260" MODIFIED="1681646934364" TEXT="CalcStream-Kenndaten">
|
|
<node CREATED="1681646935872" ID="ID_1191393929" MODIFIED="1681646959241" TEXT="Timings&"/>
|
|
<node CREATED="1681646946919" ID="ID_1576152420" MODIFIED="1681646966921" TEXT="ModelPort + channel"/>
|
|
</node>
|
|
<node CREATED="1681646971664" ID="ID_524941672" MODIFIED="1681646985378" TEXT="Environment-Resourcen">
|
|
<node CREATED="1681646987124" ID="ID_147954437" MODIFIED="1681647202903" TEXT="bereitgestellt für Render-Quality">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein Play/Renderprozeß wird mit einer definiten Quality-of-Service-Strategie aufgebaut; daraus ergibt sich implizit, was benötigt wird — und das ist ein sehr erweiterungsfähiges Konzept: beispielsweise könnte man das auf die Verfügbarkeit gewisser Klassen von Mediendaten erweitern, und es müßten somit nicht alle Daten immer direkt greifbar sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681646998860" ID="ID_375377074" MODIFIED="1681647365953" TEXT="garantiert Verfügbarkeit der Ressourcen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mit der Erstellung eines CalcStream geht die Zusage einher, alle benötigten Resourcen tatsächlich im geforderten Maß verfügbar zu haben; diese Zusage mündet in die Übersetzung in eine abstrahierte RenderEnvironmentClosure; dahinter können sehr weitreichende Dispositionen verborgen sein, z.B. verteilte Resourcen in einem Render-Cluster/Netwerk-Setup, oder spezielle Hardware
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681647059168" ID="ID_403042221" MODIFIED="1681647527409" TEXT="steteless + fail-Fast">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Zusage ist verbindlich und ohne zeitliche Parametrisierung; sollte eine Resource wegbrechen, so läßt man sofort den btr. Renderprozeß zusammenbrechen und markiert ihn als schadhaft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681647531976" ID="ID_438278550" MODIFIED="1681683133041" TEXT="ist selber ein JobFunktor">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1681647578298" ID="ID_328838794" MODIFIED="1681647594158" TEXT="usage-constraints werden grundsätzlich implizit gehandhabt">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1681647609917" ID="ID_1941277429" MODIFIED="1681647652741" TEXT="hat bereits alle operativen Dependencies fertig injiziert"/>
|
|
<node CREATED="1681647654353" ID="ID_1685443734" MODIFIED="1681647671007" TEXT="einziger beweglicher Parameter: die Start-Framenummer"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681689961426" ID="ID_1735556854" MODIFIED="1681690034338" TEXT="was wird dann aber aus dem Dispatcher?">
|
|
<linktarget COLOR="#fd4259" DESTINATION="ID_1735556854" ENDARROW="Default" ENDINCLINATION="20;-71;" ID="Arrow_ID_91051045" SOURCE="ID_1384696790" STARTARROW="None" STARTINCLINATION="-206;16;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681689971576" ID="ID_497495407" MODIFIED="1681690040742">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieser wird nun mehr und mehr <i>entkernt....</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681690048013" ID="ID_800389319" MODIFIED="1681690224577" TEXT="sieht aktuell mehr aus wie eine Facade zur Fixture">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das kommt nicht von ungefähr; schon im Entwurf von 2012 sollte ja <font color="#331eb5" face="Monospaced">Dispatcher</font>  ein Interface sein, und die aktuelle Implementierung wäre eine  <font color="#331eb5" face="Monospaced">DispatchTable</font>, die direkt in der Fixture angesiedelt und gemanaged würde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681690087200" ID="ID_14312341" MODIFIED="1681690107889" TEXT="folglich wird dieser Teil komplett entkoppelt von »der Engine«"/>
|
|
<node CREATED="1681690260176" ID="ID_1829278703" MODIFIED="1681690292694" TEXT="aber er sollte per DependencyInjection eingebracht werden (‣ EngineService)"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741481500" ID="ID_384450703" MODIFIED="1681741489593" TEXT="Dispatcher-Interface neu definieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741493272" ID="ID_1834962194" MODIFIED="1681741499888" TEXT="der Builder fällt weg">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741503343" ID="ID_852301467" MODIFIED="1681741508391" TEXT="Services">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741523181" ID="ID_1358920776" MODIFIED="1681741643557" TEXT="FrameCoord locateRelative (FrameCoord, frameOffset)">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1681741644460" ID="ID_498811202" MODIFIED="1681741652180" TEXT="schon implementiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741652742" ID="ID_615819221" MODIFIED="1681741657891" TEXT="überprüfen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681741589427" ID="ID_1281351405" MODIFIED="1681741634102" TEXT="bool isEndOfChunk (frame, ModelPort)">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681741635654" ID="ID_1118664905" MODIFIED="1681741641217" TEXT="fraglich ob noch benötigt"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741688503" ID="ID_1430371522" MODIFIED="1681741803819" TEXT="JobTicket& accessJobTicket (TimeValue nominalTime, ModelPort, channel)">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1681741883229" ID="ID_15002134" MODIFIED="1681741890812" TEXT="Front-End: getJobTicketFor (FrameCoord)">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681741893771" ID="ID_1417028935" MODIFIED="1681741951224" TEXT="eigentliche Impl fehlt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742238869" ID="ID_1876795011" MODIFIED="1681742244980" TEXT="Planungs-Pipeline aufbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681742255171" ID="ID_1531898349" MODIFIED="1681744077783" TEXT="Draft im Test-Setup">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742836996" ID="ID_1978512771" MODIFIED="1681742860339" TEXT="scaffolding and mocking used for this test">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681742863121" ID="ID_101929835" MODIFIED="1681742878203" TEXT="benötigte Mocks">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682611217967" ID="ID_792021380" MODIFIED="1682611222829" TEXT="Segmentation">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742879175" ID="ID_1375353236" MODIFIED="1681742901348" TEXT="Dispatcher">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681743458393" ID="ID_891681445" MODIFIED="1681743469323" TEXT="extrahieren aus DispatcherInterface_test"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742890385" ID="ID_1681918468" MODIFIED="1681742901349" TEXT="JobTicket">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681775901704" ID="ID_1011961716" MODIFIED="1681775914876" TEXT="muß Prerequisite-Struktur von weiteren JobTIckets bieten"/>
|
|
<node CREATED="1681775915726" ID="ID_723266604" MODIFIED="1681775925599" TEXT="diese müssen irgendwo in Storage gehalten werden"/>
|
|
<node CREATED="1681775956207" ID="ID_403116999" MODIFIED="1681775974479" TEXT="idealerweise kann der Test diese Stuktur in Grenzen selber vorgeben">
|
|
<node CREATED="1681776011645" ID="ID_398083887" MODIFIED="1681776024883" TEXT="das wäre eine DSL...">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1681776041364" ID="ID_581175494" MODIFIED="1681832931895" TEXT="man könnte GenNode nutzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...bevor ich jetzt anfange, eine symbolische Notation und einen Parser zu erfinden, wäre ein einfache Konvetion für <i>structured data</i>  wohl sinnvoller; dann könnte man die Builder-Notation für GenNode nutzen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#fef7d1" DESTINATION="ID_1664606019" ENDARROW="Default" ENDINCLINATION="139;-4;" ID="Arrow_ID_1184218305" STARTARROW="None" STARTINCLINATION="13;150;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681776275452" ID="ID_952967108" MODIFIED="1681776292134" TEXT="damit würde hier sogar eine Art Mock-Fixture gebaut">
|
|
<node CREATED="1681776316175" ID="ID_814536760" MODIFIED="1681776323218" TEXT="1.Ebene: Segmentation"/>
|
|
<node CREATED="1681776335491" ID="ID_1866146614" MODIFIED="1681776353238" TEXT="jedes Element: ein JobTicket"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742895901" ID="ID_594113874" MODIFIED="1681742901350" TEXT="Test-Job">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681777299523" ID="ID_252686764" MODIFIED="1681777342528" TEXT="alle Test-Jobs verwenden einen einzigen Funktor"/>
|
|
<node CREATED="1681777343685" ID="ID_572811753" MODIFIED="1681777357938" TEXT="dieser beherbergt ein TestLog"/>
|
|
<node CREATED="1681777358683" ID="ID_768023482" MODIFIED="1681777393914" TEXT="er kann aber mit einem Adapter speziell markiert werden"/>
|
|
<node CREATED="1681777394886" ID="ID_1582494030" MODIFIED="1681777440923" TEXT="bei Aufruf loggt der Job diese spezilelle Marke + gegebene Frame-Koord"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681831353728" ID="ID_1982624809" MODIFIED="1681831371808" TEXT="längerfristig: DummyPlayConnection ausbauen">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1681831376448" ID="ID_1561067125" MODIFIED="1681831389254" TEXT="dort soll eine integrierte Dummy-Fixture entstehen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1681832399136" ID="ID_1606283048" MODIFIED="1681832419154" TEXT="diese baut auf den Test-Hilfsmitteln auf (die wir hier entwickeln)"/>
|
|
<node CREATED="1681832422005" ID="ID_1203832652" MODIFIED="1681832531957" TEXT="aber: das ist mehr ein Konfigurations Front-end">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den skizzierten, wie üblich weitreichenden Plänen gemäß kann mit erheblicher Komplexität gerechnet werden; es erscheint daher angemessen, die eigentlichen Mock-Bausteine separat nutzbar zu halten und die DummyPlayConnection zur Orchestrierung des jeweiligen Test-Setup zu verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681832844221" ID="ID_826966768" MODIFIED="1681832848268" TEXT="Aufbau">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1681832851795" ID="ID_1453467501" MODIFIED="1681832896408" TEXT="vom MockJobTicket aus beginnen...">
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681832899812" ID="ID_1664606019" MODIFIED="1682047865205" TEXT="GenNode-basierter Implementierungs-Kern">
|
|
<linktarget COLOR="#fef7d1" DESTINATION="ID_1664606019" ENDARROW="Default" ENDINCLINATION="139;-4;" ID="Arrow_ID_1184218305" SOURCE="ID_581175494" STARTARROW="None" STARTINCLINATION="13;150;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#338800" CREATED="1681833031252" HGAP="29" ID="ID_1232985944" MODIFIED="1682953126289" TEXT="leer" VSHIFT="14">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681833034545" ID="ID_1378629902" MODIFIED="1681833049605" TEXT="rekursiv mit Prerequisite">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682205060282" ID="ID_290012620" MODIFIED="1682205066370" TEXT="mehrere Segmente">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682419270798" ID="ID_1327152864" MODIFIED="1682419278493" TEXT="#1294 prototype / mock fixture components">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682419302874" ID="ID_1541946258" MODIFIED="1682419591486" TEXT="Den Knoten auflösen ⟹ Prototyping">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich steck mit dem Entwurf fest,
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
weil ein deduktives Interface-Design gefährlich wäre
|
|
</li>
|
|
<li>
|
|
aber ich keine ausgearbeiteten Details für einen induktiven Zugang habe
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Daher gehe ich von der bis jetzt entwickelten Architekturskizze aus, und baue zunächst ein System von Mock-Implementierungen bottom-up; auf dieser Basis kann ich dann (hoffentlich) in die Konstruktion der Engine eindringen, um so erst die Basis zu schaffen für eine realistische Beurteilung der Möglichkeiten und Anforderungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1682419339405" ID="ID_1304787492" MODIFIED="1682419598749" TEXT="erst mal schön „hexagonale“ Mocks aufbauen">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1682419357534" ID="ID_784932569" MODIFIED="1682419600859" TEXT="aus diesen die Interfaces gewinnen">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1682419367267" ID="ID_426837392" MODIFIED="1682419603503" TEXT="dann die „hexagonalen Räder“ rund schleifen">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682611316697" ID="ID_296140708" MODIFIED="1682614014464" TEXT="Vorschau auf die Fixture-Datenstruktur">
|
|
<arrowlink COLOR="#735061" DESTINATION="ID_1136070257" ENDARROW="Default" ENDINCLINATION="-651;-968;" ID="Arrow_ID_1804652676" STARTARROW="None" STARTINCLINATION="-518;37;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1682613713646" ID="ID_1897977418" MODIFIED="1682613726321" TEXT="läuft auf eine Doppel-Hülle hinaus"/>
|
|
<node CREATED="1682613727302" ID="ID_1816573739" MODIFIED="1682613737271" TEXT="wir implementieren im Moment nur einen Level"/>
|
|
<node CREATED="1682613738020" ID="ID_3577348" MODIFIED="1682613823627" TEXT="⟹ Konsequenzen">
|
|
<node CREATED="1682613762760" ID="ID_970667296" MODIFIED="1682613815597" TEXT="Datenstruktur kann (bedenkenlos) direkt manipuliert werden">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682613782480" ID="ID_178794461" MODIFIED="1682614001907" TEXT="Split-and-Splice-Operation implementieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das wird dann später die Basis für die Implementierung des Change-Builders
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
diese Operation untersucht die bestehende Segmentation
|
|
</li>
|
|
<li>
|
|
und spaltet bestehende Segmente auf
|
|
</li>
|
|
<li>
|
|
sie kann unterscheiden zwischen Umbau(=replacement) und Kürzen bzw. Klonen eines Segments
|
|
</li>
|
|
<li>
|
|
Schlußfolgerung: ein Segment selbst darf nichts über seine Zeitspanne wissen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682384630010" ID="ID_1719484347" MODIFIED="1682385357439" TEXT="Struktur">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1682384645189" ID="ID_384048903" MODIFIED="1682384657607" TEXT="1 Record pro Segment">
|
|
<node CREATED="1682384866271" ID="ID_1100765917" MODIFIED="1682384873170" TEXT="start=Time"/>
|
|
<node CREATED="1682384873831" ID="ID_11801580" MODIFIED="1682384878098" TEXT="after=Time"/>
|
|
</node>
|
|
<node CREATED="1682384687176" ID="ID_610330883" MODIFIED="1682385008647" TEXT="das Haupt-Job-Ticket wird damit identifiziert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das mache ich ganz bewußt, um die Notation intuitiver lesbar zu machen. Tatsächlich ist der Unterschied zwischen Segment und zugehörigem JobTicket nur formaler oder systematischer Natur; es sind eben zwei verschiedene Entitäten, aber sie korrelieren 1:1 und repräsentieren lediglich eine unterschiedliche Sicht auf die gleiche Sache — denn ein Segmeint ist genau dadurch definiert, daß die Verarbeitungs-Pipeline konstant ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682385755668" ID="ID_192114797" MODIFIED="1682385838716" TEXT="ein leerer Record definiert bereits ein JobTicket">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die Sache so einfach wie möglich halten, und keine spezielle ID-Logik nur für die Tests erfinden!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1682385844965" ID="ID_1297348837" MODIFIED="1682385858720" TEXT="mark=<int>"/>
|
|
<node CREATED="1682385860578" ID="ID_1867818480" MODIFIED="1682385868229" TEXT="optional, sonst was Zufälliges"/>
|
|
</node>
|
|
<node CREATED="1682384701245" ID="ID_621302512" MODIFIED="1682384816595" TEXT="nested Records für Prerequisites">
|
|
<node CREATED="1682385047640" ID="ID_1371682614" MODIFIED="1682385052546" TEXT="sie liegen im Scope"/>
|
|
<node CREATED="1682385053111" ID="ID_285349039" MODIFIED="1682385061769" TEXT="Reihenfolge ist zu erhalten"/>
|
|
<node CREATED="1682385069872" ID="ID_1300373934" MODIFIED="1682385080052" TEXT="dabei aber noch sortiert nach Channel"/>
|
|
</node>
|
|
<node CREATED="1682384817342" ID="ID_1041945883" MODIFIED="1682385604629" TEXT="Channel-Zuordnung nur per Filter/Marker">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ich bin weiterhin noch nicht davon überzeugt, daß die Differenzierung in Channel überhaupt notwendig und hilfreich ist; aber ich kann das derzeit nicht belegen ⟹ daher spiele ich das Thema erst mal herunter
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681833071385" ID="ID_1107925235" MODIFIED="1681833077742" TEXT="MockJob hinterlegen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1682036849793" ID="ID_1932533229" MODIFIED="1682047342244" TEXT="MockJob aufrufen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1682041035913" ID="ID_755113791" MODIFIED="1682047265222" TEXT="dann doch vielleicht besser den bestehenden DummyJob nehmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682047266117" ID="ID_435343452" MODIFIED="1682047333709" TEXT="zusätzliche Accessoren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1682047285995" ID="ID_1230929061" MODIFIED="1682047293130" TEXT="den JobFunktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682047278699" ID="ID_1344827300" MODIFIED="1682047293960" TEXT="die weiteren Invocation-Parameter">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1682047294527" ID="ID_180549719" LINK="#ID_689625560" MODIFIED="1682047331605" TEXT="dabei nochmal über den Sinn der InvocationInstanceID nachgedacht">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682036866495" ID="ID_901931862" MODIFIED="1682047344590" TEXT="MockJob verifizieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1682047349883" ID="ID_840362221" MODIFIED="1682047412550" TEXT="neues Feature: Systemzeit „grad eben“">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
definiert als: weniger als 1ms in der Vergangenheit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682047394076" ID="ID_1279848807" MODIFIED="1682047409293" TEXT="RealClock::wasRecently()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682047415969" ID="ID_1003810847" MODIFIED="1682047424039" TEXT="die anderen Parameter mit Zufallswerten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682204997554" ID="ID_599701197" MODIFIED="1682205023588" TEXT="Prerequisites hinzufügen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682868258074" ID="ID_1743148920" MODIFIED="1682898174253" TEXT="Job aus Ticket erstellen und ausführbar machen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1682885817579" ID="ID_1080671855" MODIFIED="1682886037986" TEXT="Hash für Zeitwerte definieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Verwende eine halb-Rotation über size_t ⟹
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
die beiden Hälften des Bitstring der µ-ticks werden vertauscht
|
|
</li>
|
|
<li>
|
|
damit erheblicher Abstand zwischen konsekutiven Werten
|
|
</li>
|
|
<li>
|
|
hash² ≡ id
|
|
</li>
|
|
<li>
|
|
impl sollte i.d.R. nach inlining eine einzige Assembler-Instruktion sein ⟶ https://stackoverflow.com/a/31488147
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682885599653" ID="ID_1110668206" LINK="#ID_444576509" MODIFIED="1682885796274" TEXT="erster Entwurf der Hash-Verkettung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682885673339" ID="ID_1525753166" MODIFIED="1682885692857" TEXT="Instance-Hash: hier den Seed einfach durchreichen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682890776694" ID="ID_1533405151" MODIFIED="1682898136722" TEXT="NOP-Job Stub">
|
|
<linktarget COLOR="#7b88b2" DESTINATION="ID_1533405151" ENDARROW="Default" ENDINCLINATION="-1179;197;" ID="Arrow_ID_1853160081" SOURCE="ID_10757245" STARTARROW="None" STARTINCLINATION="445;-24;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1682890841485" ID="ID_774211693" MODIFIED="1682890856303" TEXT="für den Fall JobTicket::NIL"/>
|
|
<node COLOR="#338800" CREATED="1682898128631" ID="ID_1765265251" MODIFIED="1682898138153" TEXT="per lib::Depend einbinden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682898161611" ID="ID_98710848" MODIFIED="1682898165898" TEXT="im Test verifiziert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#5b280f" CREATED="1682627654491" ID="ID_1371147624" MODIFIED="1682948581383" TEXT="Marker definieren und sichtbar machen">
|
|
<linktarget COLOR="#48417c" DESTINATION="ID_1371147624" ENDARROW="Default" ENDINCLINATION="-48;56;" ID="Arrow_ID_1753796050" SOURCE="ID_1110039315" STARTARROW="None" STARTINCLINATION="-284;-8;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682641810117" ID="ID_596391717" MODIFIED="1682641823784" TEXT="Problem: wie integieren?">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1682641827594" ID="ID_361324923" MODIFIED="1682641841154" TEXT="JobTicket selber hat keine VTable">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist gut so
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682641932932" ID="ID_554797446" MODIFIED="1682642480303" TEXT="das gehört damit eigentlich in den JobFunktor">
|
|
<node CREATED="1682641950985" ID="ID_775736069" MODIFIED="1682641959993" TEXT="denn der wird vermutlich ein generischer Baustein"/>
|
|
<node CREATED="1682641960512" ID="ID_1052805185" MODIFIED="1682641969181" TEXT="und könnte dann auf die ProcNode delegieren"/>
|
|
</node>
|
|
<node CREATED="1682642490281" ID="ID_1787652965" MODIFIED="1682642992889">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#e62222">ärgerliche Konsequenz</font>: bekomme <b>viele Instanzen</b> vom JobFunktor
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1682691820105" ID="ID_405339335" MODIFIED="1682691853870" TEXT="stattdessen: vom JobFunktor den konstanten Teil berechnen lassen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1682718443540" ID="ID_116215580" MODIFIED="1682718589879" TEXT="es genügt, den Marker/Seed zu bestätigen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ich darf nicht daran hängenbleiben, daß der Marker literal in der InvocationInstanceID steckt; das mit der Uniton ist ohnehin nur ein temporärer Trick und kann nicht dauerhaft so bleiben — vielmehr ist die Lösung, den chained-Hash-Mechanismus für den Test so umzufunktionieren, daß man mit ihm beweisen kann, daß ein ganz bestimmter Job auch aufgerufen wurde.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1682805859751" ID="ID_1020214107" MODIFIED="1682805886125" TEXT="es gibt zwei Implementierungen">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1682805888320" ID="ID_1779572309" MODIFIED="1682805905593" TEXT="und es ist derzeit unklar, ob das so bleibt...."/>
|
|
<node CREATED="1682805906307" ID="ID_308580099" MODIFIED="1682806098603" TEXT="bisher gibt es schon den DummyJob">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...mit dem man zufällige pseudo-Invocations erzeugen kann und diese auch später mithilfe eines statischen Invocation-Log verifizieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682807066972" ID="ID_1766437793" MODIFIED="1682808824748" TEXT="nun kommt die Konstruktion mit dem MockTicket dazu">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und die setzt auf die für später tatsächlich vorgesehene Hash-Verknüpfung auf, welche <i>in diesem Fall auch die nominelle Zeit </i>in die InvocationInstanceID mit einrechnet — nicht jedoch die reale Deadline (die in der Job-Instanz explizit vermerkt ist)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1682808327555" ID="ID_782813898" MODIFIED="1682808633170" TEXT="Job-Invocation ist derzeit noch weitgehend ungeklärt">
|
|
<arrowlink COLOR="#b75269" DESTINATION="ID_1713196934" ENDARROW="Default" ENDINCLINATION="-871;-27;" ID="Arrow_ID_865176706" STARTARROW="None" STARTINCLINATION="-1263;70;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682941524301" ID="ID_1050000340" MODIFIED="1682942127658" TEXT="die C-ismen sind problematisch und müssen weg">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bisher wird noch die Fiktion aufrecht erhalten, daß die Basis-Schnittstelle zum Scheduler in reinem C geschrieben ist; tatsächlich ist dadurch so mancher Teil der implementierung grenzwertig bzw. würde tatsächlich mit reinem C nicht (mehr) funktionieren; außerdem bekommen wir mehfrach geschichtete Vererbungen und müssen regelmäßig casten und implizite ungeprüfte Annahmen machen.
|
|
</p>
|
|
<br/>
|
|
<p>
|
|
<i><font color="#f83434">Und das gemischte Setup ist tückisch:</font></i> habe gestern Nacht und heute ein paar Stunden einen Link-Fehler gesucht, der auf ein fehlendes <font face="Monospaced" size="2" color="#1b1981">extern "C" { }</font> zurückging, aber nicht aufgefallen war, solange C++ die Definitionen inlinen konnte...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682948593099" HGAP="-167" ID="ID_924000740" MODIFIED="1682948640643" STYLE="bubble" TEXT="stattdessen: verifizieren" VSHIFT="-5">
|
|
<edge COLOR="#1d699e"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1682205189643" ID="ID_897564380" MODIFIED="1682205211467" TEXT="Problem: Umbau in JobTicket selber blockt">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1682205214637" ID="ID_451342844" MODIFIED="1682205353004" TEXT="kann nicht klar sehen, wie ich einen Marker im MockJob hinterlegen kann">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1682205234442" ID="ID_1168362425" MODIFIED="1682205344594" TEXT="Grund ist...">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1682205280447" ID="ID_1890320289" MODIFIED="1682205280447" TEXT="derzeit reflektiert das JobTicket noch die Monaden-Struktur"/>
|
|
<node CREATED="1682205282092" ID="ID_577681512" MODIFIED="1682205305621" TEXT="und die Abläufe sind daher ziemlich undurchsichtig"/>
|
|
<node CREATED="1682205306451" ID="ID_936014701" MODIFIED="1682715333366" TEXT="die eigentliche Ergebnis/Job-Erzeugung ist dabei halb mit eingewoben"/>
|
|
<node CREATED="1682205329192" ID="ID_1591053369" MODIFIED="1682205341296" TEXT="schwer für einen Test/Mock zu isolieren"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682205419719" ID="ID_806137309" MODIFIED="1682212328035" TEXT="Job createJobFor (FrameCoord) ist noch gar nicht implementiert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1682385376739" ID="ID_576604811" MODIFIED="1682948833179" TEXT="Mock-Implementierung">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1682385392969" ID="ID_1317765253" MODIFIED="1682385456612" TEXT="Storage">
|
|
<node CREATED="1682385491724" ID="ID_1049416610" MODIFIED="1682385544239" TEXT="JobTickets in eine Deque allozieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das erlaubt flexibles Hinzufügen, ohne daß Addressen invalidiert werden. Die Tickets selber müssen NonCopyable sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682385911140" ID="ID_310070879" MODIFIED="1682385934313" TEXT="move-only Mock-Objekt herausgeben">
|
|
<node CREATED="1682385936418" ID="ID_755704146" MODIFIED="1682385951914" TEXT="das ist aber „das Ding selber“"/>
|
|
<node CREATED="1682385963140" ID="ID_1239158970" MODIFIED="1682385993315" TEXT="also MockSegmentation, MockJobTicket,..."/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1682614081119" ID="ID_57760675" MODIFIED="1682948825902" TEXT="Interpretieren der jeweilgen Spec">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1682614092900" ID="ID_1252815318" MODIFIED="1682614105470" TEXT="Basis-Impl: ein Segment gibt es immer"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682614117409" ID="ID_1176991982" MODIFIED="1682614138327" TEXT="splitSplice() implementieren">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1682627110771" ID="ID_183754275" MODIFIED="1682627133820" TEXT="Invariante: lückenlose Abdeckung">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1682985654543" ID="ID_433290925" MODIFIED="1682993072525" TEXT="Algorithmus">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1682987424458" ID="ID_419424512" MODIFIED="1682987433683" TEXT="Invariante">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1682987436544" ID="ID_274517946" MODIFIED="1682987447444" TEXT="vollständige lückenlose Abdeckung der gesamten Zeitachse"/>
|
|
<node CREATED="1682987448551" ID="ID_1538436206" MODIFIED="1682987455003" TEXT="alle Einträge sind aufsteigend sortiert"/>
|
|
</node>
|
|
<node CREATED="1682985661822" ID="ID_851188636" MODIFIED="1682986190931" TEXT="Vorgänger und Nachfolger finden">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1682986432658" ID="ID_792953434" MODIFIED="1682989149768" TEXT="Predecessor">
|
|
<node CREATED="1682986511215" ID="ID_493462626" MODIFIED="1682986543401" TEXT="sep ≔ start oder after (wenn start fehlt)"/>
|
|
<node CREATED="1682986554783" ID="ID_750576553" MODIFIED="1682989185654" TEXT="Pstart >= sep ⟹ ↯ Predecessor"/>
|
|
<node CREATED="1682986826346" ID="ID_727853130" MODIFIED="1682989193099" TEXT="suche größten mit Pstart < sep">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_727853130" ENDARROW="Default" ENDINCLINATION="158;0;" ID="Arrow_ID_1115982284" SOURCE="ID_408822268" STARTARROW="None" STARTINCLINATION="158;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682987368050" ID="ID_1970941364" MODIFIED="1682989212975" TEXT="Succsessor ist erster, der diese Bedingung verletzt"/>
|
|
<node CREATED="1682987507623" ID="ID_395536171" MODIFIED="1682989230851" TEXT="andernfalls: Successor == Predecessor (split)"/>
|
|
</node>
|
|
<node CREATED="1682985733848" ID="ID_1672899650" MODIFIED="1682986193244" TEXT="Start- und Endpunkt festsetzen">
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1682987322728" ID="ID_320248563" MODIFIED="1682987335524" TEXT="definerter start/after-Punkt ist stets verbindlich">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1682987561688" ID="ID_1309770929" MODIFIED="1682987568688" TEXT="fehlernder start">
|
|
<node CREATED="1682987742720" ID="ID_1884018589" MODIFIED="1682987759318" TEXT="sep ≡ after">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1682987571207" ID="ID_571245598" MODIFIED="1682989244395" TEXT="Pend < sep ⟹ start ≔ Pend"/>
|
|
<node CREATED="1682987616722" ID="ID_1354576577" MODIFIED="1682989250339" TEXT="sonst ⟹ start ≔ Pstart (replace or trunc)"/>
|
|
</node>
|
|
<node CREATED="1682987667594" ID="ID_1011955521" MODIFIED="1682987671861" TEXT="fehlender after">
|
|
<node CREATED="1682987742720" ID="ID_408822268" MODIFIED="1682989269792" TEXT="sep ≡ start ∧ Sstart >= sep ">
|
|
<arrowlink DESTINATION="ID_727853130" ENDARROW="Default" ENDINCLINATION="158;0;" ID="Arrow_ID_1115982284" STARTARROW="None" STARTINCLINATION="158;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1682987571207" ID="ID_491456235" MODIFIED="1682989275719" TEXT="Sstart > sep ⟹ after ≔ Sstart"/>
|
|
<node CREATED="1682987616722" ID="ID_548072579" MODIFIED="1682989279922" TEXT="sonst ⟹ after ≔ Send (replace or trunc)"/>
|
|
</node>
|
|
<node CREATED="1682988627722" ID="ID_1905015650" MODIFIED="1682988633654" TEXT="POST">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1682988637176" ID="ID_1261626912" MODIFIED="1682988645668" TEXT="start < after">
|
|
<node CREATED="1682988713966" ID="ID_1690550958" MODIFIED="1682988744556">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sonst ⟹ <b>REJECT</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682988779297" ID="ID_28501272" MODIFIED="1682989283846" TEXT="Pstart <= start"/>
|
|
<node CREATED="1682988911963" ID="ID_1061830050" MODIFIED="1682989418556" TEXT="Pstart == Sstart ∨ start <= Sstart"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682985780238" ID="ID_1935969711" MODIFIED="1682986195716" TEXT="Relation zum Vor/Nachfolger bestimmen">
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1682989072565" ID="ID_574776010" MODIFIED="1682989310210" TEXT="Pstart < start">
|
|
<node CREATED="1682989100107" ID="ID_1303238476" MODIFIED="1682989331640" TEXT="Pend < start ⟹ ins NOP-Predecessor"/>
|
|
<node CREATED="1682989363818" ID="ID_626589766" MODIFIED="1682989412757" TEXT="Pend == start ⟹ seamless"/>
|
|
<node CREATED="1682989432318" ID="ID_1285136346" MODIFIED="1682989453085" TEXT="Pend <= after ⟹ truc(Predecessor)"/>
|
|
<node CREATED="1682989463146" ID="ID_1057868667" MODIFIED="1682990037890" TEXT="Pend > after ⟹ split(Predecessor)">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1057868667" ENDARROW="Default" ENDINCLINATION="192;0;" ID="Arrow_ID_638145525" SOURCE="ID_242314941" STARTARROW="Default" STARTINCLINATION="321;12;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682989518809" ID="ID_994366359" MODIFIED="1682989523086" TEXT="Pstart == start">
|
|
<node CREATED="1682989432318" ID="ID_1069008527" MODIFIED="1682989559145" TEXT="Pend <= after ⟹ del(Predecessor)"/>
|
|
<node CREATED="1682989463146" ID="ID_514650224" MODIFIED="1682989628688" TEXT="Pend > after ⟹ swap_trunc(Predecessor)"/>
|
|
</node>
|
|
<node CREATED="1682989799344" ID="ID_1899821024" MODIFIED="1682989806256" TEXT="Predecessor == Successor">
|
|
<node CREATED="1682989855439" ID="ID_7906079" MODIFIED="1682989886621" TEXT="Pend == after == Time::NEVER ⟹ trunc(Predecessor)"/>
|
|
<node CREATED="1682989964471" ID="ID_242314941" MODIFIED="1682990037890" TEXT="Pend > after ⟹ split(Predecessor)">
|
|
<arrowlink DESTINATION="ID_1057868667" ENDARROW="Default" ENDINCLINATION="192;0;" ID="Arrow_ID_638145525" STARTARROW="Default" STARTINCLINATION="321;12;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682990361746" ID="ID_540769988" MODIFIED="1682990378568" TEXT="Sstart < after">
|
|
<node CREATED="1682990416619" ID="ID_1218355846" MODIFIED="1682990512242" TEXT="Send < after ⟹ del(Successor) and ++Successor and recurse (same base case)"/>
|
|
<node CREATED="1682990517405" ID="ID_1733924563" MODIFIED="1682990537807" TEXT="Send == after ⟹ del(Successor)"/>
|
|
<node CREATED="1682990575017" ID="ID_1792970357" MODIFIED="1682990587208" TEXT="Send > after ⟹ trunc(Successor)"/>
|
|
</node>
|
|
<node CREATED="1682990756277" ID="ID_1049988377" MODIFIED="1682990797692" TEXT="Sstart == after ⟹ seamless"/>
|
|
<node CREATED="1682990800343" ID="ID_744397196" MODIFIED="1682990839270" TEXT="after < Sstart ⟹ ins NOP-Successor"/>
|
|
</node>
|
|
<node CREATED="1682986173785" ID="ID_1746212572" MODIFIED="1682986198143" TEXT="einfügen und löschen">
|
|
<icon BUILTIN="full-4"/>
|
|
<node CREATED="1682991925184" ID="ID_80874811" MODIFIED="1682991934113" TEXT="Predecessor">
|
|
<node CREATED="1682991935183" ID="ID_100248576" MODIFIED="1682991953832" TEXT="trunc ⟹ del"/>
|
|
<node CREATED="1682991959963" ID="ID_1359030638" MODIFIED="1682991991739" TEXT="split ⟹ del"/>
|
|
<node CREATED="1682991992375" ID="ID_1138806541" MODIFIED="1682991996168" TEXT="del ⟹ del"/>
|
|
<node CREATED="1682991997084" ID="ID_1555435391" MODIFIED="1682992007785" TEXT="swap_trunc ⟹ del"/>
|
|
</node>
|
|
<node CREATED="1682992015840" ID="ID_1551079661" MODIFIED="1682992017823" TEXT="Successor">
|
|
<node CREATED="1682992042818" ID="ID_750532199" MODIFIED="1682992082750" TEXT="de++ ⟹ del"/>
|
|
<node CREATED="1682992086602" ID="ID_79310561" MODIFIED="1682992091821" TEXT="trunc ⟹ del"/>
|
|
</node>
|
|
<node CREATED="1682992101946" ID="ID_556573150" MODIFIED="1682992140097" TEXT="insert">
|
|
<node CREATED="1682992189962" ID="ID_981883843" MODIFIED="1682992192417" TEXT="before">
|
|
<node CREATED="1682992193388" ID="ID_230175279" MODIFIED="1682992198623" TEXT="ins NOP-Predecessor"/>
|
|
<node CREATED="1682992206197" ID="ID_1040208552" MODIFIED="1682992381127" TEXT="trunc(Predecessor) ⟹ ins copy Predecessor-shortened-end"/>
|
|
<node CREATED="1682992241669" ID="ID_817365471" MODIFIED="1682992378287" TEXT="split(Predecessor) ⟹ ins copy Predecessor shortened-end"/>
|
|
</node>
|
|
<node CREATED="1682992335801" ID="ID_1805568665" MODIFIED="1682992339549" TEXT="new Segment"/>
|
|
<node CREATED="1682992340041" ID="ID_196520321" MODIFIED="1682992341444" TEXT="after">
|
|
<node CREATED="1682992352925" ID="ID_1724212588" MODIFIED="1682992384559" TEXT="split(Predecessor) ⟹ ins copy Predecessor shortened-start"/>
|
|
<node CREATED="1682992393801" ID="ID_1960696922" MODIFIED="1682992413823" TEXT="swap_trunc(Predecessor) ⟹ ins copy Predecessor shortened-start"/>
|
|
<node CREATED="1682992484030" ID="ID_1216933300" MODIFIED="1682992501055" TEXT="trunc(Successor) ⟹ ins copy Successor shortened-start"/>
|
|
<node CREATED="1682992519007" ID="ID_804784169" MODIFIED="1682992526523" TEXT="ins NOP-Successor"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682993086565" ID="ID_469257294" MODIFIED="1682993090645" TEXT="Implementierung">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682993091685" ID="ID_988617455" MODIFIED="1682993099148" TEXT="systematische Testabdeckung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1682993100755" ID="ID_1651031348" MODIFIED="1682993128370" TEXT="es sind 12 Basis-Fälle">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1682993108314" ID="ID_317827435" MODIFIED="1682993122827" TEXT="hinzu kommt die Variante, daß leere Intervalle zusammengeführt werden"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1682627621082" ID="ID_1110039315" MODIFIED="1682948822157" TEXT="ein Segment hinzufügen">
|
|
<arrowlink COLOR="#48417c" DESTINATION="ID_1371147624" ENDARROW="Default" ENDINCLINATION="-48;56;" ID="Arrow_ID_1753796050" STARTARROW="None" STARTINCLINATION="-284;-8;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682948783048" ID="ID_1811722913" MODIFIED="1682948817094" TEXT="leere Spec">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682948658996" ID="ID_1655049197" MODIFIED="1682948817094" TEXT="einfachste Spec">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682948807668" ID="ID_343017535" MODIFIED="1682948817095" TEXT="zusätzlich mit Marker">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682948677800" ID="ID_1669789277" MODIFIED="1682948685167" TEXT="zwei Segmente">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1682948692446" ID="ID_1376099012" MODIFIED="1682948701915" TEXT="disjunkt"/>
|
|
<node CREATED="1682948687990" ID="ID_691398450" MODIFIED="1682948721008" TEXT="überlappend"/>
|
|
<node CREATED="1682948709980" ID="ID_1056091678" MODIFIED="1682948718791" TEXT="verschachtelt"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682385895644" ID="ID_89969390" MODIFIED="1682385902557" TEXT="Verifikation im Test unterstützen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1682386003212" ID="ID_930954734" MODIFIED="1682386014176" TEXT="gibt die "Mock"-Variante der jeweiligen Objekte heraus"/>
|
|
<node CREATED="1682386015054" ID="ID_1516142014" MODIFIED="1682386033703" TEXT="darauf kann man z.B. die Marker-ID abfragen"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1682386040786" ID="ID_99654376" MODIFIED="1682386162332" TEXT="das ist explizit erst mal eine Skizze">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ich kann an dieser Stelle noch nicht auf die tatsächiche Implementierung vorgreifen, sonst wird das alles ein undurchdringbares Knäuel. Die eigentliche Implementierung muß stark auf Performance optimiert sein, und daher ist die Datenstruktur vermutlich schwierig zu navigieren. Also baue ich hier ganz bewußt erst mal eine Fake-Variante auf, mit einer anderen Implementierung und einer bequemen Datenstruktur
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681839415291" ID="ID_310889374" MODIFIED="1681839523165" TEXT="bestehenden Code nutzbar machen">
|
|
<linktarget COLOR="#fe80b2" DESTINATION="ID_310889374" ENDARROW="Default" ENDINCLINATION="-503;-32;" ID="Arrow_ID_1927639949" SOURCE="ID_697548050" STARTARROW="None" STARTINCLINATION="230;9;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1681839541902" ID="ID_147064800" MODIFIED="1681839551928" TEXT="die Datenstrukturen im JobTicket sind mühsam">
|
|
<node CREATED="1681839553444" ID="ID_1298986941" MODIFIED="1681839563846" TEXT="die intrusive Linked-List ist fragwürdig"/>
|
|
<node CREATED="1681839564362" ID="ID_1371203216" MODIFIED="1681839580980" TEXT="aber Storage muß zwingend lückenlos sein"/>
|
|
<node CREATED="1681839581752" ID="ID_643256358" MODIFIED="1681839603985" TEXT="alternativ wäre daher ein Builder / Subtyp-Ansatz notwendig"/>
|
|
<node CREATED="1681839605783" ID="ID_133261971" MODIFIED="1681839717383" TEXT="dieser wirft auch so seine Probleme auf">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
... vor allem eine zusätzliche Indirektion, deren Wirkung nicht einfach abzuschätzen ist. Die tatsächliche Listenlänge muß letztlich immer irgendwo explizit repräsentiert werden, und wenn man dies in einem Subtyp verbirgt, muß jeder Datenzugriff zwingend einmal durch eine Indirektion laufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839722781" ID="ID_1259093394" MODIFIED="1681839753677" TEXT="also erst mal so belassen">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681839729932" ID="ID_734404270" MODIFIED="1681839744054" TEXT="später nochmal analysieren">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839764807" ID="ID_817794853" MODIFIED="1681839788158" TEXT="der mit eingebaute Stack muß jetzt irgendwie brach liegen bleiben">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1682034742882" ID="ID_944887323" MODIFIED="1682034750820" TEXT="ist kein Problem und stört nicht"/>
|
|
<node CREATED="1682034751416" ID="ID_1279546753" MODIFIED="1682034762907" TEXT="da liegen nur Iterator (Value-Objekte) drauf"/>
|
|
</node>
|
|
<node CREATED="1681839799283" ID="ID_830915873" MODIFIED="1681839807269" TEXT="selbst einfachste Tests brauchen...">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682622337048" ID="ID_1026907820" MODIFIED="1682622340207" TEXT="Storage">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1682622347831" ID="ID_1252057037" MODIFIED="1682622360738" TEXT="für Tests: im MockSegment unterbringen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839808074" ID="ID_389152221" MODIFIED="1681839820464" TEXT="Einstiegspunkt">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681839824481" ID="ID_1782808621" LINK="#ID_1656777068" MODIFIED="1681839924803" TEXT="HA! startExploration könnte überflüssig sein">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681839942912" ID="ID_1045793970" MODIFIED="1681839954754" TEXT="an der Stelle zeigten sich deutlich die inneren Widersprüche"/>
|
|
<node CREATED="1681839958747" ID="ID_506200323" MODIFIED="1681839992513" TEXT="kann mich erinnern, daß ich damals mich dort massiv festgefahren habe">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1681839975059" ID="ID_1105715936" MODIFIED="1681839987192" TEXT="und auch jetzt hab ich schon wieder ein paar Stunden gegrübelt">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681860325369" ID="ID_328096563" MODIFIED="1681860348325" TEXT="muß nun aber JobTicket-Ctor bereitstellen">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681860349394" ID="ID_1525241951" MODIFIED="1681860363389" TEXT="wie definiert man ein JobTicket?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1681860366713" ID="ID_161470410" MODIFIED="1681860416753" TEXT="erste Näherung: eine Spec abliefern">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681860397581" ID="ID_676680756" MODIFIED="1681860411652" TEXT="man kann Provision und Requirements zusammenlegen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681860421530" ID="ID_1550922413" MODIFIED="1682034579135" TEXT="JobTicket braucht aber LinkedElements<Provision>">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#690f14" CREATED="1681860473137" ID="ID_1498832886" MODIFIED="1682034500105" TEXT="den RAII-Populations-ctor nutzen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1681860490289" ID="ID_118026994" MODIFIED="1681860510052" TEXT="erst mal für den Test definieren">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1681860520930" ID="ID_770893349" MODIFIED="1681860570905" TEXT="Provision-Record anlegen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geht nicht: ist privat (und das ist sinnvoll so!)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1681860530027" ID="ID_1039467630" MODIFIED="1681860537190" TEXT="Provision-Record irgendwie bauen"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681860641938" ID="ID_1900625689" MODIFIED="1681860659290" TEXT="AUA! JobTicket übernimmt Ownership">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1681860661257" ID="ID_1274485445" MODIFIED="1681860705389" TEXT="zwar nur ein vorläufiges Problem (OwningHeapAllocated)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1681860689006" ID="ID_160492283" MODIFIED="1681861171511" TEXT="aber dahinter steckt ein konzeptionelles Problem">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und zwar ist die JobTicket-Struktur explizit darauf angelegt, anderweitig erstellte Deskriptoren zu verlinken; das soll so sein aus Performance-Gründen (Cache Locality ⟹ AllocationCluster)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#df2b36" DESTINATION="ID_1071396002" ENDARROW="Default" ENDINCLINATION="317;-20;" ID="Arrow_ID_375386930" STARTARROW="None" STARTINCLINATION="-437;23;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681864684118" ID="ID_1606009220" MODIFIED="1682034587669" TEXT="Spezifikation">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1681864799687" ID="ID_1244549458" MODIFIED="1681864834215" TEXT="Aufzählung Prerequisites"/>
|
|
<node CREATED="1681864758749" ID="ID_941507735" MODIFIED="1681864762804" TEXT="JobFunktor"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681860589211" ID="ID_1071396002" MODIFIED="1681861171511" TEXT="Problem: Allokation für die Provision-Records">
|
|
<linktarget COLOR="#df2b36" DESTINATION="ID_1071396002" ENDARROW="Default" ENDINCLINATION="317;-20;" ID="Arrow_ID_375386930" SOURCE="ID_160492283" STARTARROW="None" STARTINCLINATION="-437;23;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1681860891883" HGAP="24" ID="ID_1751384108" MODIFIED="1681861186918" VSHIFT="7">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die muß definitiv <i>von „wo anders“</i> kommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1681861077210" ID="ID_506364370" MODIFIED="1682034446522" TEXT="sollte die Deskriptoren per pushNew() erzeugen (also emplace...)">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681861418620" ID="ID_1440642182" MODIFIED="1682027038910" TEXT="Spezifikations-Schnittstelle schaffen">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1681861430131" ID="ID_38853136" MODIFIED="1681861501198" TEXT="dort könnte auch das ganze Problem Allokation mit verborgen werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ziel sollte tatsächlich sein, die Komplexitäten mit der Allokation aus dem funktionalen Code heraus zu verbergen; denn dies dient nur dem separaten Belang der Performance
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681946822662" ID="ID_527151044" MODIFIED="1681946836012" TEXT="Form der Schnittstelle noch unklar">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1681946837591" ID="ID_1753359630" MODIFIED="1681947351700" TEXT="zunächst einmal nur getrieben vom Test">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1681946849061" ID="ID_1328735668" LINK="#ID_122410804" MODIFIED="1681947238611" TEXT="die ungeklärte Frage bezüglich Aufteilung pro Medien-Channel">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ist hier relevant, denn dies scheidet eine einfache Funktions/Konstruktor-Schnittstelle aus; wir müssen einen strukturierten Datensatz bereitstellen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681946946288" ID="ID_735321008" LINK="#ID_514995150" MODIFIED="1681947691935" TEXT="überdies ist die interne Repräsentation des top-level fragwürdig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Zunächst wurden LinkedElements lediglich aus Gründen der Konsistenz auch hierfür verwendet. Eine intrusive-single-linked-List mag für die Vernetzung der Prerequisites sinnvoll sein, aber für eine Sprungtafel nach Channel-Nr ließe sich genauso gut eine Array-backed-Implementation konstruieren (vielleicht dann ein neuer Anlauf anstelle der alten Idee des »RefArray« ?)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681947254466" ID="ID_114148381" MODIFIED="1681947340793" TEXT="noch längerfristig unklar wie die Schnittstelle tatsächlich produkiv genutzt werden wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn es wird noch deutlich über dieses PlaybackVerticalSlice hinaus dauern, bis die erste rudimentäre Implementierung des Builders am Start ist — und <i>erst dann gibt es eine praktischen Bezugspunkt für das Design</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1681948120763" ID="ID_750154353" MODIFIED="1681948327526" TEXT="denkbar daß sich das später stets auf eine ProcNode-Referenz reduzieren läßt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...möglicherweise könnte zumindest so der wichtigste Standardfall komplett ohne einen eigens allozierten JobFunktor dargestellt werden — einfach indem alle notwendigen Parameter direkt aus der referenzierten ProcNode gezogen werden. Um diese Möglichkeit abzuschätzen, müßte aber zuerst definiert werden, wie der Übergang zu den Prerequisites konkret im Proc-Node-Graph dargestellt werden: durch spezielle Metadaten? oder durch eine besondere Marker-Node, die wie eine Quelle fungiert?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1681947704128" ID="ID_1307528426" MODIFIED="1682027027824" TEXT="vorläufige Lösung: Iterator über std::tuple">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1681947910447" ID="ID_1183443190" MODIFIED="1681947934893" TEXT="Begründung">
|
|
<node CREATED="1681947935610" ID="ID_218509707" MODIFIED="1681947935610" TEXT="sonst müßten wir hier doch einen Deskriptor-Record-Typ einführen"/>
|
|
<node CREATED="1681947938444" ID="ID_1201610351" MODIFIED="1681947959060" TEXT="und damit einer späteren ausgebauten Builder-Syntax vorgreifen"/>
|
|
<node CREATED="1681947964857" ID="ID_733464382" MODIFIED="1681947997559" TEXT="besser wäre es, das in eine Subklasse zu verschieben"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681948003825" ID="ID_1586450204" MODIFIED="1682034453286" TEXT="Hilfsfunktion: Transformator mit Allokation">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1681961414575" ID="ID_648708446" MODIFIED="1681961436412" TEXT="Argument-Typ validieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681961449442" ID="ID_1664168385" MODIFIED="1681961462617" TEXT="Provision und Prerequisite per Allokator erzeugen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681961464064" ID="ID_647784147" MODIFIED="1682026936579" TEXT="muß Reihenfolge der Linked-List umkehren">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1681961488869" ID="ID_1984454996" MODIFIED="1682026941393" TEXT="Hilfsfunktion in LinkedElements implementieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681961499158" ID="ID_1061765881" MODIFIED="1682026940080" TEXT="Unit-Test hierfür">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1681948057567" ID="ID_923881429" MODIFIED="1682027001897" TEXT="muß zunächst den empty()-Testcase erfüllen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1681948087120" ID="ID_555715675" MODIFIED="1682026994517" TEXT="brauche dazu einen NOP-JobFunktor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1682026957482" ID="ID_637833464" MODIFIED="1682026990813" TEXT="schreibe den bestehenden dummy-job.cpp um">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1682026969063" ID="ID_32615180" MODIFIED="1682026989799" TEXT="verwende eine TestLog-Instanz">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1682026978301" ID="ID_347272426" MODIFIED="1682027065816" TEXT="als Singleton per lib::Depend">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#df2bbd" CREATED="1682027074106" ID="ID_1659411020" MODIFIED="1682027096603" TEXT="tut">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nach zwei Tagen Gewürge....
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681948045301" ID="ID_1777275098" MODIFIED="1681948056012" TEXT="dann Beispiel-Impl für Mock">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839812280" ID="ID_525360569" MODIFIED="1681839820465" TEXT="Iteration">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681840007512" ID="ID_1951568685" MODIFIED="1681840020471" TEXT="ist für LinkedElements bereits fertig implementiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681839815223" ID="ID_864479514" MODIFIED="1681839820465" TEXT="Verifikation">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681840026883" ID="ID_43381502" MODIFIED="1681840070423" TEXT="es gibt eine empty()-Funktion — brauchbar?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742836995" ID="ID_456677168" MODIFIED="1681742856094" TEXT="using a frame step as base tick">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742836996" ID="ID_1790705283" MODIFIED="1681742856095" TEXT="invoke the dispatcher to retrieve the top-level JobTicket">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742836996" ID="ID_1224963303" MODIFIED="1681742856095" TEXT="expander function to explore prerequisite JobTickets">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742836996" ID="ID_1332543018" MODIFIED="1681742856096" TEXT="integration: generate a complete sequence of (dummy)Jobs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742264338" ID="ID_627755845" MODIFIED="1681742273104" TEXT="in RenderDrive überführen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512925253328" ID="ID_922277724" MODIFIED="1681168670386" TEXT="JobTicket">
|
|
<linktarget COLOR="#82597c" DESTINATION="ID_922277724" ENDARROW="Default" ENDINCLINATION="43;-81;" ID="Arrow_ID_941233317" SOURCE="ID_946385163" STARTARROW="None" STARTINCLINATION="-124;34;"/>
|
|
<node CREATED="1681166276225" ID="ID_877524227" MODIFIED="1681166317636" TEXT="ein Execution-Plan gülitg für ein Segment + ModelPort"/>
|
|
<node CREATED="1681167533752" ID="ID_1794156121" MODIFIED="1681167538096" TEXT="Anforderungen">
|
|
<node CREATED="1681167546919" ID="ID_1656777068" MODIFIED="1681239514849" TEXT="startExploration()">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1681239526094" ID="ID_1262163051" MODIFIED="1681239557592" TEXT="redundant">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1681239544411" ID="ID_294349606" MODIFIED="1681239552793" TEXT="nur den Monaden geschuldet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681167559614" ID="ID_1796690712" MODIFIED="1681167566611" TEXT="discoverPrerequisites()">
|
|
<node CREATED="1681239648250" ID="ID_543821327" MODIFIED="1681239654691" TEXT="lazy-on-demand gestartet"/>
|
|
<node CREATED="1681239661863" ID="ID_893985229" MODIFIED="1681239699686" TEXT="liefert Iterator über alle Voraussetzungen"/>
|
|
<node CREATED="1681239735718" ID="ID_464013545" MODIFIED="1681239741761" TEXT="rekursive Tiefensuche"/>
|
|
</node>
|
|
<node CREATED="1681167579899" ID="ID_428564529" MODIFIED="1681167585941" TEXT="createJobFor(FrameCoord)"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681861351924" ID="ID_446140172" MODIFIED="1681861366116" TEXT="Builder-Mechanismus bereitstellen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1681167633659" ID="ID_374689298" MODIFIED="1681167759825" TEXT="abstrakt-referentiell">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es wird das Vorhandensein abstrakt definierter Zustands-Deskriptoren impliziert, deren Sinn der Implementierung vorbehalten bleibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681167647585" ID="ID_1721954285" MODIFIED="1681167652349" TEXT="Prerequisite(s)"/>
|
|
<node CREATED="1681167653769" ID="ID_1301968397" MODIFIED="1681167655572" TEXT="Provision"/>
|
|
<node CREATED="1681167667360" ID="ID_1056088464" MODIFIED="1681167828900" TEXT="(nested) ExplorationState">
|
|
<arrowlink COLOR="#5c74b4" DESTINATION="ID_247185233" ENDARROW="Default" ENDINCLINATION="28;-86;" ID="Arrow_ID_1572923842" STARTARROW="None" STARTINCLINATION="-77;9;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682622153437" ID="ID_524720976" MODIFIED="1682622219250" TEXT="zu klären...">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682622220974" ID="ID_136220191" MODIFIED="1682622223749" TEXT="NIL-Ticket?">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682887222315" ID="ID_786532593" MODIFIED="1682887238132" TEXT="brauche generischen NOP-Job">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682890662127" ID="ID_952568490" MODIFIED="1682890669817" TEXT="#1296 NOP job">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682890725729" ID="ID_10757245" MODIFIED="1682898144599" TEXT="vorerst mal als JobFunctor-Stub implementieren">
|
|
<arrowlink COLOR="#7b88b2" DESTINATION="ID_1533405151" ENDARROW="Default" ENDINCLINATION="-1179;197;" ID="Arrow_ID_1853160081" STARTARROW="None" STARTINCLINATION="445;-24;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1682890675172" ID="ID_1935070165" MODIFIED="1682890762548" TEXT="nicht klar ob das Output-Protokoll einfach "leer" laufen kann">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682626547198" ID="ID_1401129193" MODIFIED="1682626582171" TEXT=" macht ein const JobTicket Sinn?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1682626583859" ID="ID_959446855" MODIFIED="1682626669241" TEXT="zunächst nur aus Gründen der Interface-Logik eingeführt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil Segment inhärent ein mutabler Typ ist (ich denke an das Umbauen und Modifizieren), gibt der reine Access nur ein Segment const& raus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682626596442" ID="ID_627099643" MODIFIED="1682626614602" TEXT="würde darauf hinauslaufen, daß man auf einem const JobTicket keine Planung machen kann"/>
|
|
<node CREATED="1682626675632" ID="ID_1360253646" MODIFIED="1682626692994" TEXT="Alternative: komplett eine Builder-Notation für die Segmentation">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682622228183" ID="ID_1660287725" MODIFIED="1682622235360" TEXT="Redundanz in der Storage?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681167767260" ID="ID_247185233" MODIFIED="1681167820893" TEXT="JobTicket::ExplorationState">
|
|
<linktarget COLOR="#5c74b4" DESTINATION="ID_247185233" ENDARROW="Default" ENDINCLINATION="28;-86;" ID="Arrow_ID_1572923842" SOURCE="ID_1056088464" STARTARROW="None" STARTINCLINATION="-77;9;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512923605740" ID="ID_319280946" MODIFIED="1679783009427" TEXT="Fixture">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679783052390" ID="ID_176106926" MODIFIED="1679783057287" TEXT="gründen">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_176106926" ENDARROW="Default" ENDINCLINATION="-584;114;" ID="Arrow_ID_1229368159" SOURCE="ID_51005656" STARTARROW="None" STARTINCLINATION="-150;36;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680563536655" ID="ID_1180632123" MODIFIED="1680565151548" TEXT="Fixture: einfacher Clip">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_1180632123" ENDARROW="Default" ENDINCLINATION="-985;-61;" ID="Arrow_ID_1052251062" SOURCE="ID_1704865245" STARTARROW="None" STARTINCLINATION="-2243;270;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742004652" ID="ID_806189817" MODIFIED="1681742017755" TEXT="Addressierung ModelPort / ExitNode">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681742024628" ID="ID_1133872595" MODIFIED="1681742050101" TEXT="bis auf welchen Level wird differenziert?">
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742053502" ID="ID_122410804" MODIFIED="1681742065769" TEXT="Idee: auch noch Channel auflösen">
|
|
<icon BUILTIN="idea"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681742068918" ID="ID_1859739609" MODIFIED="1681742080663" TEXT="Frage: sinnvoll für den ModelPort?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742084938" ID="ID_202138467" MODIFIED="1681742119293" TEXT="ExitNode könnte nach Bedarf differenziert sein">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742124316" ID="ID_1362949228" MODIFIED="1681742128580" TEXT="Diskussion">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742129796" ID="ID_189050777" MODIFIED="1681742134141" TEXT="pro">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681838331575" ID="ID_239877433" MODIFIED="1681838347337" TEXT="einfachere Primitive im eigentlichen Render-Netzwerk"/>
|
|
<node CREATED="1681838400094" ID="ID_1608524064" MODIFIED="1681838415480" TEXT="ein pervasives, fast überall irrelevantes Meta-Datum fällt weg"/>
|
|
<node CREATED="1681838767717" ID="ID_1175513068" MODIFIED="1681838892572" TEXT="potentielle Komplexitäten der Channel-Selektion werden in den Build-Prozeß verlagert">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es ist keineswegs sicher, daß wir mit einer bloßen Addressierung per Channel-Nummer auskommen; es könnte durchaus passieren, daß Erweiterung auf eine generische Selektions-Sprache notwendig wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742131726" ID="ID_1521704856" MODIFIED="1681742134141" TEXT="contra">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681838010874" ID="ID_646358803" MODIFIED="1681838019972" TEXT="identisch pro channel aufgedoppelte Pipelines">
|
|
<node CREATED="1681838041838" ID="ID_1433619565" MODIFIED="1681838054376" TEXT="...müßten tatsächlich nur einmal geplant und realisiert werden"/>
|
|
<node CREATED="1681838058588" ID="ID_1606171759" MODIFIED="1681838075957" TEXT="sie werden dann lediglich mehrfach mit anderer Parametrisierung bespielt"/>
|
|
<node CREATED="1681838082068" ID="ID_262950828" MODIFIED="1681838121263" TEXT="die Parametrisierung wird typischerweise lediglich zur Quelle/Mediencontainer druchgereicht"/>
|
|
</node>
|
|
<node CREATED="1681838495277" ID="ID_314464979" MODIFIED="1681838672355" TEXT="führt zumindest zu massiver Duplikation von Deskriptoren und Metadaten zur Steuerung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man denke nur an higher-order Ambisonics...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681742137539" ID="ID_1756656706" MODIFIED="1681742142187" TEXT="Entscheidung">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742149953" ID="ID_1733561384" MODIFIED="1681742202136" TEXT="erst mal andere Teile bauen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
den Channel-Parameter kann man leichter wegfallen lassen, als ihn nachträglich durchzufädeln; die Entscheidung selber wird erst relevant, wenn wir das low-Level-Model konkretisieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681742018442" ID="ID_596503548" MODIFIED="1681742022940" TEXT="Addressierung JobTicket">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1682626961915" ID="ID_1266598906" MODIFIED="1682626982746" TEXT="direkter Zugriff auf das Segment nach Zeit-Partitionierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682626986572" ID="ID_785390936" MODIFIED="1682627018574" TEXT="hierzu stets komplett erschöpfende Partitionierung notwendig">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1682627019680" ID="ID_1706448688" MODIFIED="1682627042580" TEXT="Segmentation mit TimeSpan::ALL initialisiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1682627043510" ID="ID_1053406793" LINK="#ID_1176991982" MODIFIED="1682627105439" TEXT="Implementierung von splitSplice() muß Konsistenz sicherstellen">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682611423253" ID="ID_1136070257" MODIFIED="1682611949376" TEXT="Vorschau: Datenstruktur">
|
|
<linktarget COLOR="#735061" DESTINATION="ID_1136070257" ENDARROW="Default" ENDINCLINATION="-651;-968;" ID="Arrow_ID_1804652676" SOURCE="ID_296140708" STARTARROW="None" STARTINCLINATION="-518;37;"/>
|
|
<node CREATED="1682611979955" ID="ID_853916933" MODIFIED="1682611992260">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt einen <b>commit</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1682612009427" ID="ID_1994458742" MODIFIED="1682612053494" TEXT="vermutlich eine referentielle nicht-intrusive Linked-List">
|
|
<node CREATED="1682612056884" ID="ID_303611553" MODIFIED="1682612072158">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Einträge sind <i>woanders </i>alloziert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682612075770" ID="ID_1368353614" MODIFIED="1682612084845" TEXT="ein Eintrag kann in mehreren Instanzen der Liste liegen"/>
|
|
<node CREATED="1682612094504" ID="ID_250365879" MODIFIED="1682612109226" TEXT="⟹ die umgebaute Liste kann auf einen Schlag aktualisiert werden"/>
|
|
</node>
|
|
<node CREATED="1682612125996" ID="ID_34027511" MODIFIED="1682612133736" TEXT="re-Partitionierung per Builder">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682611408260" ID="ID_408388335" MODIFIED="1682611410703" TEXT="Interface"/>
|
|
<node CREATED="1680563454868" ID="ID_1187556686" MODIFIED="1680563459014" TEXT="Backbone"/>
|
|
<node CREATED="1680563460649" ID="ID_127710483" MODIFIED="1680563474067" TEXT="MemManagement"/>
|
|
</node>
|
|
<node CREATED="1512923592590" ID="ID_540019681" MODIFIED="1557498707237" TEXT="Engine">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679783052390" ID="ID_1851394144" MODIFIED="1679783057287" TEXT="gründen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1680563559852" ID="ID_580288207" MODIFIED="1680563577773" TEXT="plainPlay">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086194343" ID="ID_1293419166" MODIFIED="1681086200999" TEXT="gemeinsame Datenstrukturen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086202821" ID="ID_274575596" MODIFIED="1681425341555" TEXT="Job">
|
|
<linktarget COLOR="#f4fec9" DESTINATION="ID_274575596" ENDARROW="Default" ENDINCLINATION="-522;-149;" ID="Arrow_ID_1673610733" SOURCE="ID_566775911" STARTARROW="None" STARTINCLINATION="1598;114;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086220019" ID="ID_1372752844" MODIFIED="1681086232986" TEXT="Umbau: C-Struct - Layer zurückbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681951421768" ID="ID_283868393" MODIFIED="1681951528212" TEXT="Schrittweiser Umbau: alte C-Struct vorwärts-kompatibel machen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das bedeutet: die alten Interfaces müssen von den neuen Interfaces erben, dann kann schon stückweise Code geschrieben werden, der die neuen Interfaces vorraussetzt...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node COLOR="#338800" CREATED="1681951529483" ID="ID_737477406" MODIFIED="1681951551777" TEXT="JobFunctor ‣ JobClosure">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681086385917" ID="ID_1193213661" MODIFIED="1681086416077" TEXT="leichtgewichtig, kopierbar, stateful, Scheduler-impl-owned"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681425144493" ID="ID_1404753000" MODIFIED="1681425214239" TEXT="Support für engine::Activity">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086210548" ID="ID_290412713" MODIFIED="1681086213533" TEXT="JobFunktor">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086238169" ID="ID_1303340014" MODIFIED="1681086253543" TEXT="Umbenennen: JobClosure ⟼ JobFunctor">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086255534" ID="ID_1953726127" MODIFIED="1681086266246" TEXT="Umbau: C-Struct - Layer zurückbauen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086215092" ID="ID_688439359" MODIFIED="1681425384986" TEXT="Activity">
|
|
<linktarget COLOR="#f4fec9" DESTINATION="ID_688439359" ENDARROW="Default" ENDINCLINATION="-522;-149;" ID="Arrow_ID_1352278228" SOURCE="ID_1926192234" STARTARROW="None" STARTINCLINATION="1598;114;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681086269493" ID="ID_305659400" MODIFIED="1681086275809" TEXT="Entwurf : neues Konzept">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1681086278139" ID="ID_1476636286" MODIFIED="1681086349598" TEXT="Idee">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1681086280251" ID="ID_110027513" MODIFIED="1681086287093" TEXT="es handelt sich um Verben"/>
|
|
<node CREATED="1681086289650" ID="ID_1565054848" MODIFIED="1681086305807" TEXT="es sind kompakt codierte algebraische Datenstrukturen"/>
|
|
<node CREATED="1681086332556" ID="ID_48127986" MODIFIED="1681086343867" TEXT="immutable, mit jeweils Referenz-Parametern"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1681086352417" ID="ID_28342864" MODIFIED="1681086366888" TEXT="der Scheduler arbeitet nur mit Activities">
|
|
<icon BUILTIN="forward"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1681396805942" ID="ID_1886457526" MODIFIED="1681396815850" TEXT="Architektur festlegen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1681397127019" ID="ID_683727165" MODIFIED="1681397136243" TEXT="separation of concerns">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1681398162521" ID="ID_1550060591" MODIFIED="1681398225579" TEXT="CalcStream ≡ Dispatch repetitiv vorantreiben"/>
|
|
<node CREATED="1681397144793" ID="ID_439031406" MODIFIED="1681397236218" TEXT="Dispatch ≡ Festsetzen der Zeitpunkte und Beziehungen"/>
|
|
<node CREATED="1681397308511" ID="ID_1748761928" MODIFIED="1681397340043" TEXT="Planning ≡ Ermitteln der Vorrausetzungen und Beziehungen"/>
|
|
<node CREATED="1681398712198" ID="ID_1529988864" MODIFIED="1681398770503" TEXT="Schedule ≡ Priorisierung und Verteilung an die Worker"/>
|
|
<node CREATED="1681398678151" ID="ID_1921320233" MODIFIED="1681398704971" TEXT="Control ≡ Beobachtung und Zustands-Aktualisierung"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680563595176" ID="ID_773353840" MODIFIED="1680563601552" TEXT="Aufruf/Verdrahtung im Player">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680564304940" ID="ID_1657236591" MODIFIED="1680565125463" TEXT="Scheduler entwerfen">
|
|
<linktarget COLOR="#f6e1c2" DESTINATION="ID_1657236591" ENDARROW="Default" ENDINCLINATION="-1219;85;" ID="Arrow_ID_49470357" SOURCE="ID_59027079" STARTARROW="None" STARTINCLINATION="-2189;368;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1680565469342" ID="ID_250843894" MODIFIED="1680566937368" TEXT="Priority-Scheduling">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_250843894" ENDARROW="Default" ENDINCLINATION="-644;84;" ID="Arrow_ID_1702721830" SOURCE="ID_12567096" STARTARROW="None" STARTINCLINATION="-233;30;"/>
|
|
</node>
|
|
<node CREATED="1680565476652" ID="ID_1218283238" MODIFIED="1680566934008" TEXT="Dependency-Notification">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_1218283238" ENDARROW="Default" ENDINCLINATION="-664;74;" ID="Arrow_ID_443600884" SOURCE="ID_695181807" STARTARROW="None" STARTINCLINATION="-240;29;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681347244544" ID="ID_444443795" MODIFIED="1681347486789" TEXT="Basis: Operational Control">
|
|
<linktarget COLOR="#9c738a" DESTINATION="ID_444443795" ENDARROW="Default" ENDINCLINATION="-1256;-1009;" ID="Arrow_ID_1047384894" SOURCE="ID_594073373" STARTARROW="None" STARTINCLINATION="-902;35;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681347258814" ID="ID_1046752034" MODIFIED="1681347345729" TEXT="TimingObservable">
|
|
<linktarget COLOR="#a54e77" DESTINATION="ID_1046752034" ENDARROW="Default" ENDINCLINATION="-1519;212;" ID="Arrow_ID_1830118942" SOURCE="ID_1139462793" STARTARROW="None" STARTINCLINATION="836;79;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681396857183" ID="ID_1618297513" MODIFIED="1681396863069" TEXT="Test/Integration">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680563506475" ID="ID_53985081" MODIFIED="1680563509211" TEXT="Interface">
|
|
<node CREATED="1681341888374" ID="ID_1288070081" MODIFIED="1681341890674" TEXT="Konzepte">
|
|
<node CREATED="1681341891551" ID="ID_1494961491" MODIFIED="1681341894065" TEXT="CalcStream">
|
|
<node CREATED="1681341919130" ID="ID_979269608" MODIFIED="1681341943300">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>symbolische Repräsentation</b> eines dynamisch laufenden Berechnungsprozesses
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681341944072" ID="ID_126625217" MODIFIED="1681342028220" TEXT="selber ein opaques Value-Objekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es enthält keine relevanten Informationen und dient auch nicht dem Tracking; vielmehr ist es ein Schlüssel, mit dessen Hilfe der PlayProcess später mit der Render-Engine reden kann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1681342047137" ID="ID_629527239" MODIFIED="1681342196215" TEXT="Aber: enthält die Implementierung des »Render-Start« Setups">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es ist im Entwurf von 2011 noch nicht festgelegt, ob diese Implementierung konkret ist (d.h. direkt Elemente aus dem Play-Service verbindet), oder nur abstrakt, durch Aufruf der RenderEnvironmentClosure. Letzteres wäre adäquat im sinne von <i>Inversion of Control</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1681685256388" ID="ID_845968912" MODIFIED="1681685407179" TEXT="besitzt/verwaltet den RenderDrive">
|
|
<arrowlink COLOR="#ffe4c9" DESTINATION="ID_1928295133" ENDARROW="Default" ENDINCLINATION="-724;353;" ID="Arrow_ID_1773297165" STARTARROW="None" STARTINCLINATION="-257;23;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681685287808" ID="ID_439004499" MODIFIED="1681685335962" TEXT="TODO: non-copyable?">
|
|
<arrowlink COLOR="#e0804f" DESTINATION="ID_1313231227" ENDARROW="Default" ENDINCLINATION="2513;164;" ID="Arrow_ID_861540006" STARTARROW="None" STARTINCLINATION="676;-84;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681341894866" ID="ID_94172116" MODIFIED="1681341900624" TEXT="RenderEnvironmentClosure">
|
|
<node CREATED="1681341905668" ID="ID_432577558" MODIFIED="1681341915150" TEXT="das ist die »abstrahierte Render-Engine«"/>
|
|
</node>
|
|
<node CREATED="1681594252245" ID="ID_1719102613" MODIFIED="1681594256245" TEXT="InvocationInstanceID">
|
|
<linktarget COLOR="#677097" DESTINATION="ID_1719102613" ENDARROW="Default" ENDINCLINATION="20;85;" ID="Arrow_ID_470615287" SOURCE="ID_465090802" STARTARROW="None" STARTINCLINATION="-167;-25;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681594257143" ID="ID_689625560" MODIFIED="1681594270271" TEXT="Bedeutung klären">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682039643804" ID="ID_1788184151" MODIFIED="1682040050470" TEXT="2012…2023+ ist das lediglich ein Platzhalter">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1682040059096" ID="ID_1654338206" MODIFIED="1682040070726" TEXT="wartet auf einen real nutzbaren Render-Graphen"/>
|
|
<node CREATED="1682040071416" ID="ID_137672818" MODIFIED="1682040086633" TEXT="und auf eine Basis-Implementierung des Frame-Cache"/>
|
|
</node>
|
|
<node CREATED="1682039675903" ID="ID_1413652743" MODIFIED="1682039709619" TEXT="Geplant: reproduzierbare Hash-Verkettung des Berechnungsweges">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1682039718122" ID="ID_1143247890" MODIFIED="1682039877063">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
soll genau dann reproduzierbar sein,
|
|
</p>
|
|
<p>
|
|
wenn das Resultat ebenfalls quasi-reproduzierbar(*) ist
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<font size="1" color="#393297">(*) bedeutet </font>
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<font size="1" color="#393297">effektiv gleiche Wirkung </font>
|
|
</li>
|
|
<li>
|
|
<font size="1" color="#393297">bis auf Rechenfehler identisch</font>
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1682039901233" ID="ID_373686563" MODIFIED="1682039956586" TEXT="Hash-Verkettung Merkle-Tree oder ähnlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Änderung auch nur eines Teils des Render-Graphen: Hash ändert sich ⟹ Cache invalidiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682039960965" ID="ID_205623629" MODIFIED="1682039976626" TEXT="Problem: muß Parameter-Automation mit erfassen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682047799390" ID="ID_1327852689" MODIFIED="1682047826186" TEXT="#1293 job invocation identity">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1681594271596" ID="ID_963803611" MODIFIED="1681594283643" TEXT="in welchem Scope ist sie eindeutig?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1682885727188" ID="ID_444576509" MODIFIED="1682885734939" TEXT="vorläufige Impl">
|
|
<icon BUILTIN="forward"/>
|
|
<node CREATED="1682885740362" ID="ID_362133279" MODIFIED="1682885761537" TEXT="untere Hälfte: Seed bzw. zufällig"/>
|
|
<node CREATED="1682885762190" ID="ID_1713133015" MODIFIED="1682885777729" TEXT="obere Hälfte: Hash aus der nominellen Zeit"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682941259374" ID="ID_1987226609" MODIFIED="1682941345993" TEXT="auf C++ umstellen (#1295 bzw. #1287)">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682039636789" ID="ID_986989156" MODIFIED="1682039638216" TEXT="Job">
|
|
<node CREATED="1682040113581" ID="ID_226959477" MODIFIED="1682040120147" TEXT="Bestandteile">
|
|
<node CREATED="1682040128483" ID="ID_1479051411" MODIFIED="1682040135022" TEXT="Job-Deskriptor"/>
|
|
<node CREATED="1682040135826" ID="ID_1456180976" MODIFIED="1682040139389" TEXT="Job-Parameter">
|
|
<node CREATED="1682040150126" ID="ID_1607794832" MODIFIED="1682040158098" TEXT="nomineller Zeitpunt"/>
|
|
<node CREATED="1682040159275" ID="ID_465090802" MODIFIED="1682040208269" TEXT="InvocationInstanceID">
|
|
<arrowlink COLOR="#677097" DESTINATION="ID_1719102613" ENDARROW="Default" ENDINCLINATION="20;85;" ID="Arrow_ID_470615287" STARTARROW="None" STARTINCLINATION="-167;-25;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682040140026" ID="ID_606595034" MODIFIED="1682040142533" TEXT="Job-Funktor">
|
|
<node CREATED="1682040662634" ID="ID_1775269495" MODIFIED="1682040670827" TEXT="definiert die eigentliche Nutzfunktion"/>
|
|
<node CREATED="1682040649447" ID="ID_1318983077" MODIFIED="1682040753078">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier ist <i>mindestens eine </i>Indirektion notwendig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aktuell passieren sogar zwei Indirektionen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Job-Deskriptor ⟼ JobFunctor-Objekt
|
|
</li>
|
|
<li>
|
|
JobFunctor vtable ⟼ Nutzfunktion
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1682040770119" ID="ID_840369063" MODIFIED="1682041006808" TEXT="JobFunktor selber ist generisch und wird möglichst weithin geteilt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wie generisch, ist eine offene Frage, die eing damit zusammenhängt, was tatsächlich durch die PriorityQueue läuft: Wenn nämlich auch schon der Job-Parameter in separater Storage liegt, dann könnte bereits dieser eine Vorstufe zum Funktor sein, und bsp. auch den Einsprung für die passende ProcNode transportieren; in diesem Fall gäbe es dann nur noch ganz wenige, prototypische Basis-Funktoren (Render aufrufen, Daten laden, Netzkommunikation, Verwaltungsaufgaben), und der konkrete Aufrufkontext würde im Parameter stecken — wir hätten dann wieder zwei Indirektionen (Job⟼Parameter und Parameter⟼Nutzfunktion)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682892551985" ID="ID_479084448" MODIFIED="1682892564322" TEXT="Interface">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682892569091" ID="ID_506216512" MODIFIED="1682892588596">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
welcher Teil muß wirklich<i> flexibel</i> sein?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682892594378" ID="ID_470552795" MODIFIED="1682892605477" TEXT="fragwürdig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1682892640709" ID="ID_587647024" MODIFIED="1682892640709" TEXT="HashVal hashOfInstance(InvocationInstanceID)"/>
|
|
<node CREATED="1682892668386" ID="ID_893041429" MODIFIED="1682892668386" TEXT="bool verify (Time, InvocationInstanceID)">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682892726514" ID="ID_231285908" MODIFIED="1682892847128" TEXT="führt das nicht zu einer gefählichen zyklischen Verkopplung?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn von den grundsätzlichen Abhängigkeiten her weiß nicht einmal ein JobTicket, in welchem Segment es hängt; auch ProcNodes könnten theoretisch sogar in mehreren Segmenten hängen ⟹ es schreint mehr als fragwürdig, ob ein JobFunktor überhaupt im Stande ist, eine inhaltlich sinnvolle verifikation zu machen (über das Prüfen auf null-Pointer hinaus)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682892700196" ID="ID_113377758" MODIFIED="1682892700196" TEXT="void signalFailure (JobParameter,JobFailureReason)">
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682892704686" ID="ID_1226594521" MODIFIED="1682892718331" TEXT="macht das nicht beser Layer-2 im Scheduler?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1682892868892" ID="ID_1825787555" MODIFIED="1682892871994" TEXT="void invokeJobOperation (JobParameter parameter)">
|
|
<icon BUILTIN="forward"/>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682892874899" ID="ID_1605821761" MODIFIED="1682892883021" TEXT="könnte man die generisch implementieren?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682892899276" ID="ID_1612087262" MODIFIED="1682892909242" TEXT="JobKind getJobKind()">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682892925095" ID="ID_1576147260" MODIFIED="1682892975170" TEXT="InvocationInstanceID buildInstanceID(HashVal)">
|
|
<arrowlink COLOR="#4d4eb0" DESTINATION="ID_1493396541" ENDARROW="Default" ENDINCLINATION="-46;-58;" ID="Arrow_ID_1838720811" STARTARROW="None" STARTINCLINATION="148;9;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1682040531781" ID="ID_913436563" MODIFIED="1682040539889" TEXT="offene Fragen">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1682040544603" ID="ID_1221736313" MODIFIED="1682040594240" TEXT="was steht tatsächlich in der PriQueue? Job-Deskriptor oder nur eine Activity?"/>
|
|
<node CREATED="1682040603211" ID="ID_1088917301" MODIFIED="1682040621149" TEXT="wenn nicht in der Queue, wo werden Jobs dann gespeichert? und wieder freigegeben?"/>
|
|
<node CREATED="1682808411785" ID="ID_1713196934" MODIFIED="1682808633170" TEXT="welche Parameter müssen einer Invocation im allgemeinen mitgegeben werden">
|
|
<linktarget COLOR="#b75269" DESTINATION="ID_1713196934" ENDARROW="Default" ENDINCLINATION="-871;-27;" ID="Arrow_ID_865176706" SOURCE="ID_782813898" STARTARROW="None" STARTINCLINATION="-1263;70;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682810738487" ID="ID_1493396541" MODIFIED="1682810875535" TEXT="#1295 draft job invocation parameter representation">
|
|
<linktarget COLOR="#4d4eb0" DESTINATION="ID_1493396541" ENDARROW="Default" ENDINCLINATION="-46;-58;" ID="Arrow_ID_1838720811" SOURCE="ID_1576147260" STARTARROW="None" STARTINCLINATION="148;9;"/>
|
|
<linktarget COLOR="#b22e63" DESTINATION="ID_1493396541" ENDARROW="Default" ENDINCLINATION="-1383;-51;" ID="Arrow_ID_847435526" SOURCE="ID_48632766" STARTARROW="None" STARTINCLINATION="-753;40;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1682040285134" ID="ID_1653553289" MODIFIED="1682040299541" TEXT="Performance-Belange">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1682040301305" ID="ID_1810860564" MODIFIED="1682040325124" TEXT="der Job-Descriptor wird ggfs durch die Priority-Queue geschoben"/>
|
|
<node CREATED="1682040325953" ID="ID_1613526709" MODIFIED="1682040363310" TEXT="Jobs können einen permanenten Allokations-Druck erzeugen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1682040431970" ID="ID_895676940" MODIFIED="1682040530953" TEXT="Gefahr der contention und multi-Core-Synchronisation">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
da Jobs massiv über mehrere Threads hinweg gereicht werden, könnte der bloße Umstand einer Datenaktualisierung bereits zu Cache-Coherency-Overheads führen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680563509728" ID="ID_1883500842" MODIFIED="1680563511567" TEXT="Scheduler">
|
|
<node CREATED="1680563512563" ID="ID_960191744" MODIFIED="1680563516470" TEXT="Layer-2"/>
|
|
<node CREATED="1680563517255" ID="ID_1104189783" MODIFIED="1680563519264" TEXT="Layer-1"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512923629577" ID="ID_617347424" MODIFIED="1557498707237" TEXT="Backend">
|
|
<node CREATED="1680565608115" ID="ID_1114884704" MODIFIED="1680565612050" TEXT="Hilfsmittel">
|
|
<node CREATED="1680565613038" ID="ID_1202060017" MODIFIED="1680565616857" TEXT="Content-Generator">
|
|
<node CREATED="1680565626147" ID="ID_460039330" MODIFIED="1680566930977" TEXT="Test-Content für Playback">
|
|
<linktarget COLOR="#fec499" DESTINATION="ID_460039330" ENDARROW="Default" ENDINCLINATION="-632;68;" ID="Arrow_ID_1437229627" SOURCE="ID_988488968" STARTARROW="None" STARTINCLINATION="-241;31;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1681085780230" ID="ID_667166448" MODIFIED="1681085784377" TEXT="Render Toolkit">
|
|
<node CREATED="1681085789797" ID="ID_435519695" MODIFIED="1681085821901" TEXT="Abstraktionsschicht über Low-Level-Funktionalität"/>
|
|
<node CREATED="1681085863204" ID="ID_136936235" MODIFIED="1681085881132" TEXT="isoliert system-Level Services und externe Library-Erweiterungen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512923647255" ID="ID_1800845122" MODIFIED="1557498707237" TEXT="Plug-in"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1670599468591" HGAP="175" ID="ID_1144378342" MODIFIED="1670599561156" POSITION="left" TEXT="Methoden" VSHIFT="-32">
|
|
<edge COLOR="#6164d8" STYLE="linear"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1670599621757" ID="ID_404731500" MODIFIED="1670599633186" TEXT="Numerik">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<node COLOR="#435e98" CREATED="1648160002022" ID="ID_1617011877" MODIFIED="1670599684006" TEXT="Newton-Raphson">
|
|
<linktarget COLOR="#758da1" DESTINATION="ID_1617011877" ENDARROW="Default" ENDINCLINATION="-1787;200;" ID="Arrow_ID_1389754977" SOURCE="ID_215061275" STARTARROW="None" STARTINCLINATION="-5051;242;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1648160042105" ID="ID_681739014" MODIFIED="1648160050003" TEXT="finde Nullstelle einer Funktion"/>
|
|
<node CREATED="1648160051303" ID="ID_1883017382" MODIFIED="1648160167185" TEXT="xₙ ≔ xₙ - f(xₙ)/f'(xₙ)"/>
|
|
<node CREATED="1648160182198" ID="ID_286076492" MODIFIED="1648160199375" TEXT="oft genügt guter Startwert + ein/zwei Iterationen"/>
|
|
<node CREATED="1670599038025" ID="ID_1741473977" MODIFIED="1670599307446" TEXT="Konvergenz nur gut für Startwert nahe an der Lösung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Die Methode steht und fällt damit, daß die Tangente näher zur Lösung zeigt, als der aktuelle (Start)Wert. Sonst kann die Iteration in weite Oszillationen münden und sich ggfs sogar in einem neben-Minimum festbeißen. Die Newton-Methode spielt daher ihr Potential einer senationell schnellen Konvergenz nur aus, wenn man <i>anderweitig schon eine sehr gute Näherung als Startwert hat.</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#c9d1da" COLOR="#2d2198" CREATED="1439664045448" HGAP="240" ID="ID_21531707" MODIFIED="1557498707237" POSITION="left" TEXT="Info" VSHIFT="-500">
|
|
<edge COLOR="#b4a9e3"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1439664217489" FOLDED="true" ID="ID_104059794" MODIFIED="1557498707237" TEXT="GTK-3">
|
|
<node CREATED="1439664230168" FOLDED="true" ID="ID_235548644" LINK="https://wiki.gnome.org/Projects/GTK%2B/Inspector" MODIFIED="1557498707237" TEXT="GTK+ Inspector">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1439664318604" ID="ID_1327496126" MODIFIED="1557498707237" TEXT="keyboard shortcut">
|
|
<node CREATED="1439664330354" ID="ID_257893375" MODIFIED="1557498707237" TEXT="SHIFT-Ctrl I"/>
|
|
<node CREATED="1439664339353" ID="ID_559550607" MODIFIED="1557498707237" TEXT="aktivieren via dconf">
|
|
<node CREATED="1538693388521" ID="ID_1129767870" MODIFIED="1557498707237" TEXT="per Editor">
|
|
<node CREATED="1439664358287" ID="ID_1044303564" MODIFIED="1557498707237" TEXT="apt-get install dconf-editor"/>
|
|
<node CREATED="1439664574202" ID="ID_1254903463" MODIFIED="1557498707237" TEXT="org > gtk > settings > debug"/>
|
|
</node>
|
|
<node CREATED="1538693397856" ID="ID_469176877" MODIFIED="1557498707237" TEXT="Kommandozeile">
|
|
<node CREATED="1538693413542" ID="ID_1265168543" MODIFIED="1557498707237" TEXT="gsettings set org.gtk.Settings.Debug enable-inspector-keybinding true"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538693418285" ID="ID_1301334145" MODIFIED="1557498707237" TEXT="direkt mit Applikation starten">
|
|
<node CREATED="1538693436099" ID="ID_1197910975" MODIFIED="1557498707237" TEXT="GTK_DEBUG=interactive target/lumiera"/>
|
|
</node>
|
|
<node CREATED="1538693451665" ID="ID_599439426" MODIFIED="1557498707237" TEXT="seit GTK+ 3.14 in der Standard-Distro">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1439664638857" ID="ID_1095180651" MODIFIED="1557498707237">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>saugeil</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1534634232557" HGAP="31" ID="ID_1467351006" MODIFIED="1557498707237" TEXT="Konzepte" VSHIFT="-22">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1534635219848" FOLDED="true" ID="ID_1769333890" MODIFIED="1557498707237" TEXT="show / hide">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1534635236910" ID="ID_1635567005" MODIFIED="1557498707237" TEXT="das zentrale Konzept in GTK">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1534635271809" ID="ID_545450309" MODIFIED="1557498707237" TEXT="GTK == Event-Framework">
|
|
<node CREATED="1534635363429" ID="ID_1102578851" MODIFIED="1557498707237" TEXT="GTK interessiert sich nur indirekt für den Lebenszyklus"/>
|
|
<node CREATED="1534635380794" ID="ID_121089426" MODIFIED="1557498707237" TEXT="...insofern Callbacks nicht in toten Speicher zeigen dürfen"/>
|
|
<node CREATED="1534635400479" ID="ID_1808051725" MODIFIED="1557498707237" TEXT="was aber sonst mit den "Objekten" passiert, ist GTK egal"/>
|
|
<node CREATED="1534635412070" ID="ID_1070513169" MODIFIED="1557498707237" TEXT="am Ende gehen alle Refcounts ohnehin auf Null"/>
|
|
<node CREATED="1534635426684" ID="ID_995597401" MODIFIED="1557498707237" TEXT="und wenn nicht, drof jeschissen"/>
|
|
</node>
|
|
<node CREATED="1534635260267" ID="ID_287252267" MODIFIED="1557498707237" TEXT="was verborgen ist, bekommt keine Events">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
<node CREATED="1534635309500" ID="ID_717136118" MODIFIED="1557498707237" TEXT="Container">
|
|
<node CREATED="1534635317179" ID="ID_921739364" MODIFIED="1557498707237" TEXT="verbergen rekursiv"/>
|
|
<node CREATED="1534635322938" ID="ID_1532459469" MODIFIED="1557498707237" TEXT="show_all zeigt rekursiv an"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534634259498" FOLDED="true" ID="ID_1900017952" MODIFIED="1561827466203" TEXT=""Schließen"">
|
|
<linktarget COLOR="#6f7ab9" DESTINATION="ID_1900017952" ENDARROW="Default" ENDINCLINATION="-2264;0;" ID="Arrow_ID_1220603071" SOURCE="ID_146943890" STARTARROW="None" STARTINCLINATION="-6278;0;"/>
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1534634292477" ID="ID_1867321008" MODIFIED="1534634310281">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Konzept <b>gibts nicht</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1534634334767" ID="ID_1445477599" MODIFIED="1534634373419">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GTK-Widget: <b>hide</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1534634379762" ID="ID_83493459" MODIFIED="1534634386116" TEXT="es wird unmapped">
|
|
<node CREATED="1534634403766" ID="ID_1515267212" MODIFIED="1534634426295" TEXT="keine Screen-Space-Zuordnung mehr"/>
|
|
<node CREATED="1534634426883" ID="ID_586184038" MODIFIED="1534634431582" TEXT="es wird nicht mehr gezeichnet"/>
|
|
</node>
|
|
<node CREATED="1534634386704" ID="ID_131269615" MODIFIED="1534634394739" TEXT="es wird aus dem Event-Processing herausgenommen"/>
|
|
</node>
|
|
<node CREATED="1534634453703" ID="ID_289385917" MODIFIED="1534634468974">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
GObject: <b>unref</b>()
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1534634472325" ID="ID_180385322" MODIFIED="1534634490430" TEXT="Glib hat ein refcounting Memory-Management"/>
|
|
<node CREATED="1534634502817" ID="ID_1557422702" MODIFIED="1534634512131" TEXT="das betrifft nur das Memory-Managment"/>
|
|
<node CREATED="1534634512864" ID="ID_952501435" MODIFIED="1534634524762" TEXT="jeder Client ist verantwortlich, seine Referenzen freizugeben"/>
|
|
</node>
|
|
<node CREATED="1534635126901" ID="ID_868113400" MODIFIED="1534635131976" TEXT="gtk_widget_destroy">
|
|
<node CREATED="1534635139155" ID="ID_1958818389" MODIFIED="1534635155125" TEXT="löst ein DESTROY-Signal aus"/>
|
|
<node CREATED="1534635156137" ID="ID_1010364630" MODIFIED="1534635215323" TEXT="macht sonst nur Refcount-Zeugs"/>
|
|
<node CREATED="1534635167295" ID="ID_418523562" MODIFIED="1576282357959" TEXT="keinerlei Auswirkung auf die Sichtbarkeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...in der Praxis aber entsteht indirekt eine Auswirkung,
|
|
</p>
|
|
<p>
|
|
insofern Container auf das DESTROY-Signal ihrer Kinder reagieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535629105141" ID="ID_387236763" MODIFIED="1557498707238" TEXT="Layout">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1535629144783" ID="ID_603397185" MODIFIED="1557498707238" TEXT="Phasen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1535629172787" ID="ID_1666976097" MODIFIED="1557498707238" TEXT="mapped">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1537577522482" ID="ID_629476344" MODIFIED="1557498707238" TEXT="einem GDK-Fenster mit Koordinaten zugeordnet"/>
|
|
<node CREATED="1540645314073" ID="ID_1765305895" MODIFIED="1557498707238" TEXT="ausgelöst durch show/hide"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1535629169164" ID="ID_1301809885" MODIFIED="1557498707238" TEXT="realized">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1537577511892" ID="ID_194223971" MODIFIED="1557498707238" TEXT="wird sichtbar"/>
|
|
<node CREATED="1540645329431" ID="ID_919909299" MODIFIED="1557498707238" TEXT="initial bei Fenster-Allokation; später als Folge von mapped"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535629240762" FOLDED="true" ID="ID_860094095" MODIFIED="1537576497171" STYLE="fork" TEXT="Platzierung">
|
|
<edge COLOR="#b4a9e3" STYLE="bezier" WIDTH="thin"/>
|
|
<linktarget COLOR="#6277b2" DESTINATION="ID_860094095" ENDARROW="Default" ENDINCLINATION="-1778;-100;" ID="Arrow_ID_761942436" SOURCE="ID_228360739" STARTARROW="None" STARTINCLINATION="-6486;0;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1535629255856" ID="ID_66989854" MODIFIED="1535630246025" TEXT="size_request">
|
|
<node CREATED="1535629316512" ID="ID_82343540" MODIFIED="1535630246025" TEXT="minimale oder natürliche Größe"/>
|
|
<node CREATED="1535629328246" ID="ID_1797361390" MODIFIED="1535630246025" TEXT="Widget wird niemals kleiner gemacht"/>
|
|
<node CREATED="1540647597892" ID="ID_699204853" MODIFIED="1540647691526" TEXT="Widget::queue_resize">
|
|
<arrowlink DESTINATION="ID_1615887419" ENDARROW="Default" ENDINCLINATION="401;-36;" ID="Arrow_ID_1278323856" STARTARROW="None" STARTINCLINATION="1411;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542308892655" ID="ID_1949284500" MODIFIED="1542308896395" TEXT="Allocation">
|
|
<node CREATED="1542308900630" ID="ID_1615499339" MODIFIED="1560693186079" TEXT="Container ruft gtk_widget_size_allocate()">
|
|
<arrowlink COLOR="#7573ab" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="763;-59;" ID="Arrow_ID_1309280117" STARTARROW="None" STARTINCLINATION="537;121;"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1542309002344" ID="ID_779294890" MODIFIED="1542309017723" TEXT="maximal zugewiesener Platz für dieses Widget"/>
|
|
<node CREATED="1542309018222" ID="ID_1596717915" MODIFIED="1542309025592" TEXT="einschließlich aller Dekoraktion und Margins"/>
|
|
<node CREATED="1542309064955" ID="ID_1797123207" MODIFIED="1542309079391" TEXT="dieser Ausgangs-Wert wird nicht gespeichert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1542308951807" ID="ID_1662312599" MODIFIED="1542308985044">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Widget berechnet <i>adjusted allocation</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1542308982045" ID="ID_657933396" MODIFIED="1542308982045" TEXT="gtk_widget_get_allocation"/>
|
|
<node CREATED="1542309030741" ID="ID_1042993819" MODIFIED="1576282357959" TEXT="tatsächlich für das Widget selber verfügbarer Platz">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...also <i>abzüglich</i> Dekoration und Margin
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1542308990570" ID="ID_1371068296" MODIFIED="1542309000371" TEXT="stets komplett in der zugewiesenen Allocation enthalten"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535629360298" ID="ID_872009465" MODIFIED="1535630246025" TEXT="Widget::property_expand()">
|
|
<node CREATED="1535629434440" ID="ID_384811116" MODIFIED="1535630246025" TEXT="bool">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1535629385583" ID="ID_147722143" MODIFIED="1576282357958" TEXT="nur wenn es zusätzlichen Platz gibt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...was der Fall sein kann in einer Box oder einem Grid,
|
|
</p>
|
|
<p>
|
|
sofern das Widget mit entsprechendem Modus eingefügt wurde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535629439847" ID="ID_1925784750" MODIFIED="1535630246025" TEXT="Widget dehnt sich aus, um verfügbaren Platz einzunehmen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1535630122372" ID="ID_1833778868" MODIFIED="1535630246025" TEXT="hat keinen Getter / Setter"/>
|
|
<node CREATED="1535629472923" ID="ID_927038398" MODIFIED="1535630246025" TEXT="es gibt vexpand und hexpand">
|
|
<node CREATED="1535630137082" ID="ID_793513557" MODIFIED="1535630246025" TEXT="nur für eine Richtung"/>
|
|
<node CREATED="1535630147960" ID="ID_701726630" MODIFIED="1535630246025" TEXT="diese haben Getter/Setter"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1619106728852" FOLDED="true" ID="ID_206049495" MODIFIED="1619106836504" TEXT="Thema: Koordinaten">
|
|
<linktarget COLOR="#6084b9" DESTINATION="ID_206049495" ENDARROW="Default" ENDINCLINATION="-1698;230;" ID="Arrow_ID_1554039358" SOURCE="ID_1862152665" STARTARROW="None" STARTINCLINATION="-5611;254;"/>
|
|
<node CREATED="1619106846804" ID="ID_1212718074" MODIFIED="1619106850872" TEXT="Frameworks">
|
|
<node CREATED="1619106864558" ID="ID_939967817" MODIFIED="1619106876785" TEXT="Xlib bzw Wayland"/>
|
|
<node CREATED="1619106851723" ID="ID_255903990" MODIFIED="1619106862766" TEXT="GDK (low-level-screen handling)"/>
|
|
<node CREATED="1619106880439" ID="ID_1910905372" MODIFIED="1619106889322" TEXT="Cairo (Vektor-Grafik)"/>
|
|
<node CREATED="1619106890429" ID="ID_248432300" MODIFIED="1619106903137" TEXT="Gnome Application-Framwork"/>
|
|
</node>
|
|
<node CREATED="1619106913492" ID="ID_1464583836" MODIFIED="1619106920910" TEXT="wo spielen Koordinaten eine Rolle?">
|
|
<node CREATED="1619106921874" ID="ID_1221635906" MODIFIED="1619106926267" TEXT="Maße in CSS"/>
|
|
<node CREATED="1619106926922" ID="ID_405918613" MODIFIED="1619106940067" TEXT="direkte Layout-Properties in GTK-Widgets"/>
|
|
<node CREATED="1619106941065" ID="ID_1727127052" MODIFIED="1619106952490" TEXT="das GTK Canvas-Control (Gtk::Layout)"/>
|
|
<node CREATED="1619106954997" ID="ID_1964121895" MODIFIED="1619106961377" TEXT="Cairo drawing-context"/>
|
|
<node CREATED="1619106962340" ID="ID_453051214" MODIFIED="1619106972463" TEXT="der Gnome-Canvas"/>
|
|
</node>
|
|
<node CREATED="1619107449907" ID="ID_1457702957" MODIFIED="1619107458558" TEXT="Doku / Infos / Tutorials">
|
|
<node CREATED="1619107459690" ID="ID_1000844260" LINK="https://www.linuxtopia.org/online_books/gui_toolkit_guides/gtk+_gnome_application_development/z174_1.html" MODIFIED="1619107497044" TEXT="Linuxtopia: Coordinates (Kontext: Gnome-canvas)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537575934664" ID="ID_849901633" MODIFIED="1557498707238" TEXT="Style">
|
|
<font NAME="SansSerif" SIZE="13"/>
|
|
<node CREATED="1538706283719" FOLDED="true" ID="ID_311272365" MODIFIED="1557498707238" TEXT="CSS">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1561742970171" ID="ID_1527227622" LINK="https://developer.gnome.org/gtk3/stable/chap-css-overview.html" MODIFIED="1561742986234" TEXT="Overview: CSS in Gtk">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1538706287605" ID="ID_811190435" LINK="https://developer.gnome.org/gtk3/stable/chap-css-properties.html" MODIFIED="1557498707238" TEXT="unterstützte properties">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1563035652060" ID="ID_1461845755" MODIFIED="1563035657162" TEXT="State / Pseudo-Klassen">
|
|
<node CREATED="1563035659642" ID="ID_1776634695" MODIFIED="1563035663793" TEXT=":backdrop">
|
|
<node CREATED="1563035576188" ID="ID_422408673" LINK="https://developer.gnome.org/gtk3/stable/gtk3-Standard-Enumerations.html#GtkStateFlags" MODIFIED="1576282357958" TEXT="GtkStateFlags::GTK_STATE_FLAG_BACKDROP">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"Widget is in a background toplevel window"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#8aafdb" DESTINATION="ID_422408673" ENDARROW="Default" ENDINCLINATION="-430;209;" ID="Arrow_ID_384398411" SOURCE="ID_1747578312" STARTARROW="None" STARTINCLINATION="-1700;-117;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679146582785" ID="ID_62393759" LINK="https://docs.gtk.org/gtk3/css-overview.html#colors" MODIFIED="1679146753812" TEXT="Farben">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1679146772278" ID="ID_93147070" MODIFIED="1679146786718" TEXT="reguläre CSS-Angaben">
|
|
<node CREATED="1679146852459" ID="ID_893843079" MODIFIED="1679146855190" TEXT="#hex"/>
|
|
<node CREATED="1679146856131" ID="ID_661866874" MODIFIED="1679146858935" TEXT="rgb()">
|
|
<node CREATED="1679146881816" ID="ID_590080260" MODIFIED="1679146905864" TEXT="Zahl (0..255)"/>
|
|
<node CREATED="1679146906452" ID="ID_1648565700" MODIFIED="1679146919750" TEXT="Prozentzahl 0%..100%"/>
|
|
</node>
|
|
<node CREATED="1679146859528" ID="ID_1780347020" MODIFIED="1679146862390" TEXT="rgba()">
|
|
<node CREATED="1679146920978" ID="ID_593670937" MODIFIED="1679146931669" TEXT="zusätzlich Alpha 0.0 .. 1.0"/>
|
|
</node>
|
|
<node CREATED="1679146945760" ID="ID_1337294797" MODIFIED="1679146952186" TEXT="standard color name">
|
|
<node CREATED="1679147071758" ID="ID_1977091316" LINK="https://www.w3schools.com/colors/colors_names.asp" MODIFIED="1679147080648" TEXT="die bekannten HTML-Farben"/>
|
|
<node CREATED="1679147109899" ID="ID_434533083" LINK="https://www.w3.org/TR/css-color-3/#svg-color" MODIFIED="1679147119718" TEXT="formale Spec(w3c)"/>
|
|
</node>
|
|
<node CREATED="1679146863199" ID="ID_658577497" MODIFIED="1679146870941" TEXT="currentColor"/>
|
|
<node CREATED="1679146871649" ID="ID_224240207" MODIFIED="1679146873653" TEXT="transparent"/>
|
|
</node>
|
|
<node CREATED="1679147135733" FOLDED="true" ID="ID_254968681" MODIFIED="1679147146400" TEXT="GTK-extended-spec">
|
|
<node CREATED="1679147159139" ID="ID_1704222116" MODIFIED="1679147162102" TEXT="color expression">
|
|
<node CREATED="1679147200986" ID="ID_85459751" MODIFIED="1679147206624" TEXT="lighter(color)"/>
|
|
<node CREATED="1679147207259" ID="ID_1837545759" MODIFIED="1679147210199" TEXT="darker(color)"/>
|
|
<node CREATED="1679147211053" ID="ID_1973625685" MODIFIED="1679147234195" TEXT="shade(color, degree)">
|
|
<node CREATED="1679147235421" ID="ID_138843695" MODIFIED="1679147265504" TEXT="degree ≔0.0 ⟹ black"/>
|
|
<node CREATED="1679147235421" ID="ID_1081933251" MODIFIED="1679147278062" TEXT="degree ≔1.0 ⟹ color"/>
|
|
<node CREATED="1679147235421" ID="ID_1278348110" MODIFIED="1679147285213" TEXT="degree ≔2.0 ⟹ white"/>
|
|
</node>
|
|
<node CREATED="1679147297672" ID="ID_801922011" MODIFIED="1679147332825" TEXT="alpha(color, opacity)">
|
|
<node CREATED="1679147235421" ID="ID_1252329160" MODIFIED="1679147352292" TEXT="opacity ≔0.0 ⟹ transparent"/>
|
|
<node CREATED="1679147235421" ID="ID_245757625" MODIFIED="1679147364543" TEXT="opacity ≔1.0 ⟹ opaque"/>
|
|
</node>
|
|
<node CREATED="1679147374558" ID="ID_620059171" MODIFIED="1679147385248" TEXT="mix(color1, color2, fade)"/>
|
|
</node>
|
|
<node CREATED="1679147153411" ID="ID_1245707107" MODIFIED="1679147392492" TEXT="symbolic color">
|
|
<node CREATED="1679147419260" ID="ID_431721011" MODIFIED="1679147420560" TEXT="@define-color 〈name〉 〈color〉"/>
|
|
<node CREATED="1679147423037" ID="ID_1801725279" MODIFIED="1679147432737" TEXT="use: @colorname"/>
|
|
<node CREATED="1679147401874" ID="ID_609120791" MODIFIED="1679147442412" TEXT="defined in the theme">
|
|
<node CREATED="1679147447011" ID="ID_1878670506" LINK="https://gitlab.gnome.org/GNOME/gtk/-/tree/d930c4a4d12e730a2d1711f865754315006506ff/gtk/theme/Adwaita" MODIFIED="1679147554401" TEXT="in Adwaitha">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Adwaita ist leider direkt in GTK integriert und ist ein aufgeblähter Wust an SCSS-generierten Regeln, die dann aus »performance-Gründen« (d.h. aus Dummheit und Arroganz) binär compiliert und eingebettet werden müssen.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1679147881250" ID="ID_365618706" MODIFIED="1679148018580" TEXT="definitionen sichtbar via _colors-public.scss"/>
|
|
<node CREATED="1679147918675" ID="ID_10101800" MODIFIED="1679147928687" TEXT="Farbwerte definiert in colors.scss">
|
|
<node CREATED="1679147938898" ID="ID_1015338145" MODIFIED="1679147948757" TEXT="Achtung: Switch light/dark"/>
|
|
</node>
|
|
<node CREATED="1679147982325" ID="ID_943402704" MODIFIED="1679148013300" TEXT="eingebunden via gtk-contained.scss"/>
|
|
</node>
|
|
<node CREATED="1679147578310" ID="ID_602384838" LINK="https://stackoverflow.com/a/64613523" MODIFIED="1679147798973">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
geläufiges<br />Farbschema
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es war und ist immer noch üblich, daß jedes <i>Theme</i> einen Satz von Basis-Farben definiert. Auch Adwaita macht das aktuell so (wenngleich es den Gnome-Leuten lästig ist, und sie immer wieder darauf hinweisen, daß das alles "difficult" und "challenging" ist. Sprich, man will raus aus der Nummer, aber der Widerstand der Nutzer ist zu stark)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1679148565999" ID="ID_303603967" MODIFIED="1679148582976" TEXT="Layout">
|
|
<node CREATED="1679148586102" ID="ID_745102737" MODIFIED="1679148602308" TEXT="theme_fg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widget text/foreground color
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586103" ID="ID_408960995" MODIFIED="1679148614603" TEXT="theme_text_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text color for entries, views and content in general
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586103" ID="ID_555799552" MODIFIED="1679148628299" TEXT="theme_bg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widget base background color
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586104" ID="ID_1295740691" MODIFIED="1679148642821" TEXT="theme_base_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text widgets and the like base background color
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586104" ID="ID_1732797987" MODIFIED="1679148655331" TEXT="theme_selected_bg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
base background color of selections
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586105" ID="ID_1199469015" MODIFIED="1679148665685" TEXT="theme_selected_fg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text/foreground color of selections
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586106" ID="ID_999836079" MODIFIED="1679148677841" TEXT="insensitive_bg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
base background color of insensitive widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586106" ID="ID_416797432" MODIFIED="1679148686769" TEXT="insensitive_fg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text foreground color of insensitive widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586107" ID="ID_1094511289" MODIFIED="1679148704615" TEXT="insensitive_base_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insensitive text widgets and the like base background color
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586107" ID="ID_705496778" MODIFIED="1679148713000" TEXT="theme_unfocused_fg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widget text/foreground color on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586108" ID="ID_1355753292" MODIFIED="1679148722532" TEXT="theme_unfocused_text_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text color for entries, views and content in general on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586108" ID="ID_461157644" MODIFIED="1679148732329" TEXT="theme_unfocused_bg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widget base background color on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586109" ID="ID_49882093" MODIFIED="1679148742267" TEXT="theme_unfocused_base_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text widgets and the like base background color on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586110" ID="ID_349036672" MODIFIED="1679148751759" TEXT="theme_unfocused_selected_bg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
base background color of selections on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586110" ID="ID_626976605" MODIFIED="1679148764268" TEXT="theme_unfocused_selected_fg_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
text/foreground color of selections on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586111" ID="ID_537990754" MODIFIED="1679148776699" TEXT="unfocused_insensitive_color">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
insensitive color on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586111" ID="ID_1700746299" MODIFIED="1679148785292" TEXT="borders">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widgets main borders color
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679148586111" ID="ID_1698242897" MODIFIED="1679148794104" TEXT="unfocused_borders">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
widgets main borders color on backdrop windows
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679148569038" ID="ID_1622259143" MODIFIED="1679148580505" TEXT="Status">
|
|
<node CREATED="1679148586111" ID="ID_1392247646" MODIFIED="1679148586111" TEXT="warning_color"/>
|
|
<node CREATED="1679148586111" ID="ID_1621214244" MODIFIED="1679148586111" TEXT="error_color"/>
|
|
<node CREATED="1679148586111" ID="ID_619365964" MODIFIED="1679148586111" TEXT="success_color"/>
|
|
</node>
|
|
<node CREATED="1679148572758" ID="ID_1709733815" MODIFIED="1679148850295" TEXT="Window">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
these colors are exported for the window manager and shouldn't be used in applications,
|
|
</p>
|
|
<p>
|
|
read if you used those and something break with a version upgrade you're on your own...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1679148881944" MODIFIED="1679148881944" TEXT="wm_title"/>
|
|
<node CREATED="1679148881945" MODIFIED="1679148881945" TEXT="wm_unfocused_title"/>
|
|
<node CREATED="1679148881945" MODIFIED="1679148881945" TEXT="wm_highlight"/>
|
|
<node CREATED="1679148881945" MODIFIED="1679148881945" TEXT="wm_borders_edge"/>
|
|
<node CREATED="1679148881946" MODIFIED="1679148881946" TEXT="wm_bg_a"/>
|
|
<node CREATED="1679148881946" MODIFIED="1679148881946" TEXT="wm_bg_b"/>
|
|
<node CREATED="1679148881946" MODIFIED="1679148881946" TEXT="wm_shadow"/>
|
|
<node CREATED="1679148881946" MODIFIED="1679148881946" TEXT="wm_border"/>
|
|
<node CREATED="1679148881947" MODIFIED="1679148881947" TEXT="wm_button_hover_color_a"/>
|
|
<node CREATED="1679148881947" MODIFIED="1679148881947" TEXT="wm_button_hover_color_b"/>
|
|
<node CREATED="1679148881947" MODIFIED="1679148881947" TEXT="wm_button_active_color_a"/>
|
|
<node CREATED="1679148881948" MODIFIED="1679148881948" TEXT="wm_button_active_color_b"/>
|
|
<node CREATED="1679148881948" MODIFIED="1679148881948" TEXT="wm_button_active_color_c"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563557082887" FOLDED="true" ID="ID_1375283498" MODIFIED="1563557089708" TEXT="CSS node Namen">
|
|
<node CREATED="1563557091053" ID="ID_1694938996" MODIFIED="1563557119660" TEXT="werden explizit in der XXX_class_init()-Funktion gesetzt"/>
|
|
<node CREATED="1563557121848" ID="ID_920321676" MODIFIED="1563557129943" TEXT="sind in der API-Dok dokumentiert">
|
|
<node CREATED="1563557131952" ID="ID_286084554" MODIFIED="1563557140589" TEXT="manche Widgets konstruieren einen ganzen Baum"/>
|
|
</node>
|
|
<node CREATED="1563557146126" ID="ID_541393362" MODIFIED="1563557156289" TEXT="Fallback: Name des GType">
|
|
<node CREATED="1563557158442" ID="ID_1858830455" MODIFIED="1563557164659" TEXT="Unterschiedlich für C und C++"/>
|
|
<node CREATED="1563557179170" ID="ID_245445009" MODIFIED="1563557183623" TEXT="Gtk::Frame::get_type()">
|
|
<node CREATED="1563557202959" ID="ID_171572665" MODIFIED="1563557207820" TEXT="liefert gtkmm__GtkFrame"/>
|
|
</node>
|
|
<node CREATED="1563557217956" ID="ID_1703813951" MODIFIED="1563557221296" TEXT="gtk_frame_get_type()">
|
|
<node CREATED="1563557232764" ID="ID_1095076986" MODIFIED="1563557233612" TEXT="GtkFrame"/>
|
|
</node>
|
|
<node CREATED="1563557235763" ID="ID_149384360" MODIFIED="1563557243823" TEXT="korrekt ist aber "frame"">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563557245954" ID="ID_1216219394" MODIFIED="1576282357957" TEXT="CSS Node-Namen will man normalerweise nicht ändern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Warum?
|
|
</p>
|
|
<p>
|
|
Weil man normalerweise das bestehende Styling vom System-Theme abgreifen möchte,
|
|
</p>
|
|
<p>
|
|
und das baut auf den bekannten Node-Namen auf, wie z.B "fame", "box", "notebook"
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Und das erklärt wohl auch, warum man diesen CSS-Node-Namen nur direkt in C ändern kann,
|
|
</p>
|
|
<p>
|
|
indem man eine eigene XXX_class_init() - Funktion schreibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink DESTINATION="ID_1245820640" ENDARROW="Default" ENDINCLINATION="-18;-274;" ID="Arrow_ID_1242464259" STARTARROW="None" STARTINCLINATION="309;8;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1563557421449" ID="ID_1549555929" MODIFIED="1576282357957" TEXT="es gibt (wohl) kein API, um diesen Namen zu erhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in den Fällen, die ich mir angeschaut habe, steht dieser String hart codiert in der XXXX_class_init()-Funktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563631851881" FOLDED="true" ID="ID_1732615721" MODIFIED="1563631854580" TEXT="Erfahrungen">
|
|
<node CREATED="1563631855781" ID="ID_1599365177" MODIFIED="1563631858795" TEXT="Frames">
|
|
<node CREATED="1563631859864" ID="ID_1388716276" MODIFIED="1576282357956" TEXT="werden nach innen gezeichnet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. die angegebenen Abmessungen entsprechen der bounding box
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563631918721" ID="ID_545245141" MODIFIED="1576282357956" TEXT="partielle / Gesamt-Definitionen sind jeweils komplett incl Farbe">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es geht also nicht, daß man sagt
|
|
</p>
|
|
<p>
|
|
border: solid yellow;
|
|
</p>
|
|
<p>
|
|
border-left: 2px
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
in diesem Falle würde die linke Border mit der geerben Farbe gezeichnet, und nicht gelb
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1564926426614" ID="ID_240623877" MODIFIED="1564926740793" TEXT="box-shadow">
|
|
<linktarget COLOR="#405ecf" DESTINATION="ID_240623877" ENDARROW="Default" ENDINCLINATION="-838;0;" ID="Arrow_ID_1124667032" SOURCE="ID_1488276378" STARTARROW="None" STARTINCLINATION="-522;0;"/>
|
|
<node CREATED="1564926431517" ID="ID_1620722736" LINK="https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Background_and_Borders/Box-shadow_generator" MODIFIED="1564926458324" TEXT="interaktives box-shadow-Tool bei Mozilla">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1564926468217" ID="ID_1021621147" MODIFIED="1564926476805" TEXT="ein CSS3-Effekt"/>
|
|
<node CREATED="1564926773320" ID="ID_1461042373" LINK="https://developer.mozilla.org/en-US/docs/Web/CSS/box-shadow" MODIFIED="1576282357955" TEXT="CSS-Syntax">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<offX> <offY> [<blur> [<spread>]] <colour>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1564926477387" ID="ID_1307917529" MODIFIED="1564926492175" TEXT="wird zusätzlich zum Element in Z-Order gerendert">
|
|
<node CREATED="1564926496242" ID="ID_1998030818" MODIFIED="1564929104275" TEXT="backdrop: below and outside background frame"/>
|
|
<node CREATED="1564926502241" ID="ID_1213868388" MODIFIED="1564929115263" TEXT="inset: on top of backround and inside the border"/>
|
|
<node CREATED="1564929121202" ID="ID_321264842" MODIFIED="1564932279130" TEXT="Note">
|
|
<linktarget COLOR="#9a85e1" DESTINATION="ID_321264842" ENDARROW="Default" ENDINCLINATION="-618;56;" ID="Arrow_ID_852851809" SOURCE="ID_1904122891" STARTARROW="None" STARTINCLINATION="-805;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1564929129077" ID="ID_1739609367" MODIFIED="1564929143403" TEXT="effect spreads over other content outside the bounding box"/>
|
|
<node CREATED="1564929150870" ID="ID_237587547" MODIFIED="1564929178639" TEXT="what other drawing it precisely covers is implementation-defined"/>
|
|
<node CREATED="1564929179711" ID="ID_74068953" MODIFIED="1564929197683" TEXT="inset box-shadow does not affect the border"/>
|
|
<node CREATED="1564929235683" ID="ID_792222700" MODIFIED="1564929255468" TEXT="effects not rendered on top of content"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537575947102" FOLDED="true" ID="ID_161652920" LINK="https://developer.gnome.org/gtk3/stable/GtkStyleContext.html" MODIFIED="1561741931982" TEXT="StyleContext">
|
|
<linktarget COLOR="#3d73d3" DESTINATION="ID_161652920" ENDARROW="Default" ENDINCLINATION="-1637;0;" ID="Arrow_ID_990523511" SOURCE="ID_73927449" STARTARROW="None" STARTINCLINATION="-2361;0;"/>
|
|
<node CREATED="1562843919255" ID="ID_1423435210" MODIFIED="1562843925624" TEXT="widget->get_style_context();">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1537575960276" ID="ID_376188043" MODIFIED="1557498707238" TEXT="enthält mehrere StyleProvider"/>
|
|
<node CREATED="1562855059084" ID="ID_49781798" MODIFIED="1576282357955" TEXT="Gtk::StyleContext wird per ref_ptr weitergegeben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wir haben Referenz-Semantik
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1562855174618" ID="ID_687255786" MODIFIED="1562855190810" TEXT="statische Factory-Funktion: StyleContext::create">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
<node CREATED="1562855132568" ID="ID_936625427" MODIFIED="1562855138585" TEXT="kann nicht kopiert werden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1564838378949" ID="ID_680016998" MODIFIED="1564838383463" TEXT="Zeichenfunktionen">
|
|
<node CREATED="1564838405138" ID="ID_366839977" MODIFIED="1564838405138" TEXT="render_background"/>
|
|
<node CREATED="1564838414079" ID="ID_1075533829" MODIFIED="1564838414079" TEXT="render_frame">
|
|
<node CREATED="1564838433119" ID="ID_803718694" MODIFIED="1564838440607" TEXT="Parameter definieren die Bounding-Box"/>
|
|
<node CREATED="1564838441724" ID="ID_924305582" MODIFIED="1576282357954" TEXT="gezeichnet wird mit der effektiven border-width">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die sich aus den CSS-Selektoren ergibt, gemäß dem StylePath für diesen StyleContext,
|
|
</p>
|
|
<p>
|
|
<i>plus zuzüglich</i> den lokal, explizit hinzugefügten Classes und Modifiers, welche auch
|
|
</p>
|
|
<p>
|
|
automatisch eine höhere Priorität haben, als das, was sich aus den Path-match ergibt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1564838554448" ID="ID_1827131254" MODIFIED="1576282357954" TEXT="Müll, wenn die gegebene Bounding-Box zu klein ist">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bounding-Box meint ja, den effektiven äußeren Umfang.
|
|
</p>
|
|
<p>
|
|
GTK zeichnet also von diesem ausgehend nach Innen.
|
|
</p>
|
|
<p>
|
|
Wenn die Bounding-Box kleiner ist als die effektiven border-width, und zwar jeweils zweimal pro Richtung
|
|
</p>
|
|
<p>
|
|
(oben+unten == Höhe..), dann zeichnet GTK ggfs über die BoundingBox hinaus,
|
|
</p>
|
|
<p>
|
|
typischerweise nach Oben. Und natürlich sieht das Ganze dann auch nicht mehr wie ein frame aus.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Man muß also genügend Platz allozieren für border-top-width + border-bottom-width + gewünschter Content!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537575973946" ID="ID_1131360657" MODIFIED="1557498707238" TEXT="StyleProvider">
|
|
<node CREATED="1537575987001" ID="ID_1223531940" MODIFIED="1557498707238" TEXT="GtkCssStyleProvider">
|
|
<node CREATED="1537576001423" ID="ID_707384345" MODIFIED="1557498707238" TEXT="interpretiert ein CSS-Stylesheet"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1662049423914" ID="ID_1951916067" MODIFIED="1662049426710" TEXT="Icons">
|
|
<node CREATED="1662049427769" ID="ID_957383659" MODIFIED="1662049451890">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#bd035f" face="Monospaced">@deprecated </font>früher gab es die Stock-IDs
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1662049454454" ID="ID_1598985625" MODIFIED="1662049465776" TEXT="man soll »standard Icon-Names« verwenden">
|
|
<node CREATED="1662049467172" ID="ID_124375371" LINK="https://specifications.freedesktop.org/icon-naming-spec/icon-naming-spec-latest.html" MODIFIED="1662049489405" TEXT="icon-naming-spec FreeDesktop"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537576031611" FOLDED="true" ID="ID_1494464724" MODIFIED="1557498707238" TEXT="Widgets">
|
|
<node CREATED="1537576035498" ID="ID_1813123190" MODIFIED="1557498707238" TEXT="definieren jeweils die Styles, die sie verwenden">
|
|
<node CREATED="1537577874195" ID="ID_385552696" MODIFIED="1557498707238" TEXT="style-context zum Widget beziehen"/>
|
|
<node CREATED="1537577885042" ID="ID_9820896" MODIFIED="1557498707238" TEXT="diesem Context die spezielle Klasse hinzufügen"/>
|
|
<node CREATED="1537577901032" ID="ID_1836919045" MODIFIED="1557498707238" TEXT="diese Klasse kann nun im CSS-Selektor verwendet werden"/>
|
|
<node CREATED="1537577914422" ID="ID_1220237808" MODIFIED="1576282357953" TEXT="geht einfach per GTKmm">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Glib::RefPtr<StyleContext> context = widget->get_style_context();
|
|
</p>
|
|
<p>
|
|
context->add_class("ohMy");
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1537577929540" ID="ID_644837001" MODIFIED="1557498707238" TEXT="früher ging das nur direkt in C">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node COLOR="#803457" CREATED="1537577957752" ID="ID_36168340" LINK="https://stackoverflow.com/questions/37609381/how-to-set-a-specific-css-class-to-a-widget-in-gtk3-c" MODIFIED="1557498707238" TEXT="C-Beispiel auf Stackoverflow"/>
|
|
<node COLOR="#803457" CREATED="1537577957752" ID="ID_1015117751" LINK="https://stackoverflow.com/questions/37609381/how-to-set-a-specific-css-class-to-a-widget-in-gtk3-c" MODIFIED="1557498707238" TEXT="C++-Lösung auf Stackoverflow">
|
|
<linktarget COLOR="#c1a9a9" DESTINATION="ID_1015117751" ENDARROW="Default" ENDINCLINATION="56;152;" ID="Arrow_ID_1206355372" SOURCE="ID_903275997" STARTARROW="None" STARTINCLINATION="68;8;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537576059351" ID="ID_1816365537" MODIFIED="1557498707238" TEXT="können spezielle "Regions" haben">
|
|
<node CREATED="1537576068734" ID="ID_1594476628" MODIFIED="1557498707238" TEXT="was ist das">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1537658489614" ID="ID_1012337146" MODIFIED="1557498707238" TEXT="Doku gibt einen Baum an: "CSS nodes""/>
|
|
<node CREATED="1537658542249" ID="ID_956543325" MODIFIED="1557498707238" TEXT="das ist die tatsächliche Widget-Struktur"/>
|
|
</node>
|
|
<node CREATED="1535629240762" FOLDED="true" ID="ID_1174884362" MODIFIED="1537576577055" STYLE="fork" TEXT="CustomWidgets">
|
|
<edge COLOR="#b4a9e3" STYLE="bezier" WIDTH="thin"/>
|
|
<linktarget COLOR="#6277b2" DESTINATION="ID_1174884362" ENDARROW="Default" ENDINCLINATION="-2315;-45;" ID="Arrow_ID_380937946" SOURCE="ID_1432671260" STARTARROW="None" STARTINCLINATION="-7413;0;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1537576079756" HGAP="32" ID="ID_111059124" MODIFIED="1537658672181" TEXT="siehe Tutorial" VSHIFT="-6">
|
|
<arrowlink DESTINATION="ID_334736261" ENDARROW="Default" ENDINCLINATION="228;-492;" ID="Arrow_ID_84377619" STARTARROW="None" STARTINCLINATION="930;-42;"/>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1562843267371" ID="ID_132122055" MODIFIED="1562843271022" TEXT="Text-Tags">
|
|
<node COLOR="#990000" CREATED="1537658616952" HGAP="24" ID="ID_940676428" LINK="https://stackoverflow.com/questions/52452878/can-tags-in-gtktextbuffer-be-styled-with-css" MODIFIED="1562843313720" TEXT="habe selber auf Stackoverflow gefragt..." VSHIFT="-8">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1562843284008" ID="ID_1053320603" MODIFIED="1562843307987" TEXT="Antwort Nein; nur dirketes Styling, nicht per CSS">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537658818388" ID="ID_1554071957" MODIFIED="1537658827087" TEXT="Möglichkeiten">
|
|
<node CREATED="1537577389028" ID="ID_1690083237" MODIFIED="1576282357952" TEXT="können einen eigenen Widget-Namen setzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
this->set_name("my-widget")
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1563038427512" ID="ID_887791641" MODIFIED="1563038432987" TEXT="Vorsicht: das ist die #id"/>
|
|
<node CREATED="1563038460235" ID="ID_1245820640" MODIFIED="1576282357952" TEXT="GTKmm-definierte custom-Widgets können nicht ihren CSS-node-Namen ändern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(2019 / Debian-Stretch)
|
|
</p>
|
|
<p>
|
|
Das schließe ich aus einem Kommentar im GTKmm-Tutorial
|
|
</p>
|
|
<p>
|
|
  // Set the widget name to use in the CSS file.
|
|
</p>
|
|
<p>
|
|
  set_name("my-widget");
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  // If you make a custom widget in C code, based on gtk+'s GtkWidget, there is
|
|
</p>
|
|
<p>
|
|
  // an alternative to gtk_widget_set_name(): Set a CSS name for your custom
|
|
</p>
|
|
<p>
|
|
  // class (instead of the widget instance) with gtk_widget_class_set_css_name()
|
|
</p>
|
|
<p>
|
|
  // (new in gtk+ 3.19.1). That's not possible for custom widgets defined in gtkmm.
|
|
</p>
|
|
<p>
|
|
  // gtk_widget_class_set_css_name() must be called in the class init function,
|
|
</p>
|
|
<p>
|
|
  // which can't be customized, when the widget is based on gtkmm's Gtk::Widget.
|
|
</p>
|
|
<p>
|
|
  //
|
|
</p>
|
|
<p>
|
|
  // Another alternative: The custom widget inherits the CSS name "widget" from
|
|
</p>
|
|
<p>
|
|
  // GtkWidget. That name can be used in the CSS file. This is not a very good
|
|
</p>
|
|
<p>
|
|
  // alternative. GtkWidget's CSS name is not documented. It can probably be
|
|
</p>
|
|
<p>
|
|
  // changed or removed in the future.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#bc86a6" DESTINATION="ID_1245820640" ENDARROW="Default" ENDINCLINATION="-1901;31;" ID="Arrow_ID_1120129058" SOURCE="ID_994687888" STARTARROW="None" STARTINCLINATION="-2128;-72;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1245820640" ENDARROW="Default" ENDINCLINATION="-18;-274;" ID="Arrow_ID_1242464259" SOURCE="ID_1216219394" STARTARROW="None" STARTINCLINATION="309;8;"/>
|
|
<node CREATED="1563042271596" ID="ID_60542269" MODIFIED="1576282357951" TEXT="man kann zwar aufrufen...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gtk_widget_class_set_css_name (GTK_WIDGET_GET_CLASS(gobj()), "body");
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1563042287071" ID="ID_1579813090" MODIFIED="1563042298109" TEXT="aber das kommt zu spät und bleibt wirkungslos für das CSS"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1665955382455" ID="ID_1117299084" MODIFIED="1665956972844" TEXT="man kann aber den Glib::ObjectBase-ctor explizit aufrufen">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1665955404437" ID="ID_865788176" MODIFIED="1665955416055" TEXT="das muß dann vor allen Vaterklassen-Konstruktoren passieren"/>
|
|
<node CREATED="1665955418797" ID="ID_157490279" MODIFIED="1665957004676" TEXT="damit kann man den Namen in der Klassenhierarchie ändern"/>
|
|
<node CREATED="1665955450339" ID="ID_1763041463" MODIFIED="1665955488686" TEXT="Glib::ObjectBase("body") ⟹ CSS properties (on 'gtkmm__CustomObject_body')">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1665955490424" ID="ID_1309061874" MODIFIED="1665955496915" TEXT="Beispiel: BodyCanvasWidget">
|
|
<node COLOR="#523db7" CREATED="1665955761332" ID="ID_1043823112" MODIFIED="1665955780159" TEXT="verifiziert: funktioniert in der Tat">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1665957010202" ID="ID_230342068" MODIFIED="1665957038452">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber der Tag-Name für den CSS-Selector wird dadurch <b>nicht</b>  geändert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1537577364840" ID="ID_927285198" MODIFIED="1537577379929" TEXT="können custom-Properties haben">
|
|
<node CREATED="1537577410065" ID="ID_1611025546" MODIFIED="1537577422244" TEXT="das ist ein Proxy-Member"/>
|
|
<node CREATED="1537577424000" ID="ID_742914876" MODIFIED="1537577434658" TEXT="onRealize kann der Wert abgeholt werden"/>
|
|
</node>
|
|
<node CREATED="1537658737815" ID="ID_1865147889" MODIFIED="1537658764823" TEXT="können Basis-Widgets mit Klasse auszeichnen">
|
|
<node CREATED="1537658770555" ID="ID_920908371" MODIFIED="1537658777916" TEXT="nicht klar, ob das in C++ geht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1537658785336" ID="ID_903275997" MODIFIED="1538609485588" TEXT="Beispiel">
|
|
<arrowlink COLOR="#c1a9a9" DESTINATION="ID_1015117751" ENDARROW="Default" ENDINCLINATION="56;152;" ID="Arrow_ID_1206355372" STARTARROW="None" STARTINCLINATION="68;8;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1563042875607" ID="ID_1514342953" MODIFIED="1563042880140" TEXT="Interna">
|
|
<node CREATED="1563042881862" ID="ID_96389801" MODIFIED="1563042882948" TEXT="GtkWidgetClass">
|
|
<node CREATED="1563042885675" ID="ID_1605857107" MODIFIED="1563042893560" TEXT="ziemlich obskures internes Detail">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1563042941749" ID="ID_1890840480" MODIFIED="1563042972361" TEXT="wohl eine GLib "subklasse" der Widget-"klasse""/>
|
|
<node CREATED="1563042901556" ID="ID_252353292" MODIFIED="1563043017352" TEXT="man bekommt sie so: GTK_WIDGET_GET_CLASS(gobj())">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1563042990783" ID="ID_987465821" MODIFIED="1563043007260" TEXT="Verhältnis zur C++ Widget_Class?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1563043008460" ID="ID_30159127" MODIFIED="1563043013198" TEXT="ist mir nicht klar">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535633140424" FOLDED="true" ID="ID_293762905" MODIFIED="1563630924934" TEXT="WidgetPath">
|
|
<linktarget COLOR="#3766bc" DESTINATION="ID_293762905" ENDARROW="Default" ENDINCLINATION="-654;0;" ID="Arrow_ID_711737555" SOURCE="ID_1145993487" STARTARROW="None" STARTINCLINATION="-2487;0;"/>
|
|
<linktarget COLOR="#76a5de" DESTINATION="ID_293762905" ENDARROW="Default" ENDINCLINATION="109;127;" ID="Arrow_ID_1149853107" SOURCE="ID_222380322" STARTARROW="None" STARTINCLINATION="-391;0;"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1535633147295" ID="ID_14373153" MODIFIED="1576282357951" TEXT="Konzept ist mir nicht klar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
8/2018:
|
|
</p>
|
|
<p>
|
|
ist das eine Sequenz von konkreten Objekten, die ineinander verschachtelt sind?
|
|
</p>
|
|
<p>
|
|
oder ist es eine Vererbungs-Hierarchie, wie sie für das CSS-Styling benötigt wird?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1535633221189" ID="ID_623946936" MODIFIED="1557498707238" TEXT="beachte: hier werden Typen (GType) gespeichert">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1535633267727" ID="ID_168272548" MODIFIED="1557498707238" TEXT="Gtk::Widget::get_path()">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1562846022964" ID="ID_209760707" LINK="https://developer.gnome.org/gtkmm/3.20/classGtk_1_1WidgetPath.html" MODIFIED="1562846030046" TEXT="Gtk::WidgetPath"/>
|
|
<node CREATED="1562846100532" ID="ID_1504183934" MODIFIED="1562846529835" TEXT="GTK(C)">
|
|
<node CREATED="1562846131709" ID="ID_59749138" LINK="https://developer.gnome.org/gtk3/stable/GtkWidget.html#gtk-widget-get-path" MODIFIED="1562846137501" TEXT="gtk-widget-get-path"/>
|
|
<node CREATED="1562846107520" ID="ID_538645074" LINK="https://developer.gnome.org/gtk3/stable/GtkWidget.html#gtk-widget-path" MODIFIED="1562846406105" TEXT="gtk-widget-path()">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1562846188789" ID="ID_452719406" MODIFIED="1562846191768" TEXT="@deprecated"/>
|
|
<node CREATED="1562846317916" ID="ID_611735201" MODIFIED="1576282357950" TEXT="aber die Doku ist gut">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gtk_widget_path ()
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
void
|
|
</p>
|
|
<p>
|
|
gtk_widget_path (GtkWidget *widget,
|
|
</p>
|
|
<p>
|
|
                 guint *path_length,
|
|
</p>
|
|
<p>
|
|
                 gchar **path,
|
|
</p>
|
|
<p>
|
|
                 gchar **path_reversed);
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
gtk_widget_path has been deprecated since version 3.0 and should not be used in newly-written code.
|
|
</p>
|
|
<p>
|
|
Use gtk_widget_get_path() instead
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Obtains the full path to widget.
|
|
</p>
|
|
<p>
|
|
The path is simply the name of a widget and all its parents in the container hierarchy,
|
|
</p>
|
|
<p>
|
|
separated by periods. The name of a widget comes from gtk_widget_get_name().
|
|
</p>
|
|
<p>
|
|
Paths are used to apply styles to a widget in gtkrc configuration files.
|
|
</p>
|
|
<p>
|
|
Widget names are the type of the widget by default (e.g. “GtkButton”)
|
|
</p>
|
|
<p>
|
|
or can be set to an application-specific value with gtk_widget_set_name().
|
|
</p>
|
|
<p>
|
|
By setting the name of a widget, you allow users or theme authors to
|
|
</p>
|
|
<p>
|
|
apply styles to that specific widget their gtkrc file.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562846519978" ID="ID_696163537" LINK="https://developer.gnome.org/gtk3/stable/gtk3-GtkWidgetPath.html#GtkWidgetPath" MODIFIED="1562846664732" TEXT="GtkWidgetPath">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1562846666478" ID="ID_1250433736" MODIFIED="1562846671293" TEXT="ergiebige Doku">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1562847246347" ID="ID_1254636291" MODIFIED="1562847254881" TEXT="man kann Teile von einem Widget kopiert bekommen">
|
|
<node CREATED="1562847271831" ID="ID_1624054416" LINK="https://developer.gnome.org/gtk3/stable/gtk3-GtkWidgetPath.html#gtk-widget-path-append-for-widget" MODIFIED="1562847280845" TEXT="gtk-widget-path-append-for-widget"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562854903538" ID="ID_944355214" MODIFIED="1562854907642" TEXT="Gtk::WidgetPath">
|
|
<node CREATED="1562854908778" ID="ID_1256092544" MODIFIED="1576282357949" TEXT="ist ein boxed GTK-Objekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. nur ein Pointer auf ein GObj
|
|
</p>
|
|
<p>
|
|
mit automatischem Refcounting
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1562854931311" ID="ID_1401731034" MODIFIED="1562854940509" TEXT="kann mit dem default-Ctor leer erzeugt werden"/>
|
|
<node CREATED="1562854942971" ID="ID_395952844" MODIFIED="1562854961042" TEXT="wenn man es vom Widget explizit bezieht, wird der Pfad kopiert">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1562847187991" ID="ID_1894889012" MODIFIED="1562847225031" TEXT="anwenden....">
|
|
<node CREATED="1562847193914" ID="ID_1978755105" MODIFIED="1576282357949" TEXT="gtk_style_context_set_path ()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
As a consequence, the style will be regenerated to match the new given path.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1562847303783" ID="ID_803278574" LINK="https://stackoverflow.com/a/56415144/444796" MODIFIED="1562847334090" TEXT="man Kann WidetPath "frei stehend" verwenden (SO)">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535632661385" FOLDED="true" ID="ID_1021079796" MODIFIED="1557498707238" TEXT="Hierarchie">
|
|
<node CREATED="1535632673655" ID="ID_849385989" MODIFIED="1557498707238" TEXT="Gdk::Window">
|
|
<node CREATED="1535632686045" ID="ID_20909674" MODIFIED="1557498707238">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein Widget <i>kann</i> einem G<b>D</b>K-Window zugeordnet sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535632728343" ID="ID_1087443097" MODIFIED="1557498707238" TEXT="dieses repräsentiert den low-level Screen-Space"/>
|
|
<node CREATED="1535632754900" ID="ID_1804383493" MODIFIED="1557498707238" TEXT="diese Zuordnung heißt "mapping""/>
|
|
<node CREATED="1535632903512" ID="ID_653149380" MODIFIED="1557498707238" TEXT="Gtk::Widget::get_parent_window ()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1535632766298" ID="ID_651213437" MODIFIED="1557498707238" TEXT="Container">
|
|
<node CREATED="1535632771490" ID="ID_54072996" MODIFIED="1557498707238" TEXT="machen sich beim Hinzufügen den Kindern bekannt"/>
|
|
<node CREATED="1535632789207" ID="ID_1814287136" MODIFIED="1557498707238" TEXT="Gtk::Widget::get_parent ()">
|
|
<node CREATED="1535632854135" ID="ID_1093554517" MODIFIED="1557498707238" TEXT="Gtk::Container *"/>
|
|
<node CREATED="1535632860126" ID="ID_710254808" MODIFIED="1557498707238" TEXT="kann NULL sein"/>
|
|
</node>
|
|
<node CREATED="1535633353996" ID="ID_1722614856" MODIFIED="1557498707238" TEXT="Gtk::Widget::get_toplevel ()"/>
|
|
<node CREATED="1535633447375" ID="ID_1390203707" LINK="https://developer.gnome.org/gtkmm/3.22/classGtk_1_1Widget.html#ad65bedf64acfd0401abbe489312fba8e" MODIFIED="1557498707238" TEXT="Widget * Gtk::Widget::get_ancestor(GType widget_type)"/>
|
|
</node>
|
|
<node CREATED="1563630894868" ID="ID_222380322" MODIFIED="1563630929426" TEXT="WidgeqPath: die Sequenz von Top zum konkreten Widget">
|
|
<arrowlink COLOR="#76a5de" DESTINATION="ID_293762905" ENDARROW="Default" ENDINCLINATION="109;127;" ID="Arrow_ID_1149853107" STARTARROW="None" STARTINCLINATION="-391;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477523681978" HGAP="14" ID="ID_400257229" MODIFIED="1557498707238" TEXT="Richtlinien" VSHIFT="11">
|
|
<node CREATED="1477523701544" ID="ID_1802991794" MODIFIED="1557498707238" TEXT="empfohlen">
|
|
<node CREATED="1477523709342" ID="ID_781118281" MODIFIED="1557498707238" TEXT="Box">
|
|
<node CREATED="1477524273619" ID="ID_216152004" MODIFIED="1557498707238" TEXT="pack_start() / pack_end()"/>
|
|
<node COLOR="#ca1b00" CREATED="1477524282122" ID="ID_1542686719" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-multi-item-containers.html.en#per-child-packing-options" MODIFIED="1557498707238" TEXT="packing options">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477523710854" ID="ID_1520577996" MODIFIED="1557498707238" TEXT="Grid"/>
|
|
</node>
|
|
<node CREATED="1477523714526" ID="ID_654535915" MODIFIED="1576282357948" TEXT="Application verwenden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nicht mehr das <i>klassische</i> gtk::Main
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Wozu das?
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Design: Main war ein Singleton; aber sein dtor hat auch Plattform-Aufräum-Arbeiten gemacht
|
|
</li>
|
|
<li>
|
|
Framework: anscheinend ist hier eine Tendenz in Richtung auf ein integriertes Framework im Gange; im Besonderen will man "Aktionen" direkt aus dem Desktop aufrufen können<br />
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#627292" DESTINATION="ID_185528211" ENDARROW="Default" ENDINCLINATION="22;-122;" ID="Arrow_ID_390519319" STARTARROW="None" STARTINCLINATION="-31;42;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495221220040" HGAP="43" ID="ID_782313223" MODIFIED="1557498707238" TEXT="Framework" VSHIFT="-20">
|
|
<linktarget COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-981;-106;" ID="Arrow_ID_1912776282" SOURCE="ID_1636078216" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<linktarget COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-1088;-39;" ID="Arrow_ID_234165792" SOURCE="ID_433225506" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<linktarget COLOR="#677ab7" DESTINATION="ID_782313223" ENDARROW="Default" ENDINCLINATION="-652;20;" ID="Arrow_ID_315633048" SOURCE="ID_1894791438" STARTARROW="None" STARTINCLINATION="-2111;0;"/>
|
|
<node CREATED="1533388030963" FOLDED="true" ID="ID_1973994334" MODIFIED="1563630809180" TEXT="main context">
|
|
<node CREATED="1533388053839" ID="ID_970610402" MODIFIED="1533388063674" TEXT="abstrahierte "main loop"">
|
|
<node CREATED="1533388065237" ID="ID_1853196275" MODIFIED="1533388071944" TEXT="es gibt einen default_main_context"/>
|
|
<node CREATED="1533388072628" ID="ID_1382049092" MODIFIED="1533388077743" TEXT="dieser wird on demand erzeugt"/>
|
|
<node CREATED="1533388078595" ID="ID_1456212114" MODIFIED="1533388091037" TEXT="dieser wird von den run()-Funktionen "gepullt""/>
|
|
</node>
|
|
<node CREATED="1533388113350" ID="ID_1546795729" MODIFIED="1561827466205" TEXT="Glib::signal_idle()">
|
|
<node CREATED="1533388147720" ID="ID_1897188155" MODIFIED="1533388158218" TEXT="übergebene Closure läuft erst in der Event-Loop"/>
|
|
<node CREATED="1533388162662" ID="ID_1573817854" MODIFIED="1533388168352" TEXT="kann aber schon vorher hinzugefügt werden"/>
|
|
<node CREATED="1533388185290" ID="ID_1158890484" MODIFIED="1533388238450" TEXT="verwendet main_context_default">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und erzeugt diesen on demand auch neu
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1533388264550" ID="ID_32738634" MODIFIED="1533388282104" TEXT="gmain.c : g_source_attach"/>
|
|
<node CREATED="1533388282692" ID="ID_1259525027" MODIFIED="1533388301765" TEXT="gmain.c : g_main_context_default"/>
|
|
</node>
|
|
<node CREATED="1533388309295" ID="ID_775603522" MODIFIED="1533388317610" TEXT="man kann connect_once() macne"/>
|
|
</node>
|
|
<node CREATED="1533388128579" ID="ID_580405745" MODIFIED="1561827466205" TEXT="Glib::signal_timeout()">
|
|
<linktarget COLOR="#5568a6" DESTINATION="ID_580405745" ENDARROW="Default" ENDINCLINATION="-472;0;" ID="Arrow_ID_244184105" SOURCE="ID_1586631508" STARTARROW="None" STARTINCLINATION="-2132;-72;"/>
|
|
<node CREATED="1533388319102" ID="ID_1118350475" MODIFIED="1533388324553" TEXT="analog wie signal_idle()"/>
|
|
<node CREATED="1533388325053" ID="ID_1341702889" MODIFIED="1533388334672" TEXT="Timeout in Millisekunden"/>
|
|
<node CREATED="1533388335188" ID="ID_980760340" MODIFIED="1533388343815" TEXT="bedeutet Delay, nicht präzises Timing">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495221242285" FOLDED="true" ID="ID_185528211" MODIFIED="1563630800179" TEXT="Applikation">
|
|
<linktarget COLOR="#627292" DESTINATION="ID_185528211" ENDARROW="Default" ENDINCLINATION="22;-122;" ID="Arrow_ID_390519319" SOURCE="ID_654535915" STARTARROW="None" STARTINCLINATION="-31;42;"/>
|
|
<node CREATED="1495221272545" ID="ID_624250153" MODIFIED="1561827466206" TEXT="Gtk::Application">
|
|
<node CREATED="1495222327564" ID="ID_175461027" MODIFIED="1518487921099" TEXT="initialisiert Gio::Application"/>
|
|
<node CREATED="1495222337235" ID="ID_348472460" MODIFIED="1518487921099" TEXT="setzt ggfs. die Applikations-ID"/>
|
|
<node CREATED="1495223436241" ID="ID_1015366549" MODIFIED="1518487921099" TEXT="Application::run">
|
|
<node CREATED="1495223445527" ID="ID_1531454773" MODIFIED="1518487921099" TEXT="optional mit Window">
|
|
<node CREATED="1495223506111" ID="ID_992095337" MODIFIED="1518487921099" TEXT="macht aber nur window->show"/>
|
|
<node CREATED="1495223513438" ID="ID_1178606368" MODIFIED="1541088154146" TEXT="allerdings im activate-Callback">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum?
|
|
</p>
|
|
<p>
|
|
nur wegen ApplictationWindow!
|
|
</p>
|
|
<p>
|
|
Denn dieses setzte eine "Registrierung" voraus.
|
|
</p>
|
|
<p>
|
|
Alles in ein Framework zwingen. Alternativlos, capisce?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495223451598" ID="ID_1042773331" MODIFIED="1518487921099" TEXT="startet Gio::Application::run"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495221280336" ID="ID_1925569425" MODIFIED="1561827466211" TEXT="Gio::Application">
|
|
<node COLOR="#435e98" CREATED="1533309749035" HGAP="-6" ID="ID_274394313" MODIFIED="1533309768489" TEXT="entspricht GApplication in C" VSHIFT="-20">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1495221530614" ID="ID_1085605910" MODIFIED="1533306146656" TEXT="initialisiert das Framework">
|
|
<arrowlink DESTINATION="ID_1615155508" ENDARROW="Default" ENDINCLINATION="-27;-158;" ID="Arrow_ID_152226640" STARTARROW="None" STARTINCLINATION="-209;0;"/>
|
|
</node>
|
|
<node CREATED="1495221537366" ID="ID_381245884" MODIFIED="1518487921099" TEXT="stellt eine dBus-Verbindung bereit"/>
|
|
<node CREATED="1495221546252" ID="ID_771692992" MODIFIED="1518487921099" TEXT="erbt von Gio::ActionGroup und ActionMap"/>
|
|
<node CREATED="1533307013028" HGAP="32" ID="ID_1511454400" MODIFIED="1533608414135" TEXT="on activation" VSHIFT="16">
|
|
<node CREATED="1533307054478" ID="ID_1200897297" MODIFIED="1533307059929" TEXT="g_application_activate">
|
|
<node CREATED="1533307252691" ID="ID_11609503" MODIFIED="1533307276116" TEXT="gapplication.c (ca line 2220)"/>
|
|
<node CREATED="1533307297630" ID="ID_312502406" MODIFIED="1533307298225" TEXT="g_signal_emit (application, g_application_signals[SIGNAL_ACTIVATE], 0)"/>
|
|
</node>
|
|
<node CREATED="1533307413701" ID="ID_1516098159" MODIFIED="1533307416809" TEXT="aufgerufen von">
|
|
<node CREATED="1533307417845" ID="ID_1665005953" MODIFIED="1533307423040" TEXT="Gio::Application"/>
|
|
<node CREATED="1533307444641" ID="ID_1571069781" MODIFIED="1533307445757" TEXT="g_application_real_local_command_line">
|
|
<node CREATED="1533307489459" ID="ID_849008375" MODIFIED="1533307492846" TEXT="das ist class->local_command_line"/>
|
|
<node CREATED="1533307886653" ID="ID_322984790" MODIFIED="1541088154184" TEXT="wird auch von Gtkmm so erhalten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...allerdings eingepackt in eine vfunc,
|
|
</p>
|
|
<p>
|
|
welche ggfs C++ - Exceptions fängt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1533307599332" ID="ID_1228966939" MODIFIED="1533307626966" TEXT="aufgerufen von g_application_run">
|
|
<arrowlink DESTINATION="ID_1602611708" ENDARROW="Default" ENDINCLINATION="262;0;" ID="Arrow_ID_1688106140" STARTARROW="None" STARTINCLINATION="-50;95;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533309080840" ID="ID_1911292426" MODIFIED="1533309083211" TEXT="verwendet">
|
|
<node CREATED="1533309084015" ID="ID_103827073" MODIFIED="1533309275410" TEXT="vom Framework...">
|
|
<linktarget COLOR="#6280a2" DESTINATION="ID_103827073" ENDARROW="Default" ENDINCLINATION="-1131;-99;" ID="Arrow_ID_138401663" SOURCE="ID_574887736" STARTARROW="None" STARTINCLINATION="1028;-75;"/>
|
|
<node CREATED="1533309088679" ID="ID_603142056" MODIFIED="1533309096553" TEXT="um ein Fenster nach start darzustellen"/>
|
|
<node CREATED="1533309142479" ID="ID_1556321232" MODIFIED="1533309146650" TEXT="Gtk::Application::run(Window&)"/>
|
|
</node>
|
|
<node CREATED="1533311444004" ID="ID_1806268533" MODIFIED="1541088154201" TEXT="notwendig weil....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...nur wegen dem ganzen Registrierungs-Glump.
|
|
</p>
|
|
<p>
|
|
Ein "GTK-Application-Window" ist auch irgendwie registriert und hängt am Bus.
|
|
</p>
|
|
<p>
|
|
Frag mich nicht wie. Jedenfalls kann man das nicht im Konstruktor von Gtk::Application machen.
|
|
</p>
|
|
<p>
|
|
<i>Nur</i> das ist der Grund. Es <i>geht gar nicht</i> um die Event-Loop
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#949fb4" DESTINATION="ID_1806268533" ENDARROW="Default" ENDINCLINATION="-1845;-608;" ID="Arrow_ID_1146394851" SOURCE="ID_1211339520" STARTARROW="None" STARTINCLINATION="-474;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1533309280940" ID="ID_1482488845" MODIFIED="1541088154207" TEXT="Stand 8/2018 keine anderen Treffer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
suche (case insensitive) nach application_activate
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
treffer auf APPLICATION_ACTIVATE in g_application_activate()
|
|
</li>
|
|
<li>
|
|
die Treffer in Gtk::Application
|
|
</li>
|
|
<li>
|
|
diverse false positives mit anderen "Activation"-Signalen, z.B. in Aktionen oder Buttons
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1533309516556" ID="ID_459213298" MODIFIED="1541088154213">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nicht durch <b>gtk_main</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wichtige Einsicht:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
gtk_main ist Toolit ohne Framework
|
|
</li>
|
|
<li>
|
|
bietet keine solchen Lebenszyklus-Signale
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495223467588" HGAP="27" ID="ID_666842762" MODIFIED="1533608414137" TEXT="run" VSHIFT="12">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1533306448070" ID="ID_1602611708" MODIFIED="1533307626966" TEXT="g_application_run(gobj(), argc, argv)">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1602611708" ENDARROW="Default" ENDINCLINATION="262;0;" ID="Arrow_ID_1688106140" SOURCE="ID_1228966939" STARTARROW="None" STARTINCLINATION="-50;95;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1495223902619" ID="ID_11620264" MODIFIED="1518487921099" TEXT="behandelt Argumente"/>
|
|
<node CREATED="1495223912401" ID="ID_1575164060" MODIFIED="1518487921099" TEXT="falls Service: wartet auf Nachricht vom dBus"/>
|
|
<node CREATED="1533307972881" ID="ID_1094265011" MODIFIED="1533308000083">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
beachte: <b>ruft nicht gtk_main</b> sondern macht das Äquivalent
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1495224012668" ID="ID_566886010" MODIFIED="1518487921099" TEXT="Event-Loop">
|
|
<node CREATED="1495224031057" ID="ID_1352224458" MODIFIED="1518487921099" TEXT="use-count"/>
|
|
<node CREATED="1495224034585" ID="ID_1852291898" MODIFIED="1518487921099" TEXT="bestimmt, ob die Loop weiter läuft"/>
|
|
<node CREATED="1495224111895" ID="ID_1808871678" MODIFIED="1518487921099" TEXT="g_main_context_iteration">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1495224682595" HGAP="35" ID="ID_1221113124" MODIFIED="1518487921099" TEXT="g_main_context_iterate" VSHIFT="7">
|
|
<linktarget COLOR="#4da894" DESTINATION="ID_1221113124" ENDARROW="Default" ENDINCLINATION="-37;92;" ID="Arrow_ID_603815905" SOURCE="ID_355427981" STARTARROW="None" STARTINCLINATION="17;-42;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495224577105" FOLDED="true" HGAP="33" ID="ID_1924897671" MODIFIED="1563630803380" TEXT="Gtk::Main" VSHIFT="10">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1495224595638" ID="ID_1774384379" MODIFIED="1518487921099" TEXT="@deprecated">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1495224609188" ID="ID_1615155508" MODIFIED="1533608414139">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
initialisiert das
|
|
</p>
|
|
<p>
|
|
Framework
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1615155508" ENDARROW="Default" ENDINCLINATION="-27;-158;" ID="Arrow_ID_152226640" SOURCE="ID_1085605910" STARTARROW="None" STARTINCLINATION="-209;0;"/>
|
|
<node CREATED="1495224862227" ID="ID_762530588" MODIFIED="1518487921099" TEXT="init_gtkmm_internals"/>
|
|
<node CREATED="1495224890119" ID="ID_137730290" MODIFIED="1518487921099" TEXT="statische funktion"/>
|
|
<node CREATED="1532795620784" ID="ID_1850885017" MODIFIED="1533608414140" TEXT="gtk_init">
|
|
<linktarget COLOR="#87a8bf" DESTINATION="ID_1850885017" ENDARROW="Default" ENDINCLINATION="-195;-45;" ID="Arrow_ID_960670945" SOURCE="ID_377749143" STARTARROW="None" STARTINCLINATION="416;0;"/>
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1532796724776" ID="ID_685469322" MODIFIED="1532796729971" TEXT="bleibt weiterhin bestehen"/>
|
|
<node CREATED="1532796730560" ID="ID_727373355" MODIFIED="1532796741082" TEXT="wird von jeder Applikations-Klasse aufgerufen"/>
|
|
<node CREATED="1533305525992" ID="ID_1048078112" MODIFIED="1533305987413" TEXT="stellt elementare Initialisierung sicher">
|
|
<node CREATED="1533305546669" ID="ID_717378410" MODIFIED="1541088154260" TEXT="gtk_init_check">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gboolean
|
|
</p>
|
|
<p>
|
|
gtk_init_check (int    *argc,
|
|
</p>
|
|
<p>
|
|
                char ***argv)
|
|
</p>
|
|
<p>
|
|
{
|
|
</p>
|
|
<p>
|
|
  gboolean ret;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  if (!gtk_parse_args (argc, argv))
|
|
</p>
|
|
<p>
|
|
    return FALSE;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  ret = GDK_PRIVATE_CALL (gdk_display_open_default) () != NULL;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  if (gtk_get_debug_flags () & GTK_DEBUG_INTERACTIVE)
|
|
</p>
|
|
<p>
|
|
    gtk_window_set_interactive_debugging (TRUE);
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  return ret;
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1533305661254" ID="ID_1064217503" MODIFIED="1533305671871" TEXT="parse commandline">
|
|
<node CREATED="1533305895966" ID="ID_1828704033" MODIFIED="1533305900774" TEXT="init gettext"/>
|
|
<node CREATED="1533305890638" ID="ID_1711757539" MODIFIED="1533305894930" TEXT="keine weitere Magie"/>
|
|
</node>
|
|
<node CREATED="1533305672436" ID="ID_1662141734" MODIFIED="1533305683502" TEXT="open/attach to windowing system"/>
|
|
<node CREATED="1533305684102" ID="ID_41618780" MODIFIED="1533305691437" TEXT="enable interactive debugging"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533305534919" ID="ID_1905259387" MODIFIED="1533305545069" TEXT="terminiert ohne Windowing-System">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1532795594468" ID="ID_681479502" MODIFIED="1541088154286" TEXT="Main::init_gtkmm_internals">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
void Main::init_gtkmm_internals()
|
|
</p>
|
|
<p>
|
|
{
|
|
</p>
|
|
<p>
|
|
  static bool init_done = false;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
  if(!init_done)
|
|
</p>
|
|
<p>
|
|
  {
|
|
</p>
|
|
<p>
|
|
    Glib::init();
|
|
</p>
|
|
<p>
|
|
    Gio::init();
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
    // Populate the map of GTypes to C++ wrap_new() functions.
|
|
</p>
|
|
<p>
|
|
    Pango::wrap_init();
|
|
</p>
|
|
<p>
|
|
#ifdef GTKMM_ATKMM_ENABLED
|
|
</p>
|
|
<p>
|
|
    Atk::wrap_init();
|
|
</p>
|
|
<p>
|
|
#endif //GTKMM_ATKMM_ENABLED
|
|
</p>
|
|
<p>
|
|
    Gdk::wrap_init();
|
|
</p>
|
|
<p>
|
|
    Gtk::wrap_init();
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
    init_done = true;
|
|
</p>
|
|
<p>
|
|
  }
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#679cc6" DESTINATION="ID_681479502" ENDARROW="Default" ENDINCLINATION="-182;-16;" ID="Arrow_ID_1451320473" SOURCE="ID_1106606369" STARTARROW="None" STARTINCLINATION="273;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1532794577245" ID="ID_1061673956" MODIFIED="1532794580305" TEXT="was macht das?">
|
|
<node CREATED="1532796682566" ID="ID_1741006267" MODIFIED="1532796691801" TEXT="Glib, Gio und Pango initialisieren"/>
|
|
<node CREATED="1532796692445" ID="ID_1058977996" MODIFIED="1532796706398" TEXT="Wrapper-Mechanismus für Gtk+-"Objekte" initialisieren"/>
|
|
<node COLOR="#435e98" CREATED="1533303515053" ID="ID_806534769" MODIFIED="1533303521236" TEXT="im Detail....">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1533302528747" ID="ID_436589291" MODIFIED="1533302531718" TEXT="Glib::init"/>
|
|
<node CREATED="1533302532330" ID="ID_1077746701" MODIFIED="1533302534862" TEXT="Gio::init">
|
|
<node CREATED="1533302535642" ID="ID_669104938" MODIFIED="1533302538965" TEXT="Glib::init">
|
|
<node CREATED="1533302837329" ID="ID_1446415127" MODIFIED="1533302841899" TEXT="wiederum...">
|
|
<node CREATED="1533302842944" ID="ID_974899245" MODIFIED="1533302853323" TEXT="Gio::wrap_init()"/>
|
|
<node CREATED="1533302853959" ID="ID_872170516" MODIFIED="1533302861305" TEXT="Gio::wrap_register_init()"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533302544745" ID="ID_358165246" MODIFIED="1533302550260" TEXT="Gio::wrap_init()">
|
|
<node CREATED="1533302581788" ID="ID_1825151057" MODIFIED="1533302612899" TEXT="viele Aufrufe Glib::wrap_register(...)"/>
|
|
<node CREATED="1533302590130" ID="ID_815735282" MODIFIED="1533302604205" TEXT="richtet C++-Bindings ein"/>
|
|
<node CREATED="1533302617511" ID="ID_1544414198" MODIFIED="1533302640740" TEXT="sonst keine Funktionalität ersichtlich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1532794561968" ID="ID_1365959028" MODIFIED="1532796658012" TEXT="ist das zukunfts-fest?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1532796634853" ID="ID_1398685017" MODIFIED="1532796646840" TEXT="in application.cc gibts die gleiche Funktion">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1532796648307" ID="ID_8715855" MODIFIED="1532796654824" TEXT="kein Grund zur Sorge">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495224625466" ID="ID_668309036" MODIFIED="1533325422859" TEXT="run">
|
|
<node CREATED="1495224647071" ID="ID_660577000" MODIFIED="1533608414143" TEXT="gtk_main">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1495224649943" ID="ID_1753452940" MODIFIED="1518487921099" TEXT="g_main_loop_run">
|
|
<node CREATED="1495224690714" ID="ID_355427981" MODIFIED="1518487921099" TEXT="g_main_context_iterate">
|
|
<arrowlink COLOR="#4da894" DESTINATION="ID_1221113124" ENDARROW="Default" ENDINCLINATION="-37;92;" ID="Arrow_ID_603815905" STARTARROW="None" STARTINCLINATION="17;-42;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1533308108853" ID="ID_650869075" MODIFIED="1533308136078" TEXT="entspricht (im Kern) g_application_run">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1533309576891" ID="ID_1533505296" MODIFIED="1533309583947" TEXT="ohne Lebenzyklus-Management">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1495224989674" FOLDED="true" HGAP="18" ID="ID_381583771" MODIFIED="1557498707238" TEXT="Verhältnis beider" VSHIFT="9">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1495225019502" ID="ID_1829681403" MODIFIED="1557498707238" TEXT="beide machen in etwas das Gleiche"/>
|
|
<node CREATED="1495225006920" ID="ID_1631847350" MODIFIED="1557498707238" TEXT="Application ist generischer"/>
|
|
<node CREATED="1495226503104" ID="ID_1991720691" MODIFIED="1557498707238" TEXT="es geht dabei um Desktop-Integration"/>
|
|
<node CREATED="1533308053493" ID="ID_281791270" MODIFIED="1576282357948" TEXT="Gio::Application ruft g_application_run">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und das ist <i>nicht</i> gtk_main,
|
|
</p>
|
|
<p>
|
|
aber macht in etwa die gleichen Operationen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1495225050138" ID="ID_1077152710" MODIFIED="1576282357947" TEXT="gtk_main beruht heute auf Gio">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt, es wurde "retrofitted".
|
|
</p>
|
|
<p>
|
|
die Lib Gio bietet ein generisches "Main-Loop-Framework",
|
|
</p>
|
|
<p>
|
|
in dem ein Main-Context gepollt wird, solange, bis ein use-count auf Null geht.
|
|
</p>
|
|
<p>
|
|
Gtk-Main verwendet inzwischen den gleichen Mechanismus
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501848602610" FOLDED="true" ID="ID_1830965770" MODIFIED="1561827466220" TEXT="Threading">
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1501848605874" ID="ID_420183704" MODIFIED="1518487921099" TEXT="nur ein GUI-Thread">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1501848662730" ID="ID_699612019" MODIFIED="1518487921099" TEXT="absichtlich nicht treadsafe">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1501848672921" ID="ID_1641235315" MODIFIED="1518487921099" TEXT="SigC++ nicht Threadsafe">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1501848716179" ID="ID_969916851" MODIFIED="1518487921099" TEXT="alle Signals + Slots nur im GUI-Thread"/>
|
|
<node CREATED="1501848914377" ID="ID_1614034013" MODIFIED="1576282357947" TEXT="Vorsicht: Desktuktoren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der springende Punkt mit sigc::trackable ist,
|
|
</p>
|
|
<p>
|
|
daß Desktuktoren automatisch die Signale abkoppeln.
|
|
</p>
|
|
<p>
|
|
Dieser Vorgang ist <b>nicht threadsafe</b>. Folglich müssen
|
|
</p>
|
|
<p>
|
|
auch die <b>Destruktoen</b> im GUI-Thread laufen.
|
|
</p>
|
|
<p>
|
|
Das ist eine subtile Falle.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1501848728354" ID="ID_1420494100" MODIFIED="1518487921099">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alles was von sigc::<b>trackable</b> erbt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1501848774883" ID="ID_1801418640" MODIFIED="1518487921099" TEXT="Glib::Dispatcher">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1501848781850" ID="ID_356349390" MODIFIED="1576282357946">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
für <b>alles</b> aus GTKmm zu verwenden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...gemeint ist:
|
|
</p>
|
|
<p>
|
|
alles das nicht aus dem GUI-Thread heraus geschieht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1501848836523" ID="ID_649355856" MODIFIED="1518487921099" TEXT="Dispatcher im GUI-Thread erzeugen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1501861717318" ID="ID_852290990" MODIFIED="1518487921099" TEXT="braucht einen Glib::MainContext"/>
|
|
<node CREATED="1501861732604" ID="ID_958721843" MODIFIED="1518487921100" TEXT="und den gibts, wenn gtk_init gelaufen ist"/>
|
|
</node>
|
|
<node CREATED="1501848867535" ID="ID_1897804143" MODIFIED="1518487921100" TEXT="emit -> Event-Loop"/>
|
|
</node>
|
|
<node CREATED="1501849055902" ID="ID_569777034" MODIFIED="1518487921100" TEXT="Policy">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1501849060757" ID="ID_1858198840" MODIFIED="1518487921100" TEXT="Mutterklasse statt Singletons"/>
|
|
<node CREATED="1501849075795" ID="ID_374275577" MODIFIED="1518487921100" TEXT="alle Aufrufe via Facade"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477785704584" ID="ID_528329491" MODIFIED="1557498707238" TEXT="event handling">
|
|
<node CREATED="1477785727469" ID="ID_129787833" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/chapter-signals.html.en" MODIFIED="1557498707238" TEXT="Guide: Kapitel "Signals""/>
|
|
<node CREATED="1477785747138" ID="ID_4618201" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-xeventsignals.html.en" MODIFIED="1557498707238" TEXT="speziell Details zu event Handlern: X event signals">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1617889469414" ID="ID_1224226747" LINK="https://developer.gnome.org/gtk3/stable/chap-input-handling.html" MODIFIED="1617889488739" TEXT="The GTK Event handling model">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1477785807338" ID="ID_80062368" MODIFIED="1557498707238" TEXT="wie">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1477785809930" ID="ID_596393977" MODIFIED="1557498707238" TEXT="signal connect()"/>
|
|
<node COLOR="#ca1b00" CREATED="1477785830295" ID="ID_94782325" MODIFIED="1557498707238" TEXT="-- oder --"/>
|
|
<node CREATED="1477785818920" ID="ID_1600280983" MODIFIED="1557498707238" TEXT="on_xxx() überschreiben">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1600280983" ENDARROW="Default" ENDINCLINATION="893;0;" ID="Arrow_ID_1707544457" SOURCE="ID_111966354" STARTARROW="None" STARTINCLINATION="893;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477785856731" ID="ID_63204089" MODIFIED="1557498707238" TEXT="Rückgabewert: true == fertig behandelt"/>
|
|
<node CREATED="1614466718256" FOLDED="true" ID="ID_1861948898" LINK="https://developer.gnome.org/libsigc++-tutorial/stable/" MODIFIED="1614467271110" TEXT="beruht auf Lib SigC++">
|
|
<node CREATED="1614466752396" ID="ID_741341742" MODIFIED="1614466766212" TEXT="diese unterstützt inzwischen voll C++11 (incl Lambdas)"/>
|
|
<node CREATED="1614466921957" ID="ID_427930105" MODIFIED="1614467268405" TEXT="Thema: track and detach slots">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1614466956096" ID="ID_1002681236" MODIFIED="1614466978183" TEXT="Signal könnte Slot auf einem bereits toten Objekt aufrufen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1614466978880" ID="ID_1226117301" MODIFIED="1614467017795" TEXT="sigc::trackable : Basisklasse für Objekte, die Slots automatisch deaktivieren"/>
|
|
<node CREATED="1614467041725" ID="ID_1616467014" MODIFIED="1614467059518" TEXT="slot(mem_fun(stigc::trackable, ....)">
|
|
<node CREATED="1614467070937" ID="ID_651462037" MODIFIED="1614467085686" TEXT="dieser wird nicht mehr aufgerufen nach dem das Trackable tot ist"/>
|
|
<node CREATED="1614467086284" ID="ID_1708957515" MODIFIED="1614467105649" TEXT="analog für alle Verbindungen via <signal>.connect()"/>
|
|
</node>
|
|
<node CREATED="1614467221680" ID="ID_1190660197" MODIFIED="1614467233958" TEXT="alternativ kann man lambdas direkt anschließen">
|
|
<node CREATED="1614467235118" ID="ID_1908157491" MODIFIED="1614467242637" TEXT="dann gibt es aber kein Tracking"/>
|
|
<node CREATED="1614467243390" ID="ID_162571863" MODIFIED="1614467252868" TEXT="se sei denn, man verwendet sigc::track_obj"/>
|
|
<node CREATED="1614467253912" ID="ID_230224690" LINK="https://developer.gnome.org/libsigc++/stable/group__track__obj.html" MODIFIED="1617458023813" TEXT="siehe Beispiel in der Doku">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<div http-equiv="content-type" content="text/html; charset=utf-8" class="fragment">
|
|
<div class="line">
|
|
struct bar : public <a class="code" href="https://developer.gnome.org/libsigc++/stable/structsigc_1_1trackable.html">sigc::trackable</a> {};
|
|
</div>
|
|
<div class="line">
|
|
sigc::signal<void()> some_signal;
|
|
</div>
|
|
<div class="line">
|
|
void foo(bar&);
|
|
</div>
|
|
<div class="line">
|
|
{
|
|
</div>
|
|
<div class="line">
|
|
bar some_bar;
|
|
</div>
|
|
<div class="line">
|
|
some_signal.connect([&some_bar](){ foo(some_bar); });
|
|
</div>
|
|
<div class="line">
|
|
// NOT disconnected automatically when some_bar goes out of scope
|
|
</div>
|
|
<div class="line">
|
|
some_signal.connect(<a class="code" href="https://developer.gnome.org/libsigc++/stable/group__track__obj.html#ga7986f33675aec143d9afbfe968f1c7ba">sigc::track_obj</a>([&some_bar](){ foo(some_bar); }, some_bar);
|
|
</div>
|
|
<div class="line">
|
|
// disconnected automatically when some_bar goes out of scope
|
|
</div>
|
|
<div class="line">
|
|
}
|
|
</div>
|
|
</div>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617571049865" FOLDED="true" ID="ID_1775827325" MODIFIED="1617571061764" TEXT="Low-Level-Events (GDK)">
|
|
<node CREATED="1617571081549" ID="ID_758420897" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-xeventsignals.html.en" MODIFIED="1617571132608" TEXT="Tutorial"/>
|
|
<node CREATED="1617578520434" ID="ID_1901070467" MODIFIED="1617578522333" TEXT="Quellen">
|
|
<node CREATED="1617578526137" ID="ID_1073829112" MODIFIED="1617578530459" TEXT="gdkevents.h"/>
|
|
</node>
|
|
<node CREATED="1666314102389" ID="ID_775914278" MODIFIED="1666314192593" TEXT="Empfang von Events einrichten">
|
|
<linktarget COLOR="#7788e0" DESTINATION="ID_775914278" ENDARROW="Default" ENDINCLINATION="-1021;-87;" ID="Arrow_ID_632223489" SOURCE="ID_2075291" STARTARROW="None" STARTINCLINATION="-1049;77;"/>
|
|
<node CREATED="1666313931612" ID="ID_1877761104" LINK="https://developer-old.gnome.org/gtkmm/3.20/classGtk_1_1Widget.html#adeb38a3d5988a0e31055bbd2edb2e954" MODIFIED="1666314244599" TEXT="siehe Beschreibung zu Gtk::Widget::set_events(Gdk::EventMask)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
The event mask determines which events a widget will receive. Keep in mind that different widgets have different default event masks, and by changing the event mask you may disrupt a widget’s functionality, so be careful. This function must be called while a widget is unrealized. Consider
|
|
|
|
<p>
|
|
<a http-equiv="content-type" content="text/html; charset=utf-8" class="el" href="https://developer-old.gnome.org/gtkmm/3.20/classGtk_1_1Widget.html#a1af589cb1d8764be5abf5579ffb69bec" title="Adds the events in the bitfield events to the event mask for widget. ">add_events()</a> for widgets that are already realized, or if you want to preserve the existing event mask. This function can’t be used with widgets that have no window. (See <a class="el" href="https://developer-old.gnome.org/gtkmm/3.20/classGtk_1_1Widget.html#a00d5da71916c20935fa7b9d856b248c2" title="Determines whether widget has a Gdk::Window of its own. ">get_has_window()</a>). To get events on those widgets, place them inside a <a class="el" href="https://developer-old.gnome.org/gtkmm/3.20/classGtk_1_1EventBox.html" title="Event capturing box. ">Gtk::EventBox</a> and receive events on the event box.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666314867550" ID="ID_1764116146" MODIFIED="1666314878146" TEXT="Voraussetzung: Widget muß ein GdkWindow haben">
|
|
<node CREATED="1666315602187" ID="ID_1896183986" MODIFIED="1666315703501" TEXT="nur einige Widgets haben ein Window">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1666315623272" ID="ID_1662006698" MODIFIED="1666315697281" TEXT="das sind auch diejenigen, die spezivische Event-Funktionalität bieten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Button hat ein Window, denn er möchte button_pressed-Events empfangen
|
|
</li>
|
|
<li>
|
|
Frame dagegen hat kein Window, Icon auch nicht
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1666315712676" ID="ID_702286995" MODIFIED="1666315725520" TEXT="Tip: get_has_window() zur Diagnose">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666314914943" ID="ID_264147295" MODIFIED="1666314936815" TEXT="Gtk::EventBox : Container zum Empfangen von Events">
|
|
<node CREATED="1666315152544" ID="ID_658878845" MODIFIED="1666315166554" TEXT="visible_window">
|
|
<node CREATED="1666315167614" ID="ID_247667753" MODIFIED="1666315176186" TEXT="ja: Hintergrund-Fenster"/>
|
|
<node CREATED="1666315176870" ID="ID_736709885" MODIFIED="1666315182856" TEXT="nein: reiner Event-Fänger">
|
|
<node CREATED="1666315189291" ID="ID_1252686683" MODIFIED="1666315277488" TEXT="vorsicht Falle">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ein Kind-Widget sein eigenes Fenster aufmacht, dann ist ein unsichtbares EventBox-GdkWindow <i>nicht ein Parent-Window</i> von dem Kind-Widget-Window. Das kann das Propagieren von Events verhindern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1666315289541" ID="ID_1282030961" MODIFIED="1666315295520" TEXT="above/below child">
|
|
<node CREATED="1666315298266" ID="ID_968292588" MODIFIED="1666315309926" TEXT="wer empfängt die Events zuerst?"/>
|
|
<node CREATED="1666315310777" ID="ID_1344206532" MODIFIED="1666315324021" TEXT="above: EventBox überdeckt und greift alle Events ab"/>
|
|
<node CREATED="1666315325549" ID="ID_1209236546" MODIFIED="1666315333027" TEXT="below: erst das Kind, dann Propagation"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617576420772" ID="ID_1731089051" MODIFIED="1617578512853" TEXT="Fälle">
|
|
<node CREATED="1617578538614" ID="ID_312257050" MODIFIED="1617578538614" TEXT="_GdkEventMotion"/>
|
|
<node CREATED="1617578546055" MODIFIED="1617578546055" TEXT="_GdkEventButton"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617889018573" FOLDED="true" ID="ID_366430158" MODIFIED="1617889193688" TEXT=""grab" (some) events">
|
|
<linktarget COLOR="#3f56d9" DESTINATION="ID_366430158" ENDARROW="Default" ENDINCLINATION="-1512;175;" ID="Arrow_ID_1894977369" SOURCE="ID_1217512191" STARTARROW="None" STARTINCLINATION="-5374;669;"/>
|
|
<node CREATED="1617889216544" ID="ID_758949629" MODIFIED="1617889221522" TEXT="Doku/Beschreibungen">
|
|
<node CREATED="1617889225238" ID="ID_1356113723" LINK="https://www.linuxtopia.org/online_books/gui_toolkit_guides/gtk+_gnome_application_development/sec-gdkcursor_1.html" MODIFIED="1617889237503" TEXT="Linuxtopia: grabbing the pointer"/>
|
|
<node CREATED="1617912074084" ID="ID_1495099926" LINK="https://developer.gnome.org/gtk3/stable/chap-input-handling.html#id-1.2.7.3.7" MODIFIED="1617912084177" TEXT="Definition: implicit and explicit grabs"/>
|
|
</node>
|
|
<node CREATED="1617889737497" ID="ID_1734077476" MODIFIED="1617889751715" TEXT="auf GDK-Ebene für das Display(X) insgesamt">
|
|
<node CREATED="1617891813242" ID="ID_573627567" MODIFIED="1617891819801" TEXT="gilt für alle Applikationen"/>
|
|
<node CREATED="1617891820437" ID="ID_159394462" MODIFIED="1617891886412" TEXT="aber nur für die low-level-Maus-Events">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
jedoch indirekt dann auch für darauf aufbauende Events, z.B. GTK-Events, weil eben nur noch das zum grabbed window gehörige Widgets diese Events überhaupt sieht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1617891887779" ID="ID_659611722" MODIFIED="1617891903519" TEXT="zuverlässig beenden, sonst friert das gesamte Display ein">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617889752694" ID="ID_1346101076" MODIFIED="1617889805828" TEXT="GTK+ bietet zusätzlich ein "grabbing widget" (z.B. modale Dialogbox)">
|
|
<linktarget COLOR="#6578a3" DESTINATION="ID_1346101076" ENDARROW="Default" ENDINCLINATION="-2521;108;" ID="Arrow_ID_1579913575" SOURCE="ID_1338391945" STARTARROW="None" STARTINCLINATION="-4417;512;"/>
|
|
<node CREATED="1617889845780" ID="ID_786899199" LINK="https://www.linuxtopia.org/online_books/gui_toolkit_guides/gtk+_gnome_application_development/sec-gdkevent_2.html#SEC-GRABS" MODIFIED="1617889861555" TEXT="Linuxtopia: receiving GDK events in GTK+"/>
|
|
<node CREATED="1617891663427" ID="ID_548825317" LINK="https://developer.gnome.org/gtk3/stable/gtk3-General.html#gtk-grab-add" MODIFIED="1617891680797" TEXT="gtk_grab_add(widget)"/>
|
|
<node CREATED="1617891683600" ID="ID_546679257" MODIFIED="1617891717399" TEXT="das ist ein ziemlich starker Eingriff">
|
|
<node CREATED="1617891718627" ID="ID_498617078" MODIFIED="1617891750043" TEXT="ein "grabed widget" empfängt alle Maus- und Tastatur-Events"/>
|
|
<node CREATED="1617891750628" ID="ID_1890756438" MODIFIED="1617891763768" TEXT="der Rest des GUI ist weitgehend deaktiviert"/>
|
|
<node CREATED="1617891777971" ID="ID_919159260" MODIFIED="1617891803969" TEXT="man muß es zuverlässig beenden, sonst ist das UI praktisch tot">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1618067891301" ID="ID_1730673667" MODIFIED="1618067900500" TEXT="Gestures in GTK">
|
|
<node CREATED="1618067902248" ID="ID_713192110" MODIFIED="1618067922572" TEXT="relatetd topic: Shortcuts">
|
|
<node CREATED="1618067923908" ID="ID_989712509" MODIFIED="1618067928769" TEXT="GtkShortcutController">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663946250024" ID="ID_1142643633" MODIFIED="1663946255308" TEXT="Layout management">
|
|
<node CREATED="1663946256977" FOLDED="true" ID="ID_1464608958" MODIFIED="1672843870753" TEXT="Thema: Size-Handling">
|
|
<arrowlink COLOR="#7584a4" DESTINATION="ID_464303848" ENDARROW="Default" ENDINCLINATION="115;-178;" ID="Arrow_ID_1938018383" STARTARROW="None" STARTINCLINATION="328;-32;"/>
|
|
<linktarget COLOR="#536cc0" DESTINATION="ID_1464608958" ENDARROW="Default" ENDINCLINATION="-1020;1248;" ID="Arrow_ID_1013900284" SOURCE="ID_1969670799" STARTARROW="None" STARTINCLINATION="-2004;139;"/>
|
|
<node COLOR="#435e98" CREATED="1612527499386" FOLDED="true" HGAP="34" ID="ID_615948747" MODIFIED="1664401278771" TEXT="Untersuchung: size_request — 2/21 + 9/22 für Clip-Display" VSHIFT="-49">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....bin damals mit size_request eingestiegen — aber von dort bald auf <font face="Monospaced" size="3" color="#f72929">gtk_widget_size_allocate_with_baseline </font>gestoßen; letzteres ist die eigentliche zentrale Funktion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#364ec7" DESTINATION="ID_615948747" ENDARROW="Default" ENDINCLINATION="-1440;0;" ID="Arrow_ID_866144981" SOURCE="ID_643882250" STARTARROW="None" STARTINCLINATION="-1942;189;"/>
|
|
<linktarget COLOR="#4b67b0" DESTINATION="ID_615948747" ENDARROW="Default" ENDINCLINATION="-1100;0;" ID="Arrow_ID_1297405131" SOURCE="ID_1143769023" STARTARROW="None" STARTINCLINATION="-2000;141;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1612530135923" ID="ID_597723725" MODIFIED="1612530155607" TEXT="gtkwidget.c Zeile 5960ff">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1664400907408" HGAP="25" ID="ID_1036425614" MODIFIED="1664401150443" TEXT="Vorsicht Sackgasse" VSHIFT="1">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1612532127121" FOLDED="true" ID="ID_1698900734" MODIFIED="1664474635424" TEXT="gtk_widget_set_size_request">
|
|
<icon BUILTIN="idea"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1663948672795" ID="ID_1935344830" MODIFIED="1663948681710" TEXT=" gtkwidget.c 11186"/>
|
|
<node CREATED="1663949014421" ID="ID_761292468" MODIFIED="1663949024301" TEXT="definiert die Mindes-Anforderung dieses Widgets"/>
|
|
<node CREATED="1663949035261" ID="ID_1775424216" MODIFIED="1663949054174" TEXT="kann undefiniert sein (-1) ⟹ dann natural request"/>
|
|
<node CREATED="1612532223794" ID="ID_1417902323" MODIFIED="1612532224951" TEXT="gtk_widget_set_usize_internal">
|
|
<node CREATED="1612532273671" ID="ID_1466904431" MODIFIED="1612532285991" TEXT="übernimmt die Werte in den internen PImpl"/>
|
|
<node CREATED="1612532301521" ID="ID_1985717542" MODIFIED="1663954418865">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
setzt bei Bedarf ein <b>queue_resize</b> ab
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1663948849724" ID="ID_592500885" MODIFIED="1663948855049" TEXT="wenn widget sichtbar ist"/>
|
|
<node CREATED="1663948855574" ID="ID_1581313527" MODIFIED="1663948882381" TEXT="und Höhe oder Breite wirklich geändert sind"/>
|
|
</node>
|
|
<node CREATED="1663954499071" ID="ID_1959081786" MODIFIED="1663955501010">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>danach</u>: priv->resize_needed = TRUE
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#852376" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="18;-93;" ID="Arrow_ID_1194665328" STARTARROW="None" STARTINCLINATION="-211;17;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612532323107" ID="ID_194122765" MODIFIED="1612532337848" TEXT="d.h. danach sind priv->height bzw priv->width gesetzt"/>
|
|
<node CREATED="1663949727304" ID="ID_1165234670" MODIFIED="1663949735266" TEXT="setzt gtk_widget_set_alloc_needed">
|
|
<node CREATED="1663949745454" ID="ID_313723300" MODIFIED="1663951388123" TEXT="Flag priv->alloc_needed">
|
|
<arrowlink COLOR="#b51c69" DESTINATION="ID_1132981577" ENDARROW="Default" ENDINCLINATION="34;-19;" ID="Arrow_ID_684196469" STARTARROW="None" STARTINCLINATION="-49;6;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664400929963" ID="ID_1240876072" MODIFIED="1664400943998" TEXT="size_request sieht ganz stark nach einem obsoleten Konzept aus">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1664400954960" ID="ID_776024263" MODIFIED="1664400966888" TEXT="er wirkt sich eigentlich nur auf die min-size aus"/>
|
|
<node CREATED="1664400967726" ID="ID_1498608883" MODIFIED="1664465602240" TEXT="und diese wird oft nur für Konsistenzchecks verwendet"/>
|
|
<node CREATED="1664465681826" ID="ID_1467702205" MODIFIED="1664465820561" TEXT="nicht klar wann die min-size verwendet wird">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Container-Widgets haben so etwas wie ein generisches Layout-Muster ⟹ <b>gtk_widget_size_allocate_with_baseline</b>
|
|
</li>
|
|
<li>
|
|
ABER es gibt anscheinend viele Widgets, die das direkt machen (und vom Container-Konzept bewegt sich GTK weg, zu Gunsten des Konzepts "CSS Gadget"); konkret habe ich bei einem <b>GtkFrame</b> durchaus beobachtet, daß dem Widget nur seine geforderte min-size zugeteilt wurde
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664474172428" ID="ID_982750434" MODIFIED="1664474183159" TEXT="normaler Container-Code ignoriert sie"/>
|
|
<node CREATED="1664474184106" ID="ID_1675446189" MODIFIED="1664474193374" TEXT="flow-Layout beachtet sie als Anschlag"/>
|
|
<node CREATED="1664474193962" ID="ID_1768206919" MODIFIED="1664486187383" TEXT="GtkLayout(Canvas) verwendet sie als Basis">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_1788566311" ENDARROW="Default" ENDINCLINATION="-47;-177;" ID="Arrow_ID_590130036" STARTARROW="None" STARTINCLINATION="287;18;"/>
|
|
<linktarget COLOR="#bed1fd" DESTINATION="ID_1768206919" ENDARROW="Default" ENDINCLINATION="-2510;160;" ID="Arrow_ID_1173769741" SOURCE="ID_1038149541" STARTARROW="None" STARTINCLINATION="-2083;106;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664467386286" ID="ID_175060844" MODIFIED="1664474394992" TEXT="widget_class->size_allocate">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="back"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664467416306" ID="ID_111898596" MODIFIED="1664474697760" STYLE="bubble">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Einstiegspunkt</u> aus vielen Widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#5247dc"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
</node>
|
|
<node CREATED="1664474418764" ID="ID_602033868" MODIFIED="1664474496100" TEXT="wer ruft das auf?">
|
|
<linktarget COLOR="#655e7d" DESTINATION="ID_602033868" ENDARROW="Default" ENDINCLINATION="-419;67;" ID="Arrow_ID_1884820801" SOURCE="ID_165291290" STARTARROW="None" STARTINCLINATION="-846;67;"/>
|
|
<node CREATED="1664471955447" ID="ID_748019971" MODIFIED="1664474513890" TEXT="Aufruf via widget_class!"/>
|
|
<node CREATED="1664471995913" ID="ID_486609942" MODIFIED="1664472003787" TEXT="hängt vom Widget ab">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664472301300" ID="ID_1282453232" MODIFIED="1664472485480" TEXT="nur wenige Aufrufe">
|
|
<node CREATED="1664472486343" ID="ID_12332143" MODIFIED="1664472489155" TEXT="top-level">
|
|
<node CREATED="1664472498670" ID="ID_928074515" MODIFIED="1664472506937" TEXT="gtk_application_window_real_size_allocate"/>
|
|
<node CREATED="1664472541528" ID="ID_1301393892" MODIFIED="1664472545202" TEXT="einige Dialogboxen"/>
|
|
<node CREATED="1664472707992" ID="ID_1435876974" MODIFIED="1664474945399">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>gtk_widget_size_allocate_with_baseline</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#692b5b" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="668;-205;" ID="Arrow_ID_378269338" STARTARROW="None" STARTINCLINATION="-279;578;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664472574035" ID="ID_535631528" MODIFIED="1664472582542" TEXT="gtk_label_size_allocate"/>
|
|
<node CREATED="1664474775284" ID="ID_1855152369" MODIFIED="1664474877769" TEXT="gtk_layout_size_allocate">
|
|
<arrowlink COLOR="#d8764f" DESTINATION="ID_159142787" ENDARROW="Default" ENDINCLINATION="53;-60;" ID="Arrow_ID_1501616113" STARTARROW="None" STARTINCLINATION="217;26;"/>
|
|
</node>
|
|
<node CREATED="1664472596690" ID="ID_1526836824" MODIFIED="1664472603892" TEXT="gtk_level_bar_size_allocate"/>
|
|
<node CREATED="1664472629652" ID="ID_844975218" MODIFIED="1664472635736" TEXT="gtk_overlay_size_allocate"/>
|
|
<node CREATED="1664472651913" ID="ID_1391420718" MODIFIED="1664472657652" TEXT="gtk_scale_size_allocate"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664473954962" ID="ID_1808329181" MODIFIED="1664474389674" TEXT="">
|
|
<node CREATED="1664473992889" ID="ID_1943066029" MODIFIED="1664474570171" TEXT="Normalerweise">
|
|
<node CREATED="1664474571526" ID="ID_1267258985" MODIFIED="1664474577490" TEXT="fragt das Kind-Widget"/>
|
|
<node CREATED="1664474578174" ID="ID_1361243851" MODIFIED="1664474587235" TEXT="ermittelt daraus den Platzbedarf"/>
|
|
</node>
|
|
<node CREATED="1664474033815" ID="ID_559670461" MODIFIED="1664474077090">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>aber</b>: spezielle Widgets/Container
|
|
</p>
|
|
<p>
|
|
behandeln hier die Child-Widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1664472707992" ID="ID_1917960846" MODIFIED="1664474093490">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>gtk_widget_size_allocate_with_baseline</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#692b5b" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="621;-190;" ID="Arrow_ID_152388281" STARTARROW="None" STARTINCLINATION="-357;417;"/>
|
|
</node>
|
|
<node CREATED="1664474775284" ID="ID_256729062" MODIFIED="1664474808855" TEXT="gtk_layout_size_allocate">
|
|
<node CREATED="1664474099975" ID="ID_159142787" MODIFIED="1664474867466" TEXT="Canvas-Widget: GtkLayout">
|
|
<linktarget COLOR="#d8764f" DESTINATION="ID_159142787" ENDARROW="Default" ENDINCLINATION="53;-60;" ID="Arrow_ID_1501616113" SOURCE="ID_1855152369" STARTARROW="None" STARTINCLINATION="217;26;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1664474832124" ID="ID_489352324" MODIFIED="1664474842148" TEXT="gtk_layout_allocate_child"/>
|
|
<node CREATED="1664474124347" ID="ID_304352916" MODIFIED="1664474846281" TEXT="ist speziell">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664474128731" ID="ID_1788566311" MODIFIED="1664474227120" TEXT="geht bei der Zuteilung vom min-Size aus">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1788566311" ENDARROW="Default" ENDINCLINATION="-47;-177;" ID="Arrow_ID_590130036" SOURCE="ID_1768206919" STARTARROW="None" STARTINCLINATION="287;18;"/>
|
|
</node>
|
|
<node CREATED="1664474142145" ID="ID_1619579487" MODIFIED="1664474155419" TEXT="dann weiter height-for-width oder umgekehrt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664467426400" ID="ID_323560628" MODIFIED="1664467636855">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beachte: <font face="Monospaced" size="3">_GtkCssGadgetClass-><b>allocate</b></font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1664467481890" ID="ID_1905806062" MODIFIED="1664467488412" TEXT="bekommt eine "allocate_func""/>
|
|
<node CREATED="1664467720488" ID="ID_994987639" MODIFIED="1664467794848">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u><i>typischerweise</i>(via GadgetClass)</u>: <font face="Monospaced">gtk_css_gadget_real_allocate</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1664467644459" ID="ID_45450826" MODIFIED="1664467662907" TEXT="CSS-Gadgets werden in Zukunft wichtiger">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1664468000858" ID="ID_1650947202" MODIFIED="1664468006117" TEXT="gadget_class->allocate">
|
|
<node CREATED="1664468030167" ID="ID_1269527361" MODIFIED="1664468035642" TEXT="von: gtk_css_custom_gadget_allocate"/>
|
|
<node CREATED="1664468049900" ID="ID_1444284149" MODIFIED="1664468072369" TEXT="von: gtk_css_gadget_allocate">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664468221301" ID="ID_815029757" MODIFIED="1664468225639" TEXT="Beispiel GtkFrame">
|
|
<node CREATED="1664468568742" ID="ID_276645627" MODIFIED="1664468573479" TEXT="Aufruf kommt von gtk_css_custom_gadget_allocate">
|
|
<node CREATED="1664468592906" ID="ID_240073713" MODIFIED="1664468602629" TEXT="effektiv von gadget_class->allocate"/>
|
|
<node CREATED="1664468725965" ID="ID_1819801827" MODIFIED="1664468747176">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und damit wieder von <b><font face="Monospaced">gtk_css_gadget_allocate</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#3865cd" DESTINATION="ID_1819801827" ENDARROW="Default" ENDINCLINATION="99;109;" ID="Arrow_ID_1378453284" SOURCE="ID_588778933" STARTARROW="None" STARTINCLINATION="390;0;"/>
|
|
</node>
|
|
<node CREATED="1664469502600" ID="ID_611893108" MODIFIED="1664469518960">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
allerdings dann vom <u>umschließenden Widget</u>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664469528852" ID="ID_1753828620" MODIFIED="1664469548960">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Implementierung: <b><font face="Monospaced">gtk_frame_allocate</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1664469632391" ID="ID_1730366357" MODIFIED="1664469639668" TEXT="ignoriert die übergebene Allocation"/>
|
|
<node CREATED="1664469640285" ID="ID_1706931088" MODIFIED="1664469888214" TEXT="Ausgabe-Parameter ist: out_clip">
|
|
<linktarget COLOR="#35d4cd" DESTINATION="ID_1706931088" ENDARROW="Default" ENDINCLINATION="-220;-17;" ID="Arrow_ID_1835745476" SOURCE="ID_1957306429" STARTARROW="None" STARTINCLINATION="74;-5;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1664469669402" ID="ID_925561460" MODIFIED="1664469736117" TEXT="berechnet from scratch eine child_allocation">
|
|
<arrowlink COLOR="#4483c1" DESTINATION="ID_24474469" ENDARROW="Default" ENDINCLINATION="75;-66;" ID="Arrow_ID_839164355" STARTARROW="None" STARTINCLINATION="-113;9;"/>
|
|
</node>
|
|
<node CREATED="1664468238896" ID="ID_1603959960" MODIFIED="1664468245349" TEXT="justiert die um die Frame-Dekoration"/>
|
|
<node CREATED="1664469756095" ID="ID_1426249821" MODIFIED="1664469802527" TEXT="und gibt das an das eigene Gadget weiter">
|
|
<arrowlink COLOR="#49a9e2" DESTINATION="ID_588778933" ENDARROW="Default" ENDINCLINATION="17;-13;" ID="Arrow_ID_1888006033" STARTARROW="None" STARTINCLINATION="-114;8;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664468227932" ID="ID_24474469" MODIFIED="1664469730107" TEXT="gtk_frame_compute_child_allocation">
|
|
<linktarget COLOR="#4483c1" DESTINATION="ID_24474469" ENDARROW="Default" ENDINCLINATION="75;-66;" ID="Arrow_ID_839164355" SOURCE="ID_925561460" STARTARROW="None" STARTINCLINATION="-113;9;"/>
|
|
<node CREATED="1664468348482" ID="ID_1161990345" MODIFIED="1664468349364" TEXT="gtk_frame_real_compute_child_allocation"/>
|
|
<node CREATED="1664468414498" ID="ID_1237799901" MODIFIED="1664468418149" TEXT="diese ruft auf: gtk_css_gadget_get_content_allocation">
|
|
<node CREATED="1664470070987" ID="ID_1498695149" MODIFIED="1664470117430">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
dieses baut auf auf: <b><font face="Monospaced">gtk_css_gadget_allocate</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1664471526800" ID="ID_346003014" MODIFIED="1664471579040" TEXT="es verwendet nämlich den vorhandenen priv->allocated_size"/>
|
|
<node CREATED="1664471678866" ID="ID_1301393710" MODIFIED="1664471693326" TEXT="und der wird nur von gtk_css_gadget_allocate gesetzt"/>
|
|
<node CREATED="1664471696617" ID="ID_165291290" MODIFIED="1664474496099" TEXT="Preisfrage: wer ruft letzteres auf?">
|
|
<arrowlink COLOR="#655e7d" DESTINATION="ID_602033868" ENDARROW="Default" ENDINCLINATION="-419;67;" ID="Arrow_ID_1884820801" STARTARROW="None" STARTINCLINATION="-846;67;"/>
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1664472004680" ID="ID_1104307328" MODIFIED="1664473489163">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
(konkret im Beispiel): <b><font face="Monospaced">gtk_frame_size_allocate</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664473514122" ID="ID_1482686732" MODIFIED="1664473548372" TEXT="Fazit: die Basis-Allokation stammt aus der bekannten Berechnungs-Routine">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664470127589" ID="ID_737926476" MODIFIED="1664470137023" TEXT="dekoriert und erweitert gemäß CSS"/>
|
|
<node CREATED="1664470140690" ID="ID_155338555" MODIFIED="1664470151199" TEXT="setzt damit die Werte im Ausgabe-parameter"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664468245849" ID="ID_588778933" MODIFIED="1664469796939">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ruft damit <b><font face="Monospaced">gtk_css_gadget_allocate</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#3865cd" DESTINATION="ID_1819801827" ENDARROW="Default" ENDINCLINATION="99;109;" ID="Arrow_ID_1378453284" STARTARROW="None" STARTINCLINATION="390;0;"/>
|
|
<linktarget COLOR="#49a9e2" DESTINATION="ID_588778933" ENDARROW="Default" ENDINCLINATION="17;-13;" ID="Arrow_ID_1888006033" SOURCE="ID_1426249821" STARTARROW="None" STARTINCLINATION="-114;8;"/>
|
|
</node>
|
|
<node CREATED="1664469820733" ID="ID_1957306429" MODIFIED="1664469888214" TEXT="Resultat: out-clip (incl shaddow)">
|
|
<arrowlink COLOR="#35d4cd" DESTINATION="ID_1706931088" ENDARROW="Default" ENDINCLINATION="-220;-17;" ID="Arrow_ID_1835745476" STARTARROW="None" STARTINCLINATION="74;-5;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663954860585" ID="ID_1293292924" MODIFIED="1663954864003" TEXT="resize_needed">
|
|
<node CREATED="1663954865611" ID="ID_1181046845" MODIFIED="1663954871465" TEXT="interne Flag im widget"/>
|
|
<node CREATED="1663954879636" ID="ID_1910791425" MODIFIED="1663954884163" TEXT="Verwendungen">
|
|
<node CREATED="1663954901013" MODIFIED="1663954901013" TEXT="gtk_widget_needs_allocate"/>
|
|
<node CREATED="1663954909806" ID="ID_1374760334" MODIFIED="1663954909806" TEXT="gtk_widget_ensure_resize">
|
|
<node CREATED="1663954912759" ID="ID_600146300" MODIFIED="1663954920356" TEXT="implementiert durch Löschen eines Cache*"/>
|
|
<node CREATED="1663954925510" ID="ID_1181014721" MODIFIED="1663954926481" TEXT="_gtk_size_request_cache_clear"/>
|
|
<node CREATED="1663954927597" ID="ID_871436829" MODIFIED="1663954950237" TEXT="Vermutung: dort wird gespeichert, was nicht resized werden muß">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663954959625" ID="ID_758176211" MODIFIED="1663954960741" TEXT="gtk_widget_get_resize_needed"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612535679525" HGAP="30" ID="ID_563938836" MODIFIED="1663955495496" VSHIFT="26">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle Fäden laufen zusammen bei....
|
|
</p>
|
|
<p>
|
|
<b>gtk_widget_size_allocate_with_baseline</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_1241133759" STARTARROW="None" STARTINCLINATION="-30;150;"/>
|
|
<linktarget COLOR="#852376" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="18;-93;" ID="Arrow_ID_1194665328" SOURCE="ID_1959081786" STARTARROW="None" STARTINCLINATION="-211;17;"/>
|
|
<linktarget COLOR="#692b5b" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="668;-205;" ID="Arrow_ID_378269338" SOURCE="ID_1435876974" STARTARROW="None" STARTINCLINATION="-279;578;"/>
|
|
<linktarget COLOR="#692b5b" DESTINATION="ID_563938836" ENDARROW="Default" ENDINCLINATION="621;-190;" ID="Arrow_ID_152388281" SOURCE="ID_1917960846" STARTARROW="None" STARTINCLINATION="-357;417;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1663955121019" ID="ID_1249298775" MODIFIED="1663955138898" TEXT="wird direkt anscheinend nur von Init aus aktiviert"/>
|
|
<node CREATED="1663955139409" ID="ID_857432800" MODIFIED="1663955255321" TEXT="aber die Call-Graphen sind schwer durchschaubar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...da Funktionen irgendwo dann an Funktionspointer zugewiesen werden für "virtuelle Funktionen"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1663955335710" ID="ID_1881953589" MODIFIED="1663955347072" TEXT="Einstieg: gtk_widget_ensure_allocate">
|
|
<node CREATED="1663955359715" ID="ID_627182614" MODIFIED="1663955359715" TEXT="gtk_container_real_check_resize"/>
|
|
<node CREATED="1663955369802" ID="ID_929212584" MODIFIED="1663955415140" TEXT="das ist die class->check_resize VFunk">
|
|
<arrowlink COLOR="#627791" DESTINATION="ID_1244279782" ENDARROW="Default" ENDINCLINATION="226;-55;" ID="Arrow_ID_1806488152" STARTARROW="None" STARTINCLINATION="400;28;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612534268245" ID="ID_1296614142" MODIFIED="1663947680137" TEXT="gtk_widget_ensure_allocate">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1612534275444" ID="ID_1132981577" MODIFIED="1663951388124" TEXT="prüft Flag ob Allokation notwendig ist">
|
|
<linktarget COLOR="#b51c69" DESTINATION="ID_1132981577" ENDARROW="Default" ENDINCLINATION="34;-19;" ID="Arrow_ID_684196469" SOURCE="ID_313723300" STARTARROW="None" STARTINCLINATION="-49;6;"/>
|
|
<node CREATED="1612534410570" ID="ID_620587901" MODIFIED="1612534423818" TEXT="Anscheined geht die initiale Allokation über einen anderen Weg">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1612534429503" ID="ID_567668302" MODIFIED="1612534445049" TEXT="hier wird vorausgesezt, daß bereits eine valide Allokation besteht"/>
|
|
</node>
|
|
<node CREATED="1663949865622" ID="ID_758836772" MODIFIED="1663949872083" TEXT="aufgerufen von...">
|
|
<node CREATED="1663949997924" ID="ID_1496580283" MODIFIED="1663950003095" TEXT="nach Container-Init"/>
|
|
<node CREATED="1663950003563" ID="ID_59538652" MODIFIED="1663950006646" TEXT="rekursiv von ">
|
|
<node CREATED="1663950018185" ID="ID_238633492" MODIFIED="1663950018877" TEXT="gtk_widget_size_allocate_with_baseline"/>
|
|
<node CREATED="1663950027784" ID="ID_1937200960" MODIFIED="1663950030291" TEXT="für Kinder"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612534325037" ID="ID_947651551" MODIFIED="1612534327833" TEXT="ruft auf">
|
|
<node CREATED="1612534329157" ID="ID_682604518" MODIFIED="1612534330137" TEXT="gtk_widget_get_allocated_size"/>
|
|
<node CREATED="1612534338443" ID="ID_585162600" MODIFIED="1612534339967" TEXT="gtk_widget_size_allocate_with_baseline"/>
|
|
</node>
|
|
<node CREATED="1612534361857" ID="ID_1011780997" MODIFIED="1612534383361" TEXT="Container: ruft rekursiv auf jedem Kind gtk_widget_ensure_allocate"/>
|
|
<node CREATED="1663953791941" HGAP="65" ID="ID_1244279782" MODIFIED="1663955453989" TEXT="führt weiter zu check_resize" VSHIFT="43">
|
|
<linktarget COLOR="#627791" DESTINATION="ID_1244279782" ENDARROW="Default" ENDINCLINATION="226;-55;" ID="Arrow_ID_1806488152" SOURCE="ID_929212584" STARTARROW="None" STARTINCLINATION="400;28;"/>
|
|
<node CREATED="1663953805363" ID="ID_1587549150" MODIFIED="1663953812528" TEXT="wieder eine virtuelle Funktion"/>
|
|
<node CREATED="1663953813403" ID="ID_656209552" MODIFIED="1663953825583" TEXT="wird offensichtlich von der Initialisierung aus aufgerufen"/>
|
|
<node CREATED="1663953843699" ID="ID_1950479692" MODIFIED="1663953845946" TEXT="gtk_window_check_resize">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1663953826319" ID="ID_1109844083" MODIFIED="1663953841300" TEXT="weitere Aufrufe verlieren sich im Nebel">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663951703391" ID="ID_427278328" MODIFIED="1663951706793" TEXT="widget_class->size_allocate">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1663951707842" ID="ID_315178651" MODIFIED="1663951753639" TEXT="virtuelle Funktion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wird im class-init mit der jeweiligen konkreten Implementierung belegt, z.b. gtk_button_size_allocate
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1663954200285" ID="ID_398055899" MODIFIED="1663954210495" TEXT="außerdem kann ein Handler / Signal angeschlossen sein">
|
|
<node CREATED="1663954234237" ID="ID_1380094030" MODIFIED="1663954234909" TEXT="widget_signals[SIZE_ALLOCATE]"/>
|
|
</node>
|
|
<node CREATED="1663954295573" ID="ID_1498770016" MODIFIED="1663954312087" TEXT="aufgerufen von gtk_widget_size_allocate_with_baseline">
|
|
<arrowlink DESTINATION="ID_1762849787" ENDARROW="Default" ENDINCLINATION="38;-96;" ID="Arrow_ID_1571144985" STARTARROW="None" STARTINCLINATION="476;0;"/>
|
|
<node CREATED="1663954335100" HGAP="39" ID="ID_1824384222" MODIFIED="1663954342338" TEXT="letztlich von init" VSHIFT="18"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612535382254" ID="ID_1555274499" MODIFIED="1612535383977" TEXT="gtk_button_size_allocate">
|
|
<node CREATED="1612535679525" HGAP="30" ID="ID_462243081" MODIFIED="1663948420227" TEXT="ruft für sich selber gtk_widget_size_allocate" VSHIFT="26">
|
|
<arrowlink COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_89255297" STARTARROW="None" STARTINCLINATION="-30;150;"/>
|
|
</node>
|
|
<node CREATED="1612535398051" ID="ID_565262993" MODIFIED="1612535410704" TEXT="dann: gtk_css_gadget_allocate">
|
|
<node CREATED="1612535412121" ID="ID_950467979" MODIFIED="1612535417956" TEXT="für den Inhalt des Buttons"/>
|
|
<node CREATED="1612535418784" ID="ID_1076896202" MODIFIED="1612535429635" TEXT="ensprechend um Margin + Padding reduziert"/>
|
|
<node CREATED="1612535549422" ID="ID_1526326867" MODIFIED="1612535563481" TEXT="gadget->allocate (virtuelle Funktion)">
|
|
<node CREATED="1612535615766" ID="ID_261273731" MODIFIED="1612535656704" TEXT="z.B. gtk_box_gadget_allocate">
|
|
<arrowlink DESTINATION="ID_526990189" ENDARROW="Default" ENDINCLINATION="24;0;" ID="Arrow_ID_1005009779" STARTARROW="None" STARTINCLINATION="24;0;"/>
|
|
</node>
|
|
<node CREATED="1612535648889" ID="ID_526990189" MODIFIED="1612535656704" TEXT="gtk_box_gadget_allocate_child">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_526990189" ENDARROW="Default" ENDINCLINATION="24;0;" ID="Arrow_ID_1005009779" SOURCE="ID_261273731" STARTARROW="None" STARTINCLINATION="24;0;"/>
|
|
<node CREATED="1612535679525" HGAP="30" ID="ID_1762849787" MODIFIED="1663956468314" TEXT="ruft dann gtk_widget_size_allocate_with_baseline" VSHIFT="26">
|
|
<arrowlink COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_1708313707" STARTARROW="None" STARTINCLINATION="-77;137;"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1762849787" ENDARROW="Default" ENDINCLINATION="38;-96;" ID="Arrow_ID_1571144985" SOURCE="ID_1498770016" STARTARROW="None" STARTINCLINATION="476;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612527537150" ID="ID_619170334" MODIFIED="1663967533656" TEXT="gtk_widget_size_allocate">
|
|
<arrowlink COLOR="#5c5a78" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="-618;-30;" ID="Arrow_ID_1785324866" STARTARROW="Default" STARTINCLINATION="-4;247;"/>
|
|
<linktarget COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_1241133759" SOURCE="ID_563938836" STARTARROW="None" STARTINCLINATION="-30;150;"/>
|
|
<linktarget COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_89255297" SOURCE="ID_462243081" STARTARROW="None" STARTINCLINATION="-30;150;"/>
|
|
<linktarget COLOR="#4c96df" DESTINATION="ID_619170334" ENDARROW="Default" ENDINCLINATION="22;-288;" ID="Arrow_ID_1708313707" SOURCE="ID_1762849787" STARTARROW="None" STARTINCLINATION="-77;137;"/>
|
|
<node CREATED="1612528130053" ID="ID_1806340634" MODIFIED="1612528177893" TEXT="macht nur etwas für "toplevel"-Widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ist eine Flag in der privaten Widget-Struktur. Keine Ahnung was das bedeutet.<br />Und übrigens: sichtbar muß das Widget auch noch sein...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1612529820222" HGAP="22" ID="ID_1943944289" MODIFIED="1663956475522" TEXT="unterscheidet dann" VSHIFT="12">
|
|
<node CREATED="1663956186778" HGAP="117" ID="ID_834898748" MODIFIED="1663956450989" TEXT="gtk_widget_get_request_mode()" VSHIFT="37">
|
|
<node CREATED="1663956207368" ID="ID_18553128" MODIFIED="1663956217421" TEXT="gtksizerequest.c 450"/>
|
|
<node CREATED="1663956419563" ID="ID_1026472626" MODIFIED="1663956420751" TEXT="GTK_WIDGET_GET_CLASS (widget)->get_request_mode (widget)"/>
|
|
<node CREATED="1663956425698" ID="ID_225463858" MODIFIED="1663956441088" TEXT="Doku">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
 * Gets whether the widget prefers a height-for-width layout
|
|
</p>
|
|
<p>
|
|
 * or a width-for-height layout.
|
|
</p>
|
|
<p>
|
|
 *
|
|
</p>
|
|
<p>
|
|
 * #GtkBin widgets generally propagate the preference of
|
|
</p>
|
|
<p>
|
|
 * their child, container widgets need to request something either in
|
|
</p>
|
|
<p>
|
|
 * context of their children or in context of their allocation
|
|
</p>
|
|
<p>
|
|
 * capabilities.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612529852915" HGAP="22" ID="ID_1335328932" MODIFIED="1663956457164" TEXT="GTK_SIZE_REQUEST_HEIGHT_FOR_WIDTH" VSHIFT="-25">
|
|
<node CREATED="1612531874357" ID="ID_321040886" MODIFIED="1663955991363" TEXT="gtk_widget_get_preferred_width">
|
|
<linktarget COLOR="#77afb6" DESTINATION="ID_321040886" ENDARROW="Default" ENDINCLINATION="-3752;338;" ID="Arrow_ID_765236235" SOURCE="ID_571017696" STARTARROW="None" STARTINCLINATION="-3454;-1310;"/>
|
|
<node CREATED="1612613898889" ID="ID_1906328896" MODIFIED="1612613898889" TEXT="gtk_widget_real_get_width"/>
|
|
<node CREATED="1612614169294" ID="ID_1044574457" MODIFIED="1612614182044" TEXT="default-Impl (widget) liefert einfach 0"/>
|
|
<node CREATED="1612614424711" ID="ID_876925671" MODIFIED="1612614453769" TEXT="Button: delegiert an gtk_css_gadget_get_preferred_size"/>
|
|
</node>
|
|
<node CREATED="1612531881837" ID="ID_503088638" MODIFIED="1612531883430" TEXT="gtk_widget_get_preferred_height_for_width">
|
|
<node CREATED="1612613911103" ID="ID_1759726068" MODIFIED="1612613912600" TEXT="gtk_widget_real_get_height_for_width"/>
|
|
<node CREATED="1612614183776" ID="ID_1283663519" MODIFIED="1612614233786" TEXT="default-Impl (widget) delegiert an get_preferred_heigt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also stellt eigentlich grade nicht die versprochene Logik bereit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1612614424711" ID="ID_407129358" MODIFIED="1612614528239" TEXT="Button: delegiert an gtk_css_gadget_get_preferred_size (ORIENTATION_VERTICAL und "forSize")"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612529854679" ID="ID_620839789" MODIFIED="1612529865489" TEXT="sonst == default">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612531908423" ID="ID_981765041" MODIFIED="1612531909730" TEXT="gtk_widget_get_preferred_height"/>
|
|
<node CREATED="1612531918893" ID="ID_1720836756" MODIFIED="1612531919753" TEXT="gtk_widget_get_preferred_width_for_height"/>
|
|
</node>
|
|
<node CREATED="1612529867091" ID="ID_1467925874" MODIFIED="1612531897569" TEXT="d.h. es gibt zwei, nicht drei Alternativen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612529887521" ID="ID_761185703" MODIFIED="1612529894551" TEXT="danach liegt vor">
|
|
<node CREATED="1612529924676" ID="ID_677442017" MODIFIED="1612529929887" TEXT="min_width"/>
|
|
<node CREATED="1612529930763" ID="ID_540378683" MODIFIED="1612529935382" TEXT="natural_width"/>
|
|
<node CREATED="1612529935882" ID="ID_574785014" MODIFIED="1612529938438" TEXT="min_height"/>
|
|
<node CREATED="1612529939218" ID="ID_226125510" MODIFIED="1612529942181" TEXT="natural_heigt"/>
|
|
</node>
|
|
<node CREATED="1612529944548" ID="ID_1276575353" MODIFIED="1612529951405" TEXT="nun wird justiert">
|
|
<node CREATED="1612530023488" ID="ID_716347716" MODIFIED="1612530028518" TEXT="(widget)->adjust_size_allocation">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1612530030341" ID="ID_1722501910" MODIFIED="1612530038256" TEXT="stets zweimal aufgerufen">
|
|
<node CREATED="1612529954784" ID="ID_1163322850" MODIFIED="1612529961136" TEXT="zuerst in horizontaler Dimension"/>
|
|
<node CREATED="1612529961751" ID="ID_1659658095" MODIFIED="1612529966442" TEXT="dann in vertikaler Dimension"/>
|
|
</node>
|
|
<node CREATED="1612530387661" ID="ID_1677551972" MODIFIED="1612530414969">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
danach noch die <i>adjust_baseline_allocation</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612530059555" ID="ID_1426144413" MODIFIED="1612534894781" TEXT="Signal: SIZE_ALLOCATE">
|
|
<arrowlink COLOR="#3156c0" DESTINATION="ID_800205161" ENDARROW="Default" ENDINCLINATION="-5;-110;" ID="Arrow_ID_1513246240" STARTARROW="None" STARTINCLINATION="-67;9;"/>
|
|
</node>
|
|
<node CREATED="1612530091126" ID="ID_1651628600" MODIFIED="1612530097016" TEXT="ggfs ein Redraw ausgelöst"/>
|
|
</node>
|
|
<node CREATED="1612534851565" ID="ID_800205161" MODIFIED="1612534894781" TEXT="widget->size_allocate">
|
|
<linktarget COLOR="#3156c0" DESTINATION="ID_800205161" ENDARROW="Default" ENDINCLINATION="-5;-110;" ID="Arrow_ID_1513246240" SOURCE="ID_1426144413" STARTARROW="None" STARTINCLINATION="-67;9;"/>
|
|
<node CREATED="1612534944266" ID="ID_1372642184" MODIFIED="1612534985979" TEXT="gtk_widget_real_size_allocate">
|
|
<arrowlink COLOR="#6f6096" DESTINATION="ID_384051197" ENDARROW="Default" ENDINCLINATION="189;0;" ID="Arrow_ID_31086336" STARTARROW="None" STARTINCLINATION="161;15;"/>
|
|
<node CREATED="1612535006062" ID="ID_1456025781" MODIFIED="1612535014459" TEXT="paßt dann auch noch das GDK-Window an"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612534965805" ID="ID_384051197" MODIFIED="1612534981305" TEXT="gtk_widget_set_allocation">
|
|
<linktarget COLOR="#6f6096" DESTINATION="ID_384051197" ENDARROW="Default" ENDINCLINATION="189;0;" ID="Arrow_ID_31086336" SOURCE="ID_1372642184" STARTARROW="None" STARTINCLINATION="161;15;"/>
|
|
<node CREATED="1612535196135" HGAP="24" ID="ID_293434969" MODIFIED="1612535244957" TEXT="weist einfach die Allokation zu" VSHIFT="12"/>
|
|
<node CREATED="1612535204550" ID="ID_1965689659" MODIFIED="1612535224055" TEXT="setzt außerdem auch noch die ClipArea auf genau diese Allokation"/>
|
|
</node>
|
|
<node CREATED="1612530262998" ID="ID_300054220" MODIFIED="1612530266178" TEXT="Einsichten">
|
|
<node CREATED="1612530267006" ID="ID_1055756887" MODIFIED="1612530295140" TEXT="man hat grundsätzlich nur die Wahl "height for width" oder anders herum?"/>
|
|
<node CREATED="1612530297000" ID="ID_786276329" MODIFIED="1612530314209" TEXT="die minimal_width|heigt wird nur für einen Konsistenzcheck verwendet">
|
|
<node CREATED="1612530584619" ID="ID_51694809" MODIFIED="1612530601140" TEXT="in der weiteren Verarbeitung steht an der Stelle eine Variable "dummy""/>
|
|
</node>
|
|
<node CREATED="1612530343387" ID="ID_750045618" MODIFIED="1612530358270" TEXT="jedoch die natural_width|height wird weiterverarbeitet"/>
|
|
<node CREATED="1612530419105" ID="ID_1290168160" MODIFIED="1612530523191" TEXT="und zwar über die Indirektion">
|
|
<node CREATED="1612530440941" ID="ID_894448937" MODIFIED="1612530446521" TEXT="widget->adjust_size_allocation"/>
|
|
<node CREATED="1612530498191" ID="ID_117553121" MODIFIED="1612530503860" TEXT="gtk_widget_real_adjust_size_allocation()"/>
|
|
<node CREATED="1612530640491" ID="ID_1645471050" MODIFIED="1612530666958" TEXT="ruft auf (entsprechend Orientierung)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also entweder in horizontaler, oder in vertikaler Richtung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1612530653137" ID="ID_1843450417" MODIFIED="1612530654181" TEXT="adjust_for_margin"/>
|
|
<node CREATED="1612530676214" ID="ID_277814433" MODIFIED="1612530677407" TEXT="adjust_for_align"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672842964141" ID="ID_215582571" MODIFIED="1672842976471" TEXT="relevante Größen">
|
|
<node CREATED="1672842978065" ID="ID_1344762228" MODIFIED="1672842981558" TEXT="size-request">
|
|
<node CREATED="1672842982532" ID="ID_1586516076" MODIFIED="1672842995869" TEXT="das ist die natürliche Minimal-Größe des Widget"/>
|
|
<node CREATED="1672842996488" ID="ID_1718515236" MODIFIED="1672843011334" TEXT="sie wird von GTK stets honoriert"/>
|
|
<node CREATED="1672843017362" ID="ID_816898465" MODIFIED="1672843030912" TEXT="es gilt das "natural*"-Setting"/>
|
|
<node CREATED="1672843033169" ID="ID_796485263" MODIFIED="1672843052405" TEXT="die "minimal*"-Werte werden aktuell (3.20) nicht verwendet"/>
|
|
<node CREATED="1672843060904" ID="ID_1337685462" MODIFIED="1672843082281" TEXT="es gibt die zwei Varianten: hight-for-width | width-for-height"/>
|
|
</node>
|
|
<node CREATED="1672843085573" ID="ID_1497640739" MODIFIED="1672843330530" TEXT="size-allocation">
|
|
<linktarget COLOR="#7995ad" DESTINATION="ID_1497640739" ENDARROW="Default" ENDINCLINATION="-562;363;" ID="Arrow_ID_1967894607" SOURCE="ID_1504859134" STARTARROW="None" STARTINCLINATION="346;-29;"/>
|
|
<node CREATED="1672843091588" ID="ID_1908929596" MODIFIED="1672843108318" TEXT="die tatsächlich von GTK zugeteilte Ausdehnung"/>
|
|
<node CREATED="1672843109026" ID="ID_448128589" MODIFIED="1672843117060" TEXT="ist stets größer als der size-request"/>
|
|
<node CREATED="1672843122045" ID="ID_1297618005" MODIFIED="1672843134122" TEXT="wird vom Widget sofort um Dekoration reduziert"/>
|
|
<node CREATED="1672843134710" ID="ID_1879903789" MODIFIED="1672843144008" TEXT="nur der reduzierte Wert wird gespeichert">
|
|
<node CREATED="1672843145045" ID="ID_751859168" MODIFIED="1672843150136" TEXT="in der private-Struktur im Widget"/>
|
|
<node CREATED="1672843167666" ID="ID_551602758" MODIFIED="1672843169069" TEXT="priv->allocation"/>
|
|
<node CREATED="1672843251318" ID="ID_17591220" MODIFIED="1672843254290" TEXT="Getter: gtk_widget_get_allocation"/>
|
|
</node>
|
|
<node CREATED="1672843172626" ID="ID_1142235582" MODIFIED="1672843180449" TEXT="modifizierbar durch Alignment etc.">
|
|
<node CREATED="1672843181936" ID="ID_139335819" MODIFIED="1672843188827" TEXT="ebenfalls in der private-Struktur"/>
|
|
<node CREATED="1672843198774" ID="ID_1645020005" MODIFIED="1672843199936" TEXT="priv->allocated_size"/>
|
|
<node CREATED="1672843208916" ID="ID_43084891" MODIFIED="1672843210008" TEXT="priv->allocated_size_baseline"/>
|
|
<node CREATED="1672843223747" ID="ID_1074349241" MODIFIED="1672843229014" TEXT="Getter: gtk_widget_get_allocated_size"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663975843179" ID="ID_1935747548" MODIFIED="1663976133002" TEXT="was ist ein CSS Gadget?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
/*
|
|
</p>
|
|
<p>
|
|
 * Gadgets are 'next-generation widgets' - they combine a CSS node
|
|
</p>
|
|
<p>
|
|
 * for style matching with geometry management and drawing. Each gadget
|
|
</p>
|
|
<p>
|
|
 * corresponds to 'CSS box'. Compared to traditional widgets, they are more
|
|
</p>
|
|
<p>
|
|
 * like building blocks - a typical GTK+ widget will have multiple gadgets,
|
|
</p>
|
|
<p>
|
|
 * for example a check button has its main gadget, and sub-gadgets for
|
|
</p>
|
|
<p>
|
|
 * the checkmark and the text.
|
|
</p>
|
|
<p>
|
|
 *
|
|
</p>
|
|
<p>
|
|
 * Gadgets are not themselves hierarchically organized, but it is common
|
|
</p>
|
|
<p>
|
|
 * to have a 'main' gadget, which gets used by the widgets size_allocate,
|
|
</p>
|
|
<p>
|
|
 * get_preferred_width, etc. and draw callbacks, and which in turn calls out
|
|
</p>
|
|
<p>
|
|
 * to the sub-gadgets. This call tree might extend further if there are
|
|
</p>
|
|
<p>
|
|
 * sub-sub-gadgets that a allocated relative to sub-gadgets. In typical
|
|
</p>
|
|
<p>
|
|
 * situations, the callback chain will reflect the tree structure of the
|
|
</p>
|
|
<p>
|
|
 * gadgets CSS nodes.
|
|
</p>
|
|
<p>
|
|
 *
|
|
</p>
|
|
<p>
|
|
 * Geometry management - Gadgets implement much of the CSS box model for you:
|
|
</p>
|
|
<p>
|
|
 * margins, border, padding, shadows, min-width/height are all applied automatically.
|
|
</p>
|
|
<p>
|
|
 *
|
|
</p>
|
|
<p>
|
|
 * Drawing - Gadgets implement standardized CSS drawing for you: background,
|
|
</p>
|
|
<p>
|
|
 * shadows and border are drawn before any custom drawing, and the focus outline
|
|
</p>
|
|
<p>
|
|
 * is (optionally) drawn afterwards.
|
|
</p>
|
|
<p>
|
|
 *
|
|
</p>
|
|
<p>
|
|
 * Invalidation - Gadgets sit 'between' widgets and CSS nodes, and connect
|
|
</p>
|
|
<p>
|
|
 * to the nodes ::style-changed signal and trigger appropriate invalidations
|
|
</p>
|
|
<p>
|
|
 * on the widget side.
|
|
</p>
|
|
<p>
|
|
 */
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#56719e" DESTINATION="ID_1935747548" ENDARROW="Default" ENDINCLINATION="-1149;116;" ID="Arrow_ID_875944733" SOURCE="ID_1277756929" STARTARROW="None" STARTINCLINATION="-702;39;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504215708147" FOLDED="true" ID="ID_975007807" MODIFIED="1557498707238" TEXT="Widget">
|
|
<node CREATED="1535630469053" ID="ID_608304313" MODIFIED="1557498707238" TEXT="konkret...">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1535630478836" ID="ID_51688888" MODIFIED="1557498707238" TEXT="Container">
|
|
<node CREATED="1535629240762" FOLDED="true" ID="ID_1889724128" MODIFIED="1561827466221" STYLE="fork">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gtk::<b>Expander</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#b4a9e3" STYLE="bezier" WIDTH="thin"/>
|
|
<linktarget COLOR="#4561ae" DESTINATION="ID_1889724128" ENDARROW="Default" ENDINCLINATION="-1778;-100;" ID="Arrow_ID_219393455" SOURCE="ID_1047933726" STARTARROW="None" STARTINCLINATION="-6486;0;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1535630679569" ID="ID_1488556262" MODIFIED="1535630685068" TEXT="ein Kind-Widget"/>
|
|
<node CREATED="1535630685712" ID="ID_848335172" MODIFIED="1535630699099" TEXT="ein/ausklapp-Handle">
|
|
<node CREATED="1535630699999" ID="ID_895008056" MODIFIED="1535630702610" TEXT="immer sichtbar"/>
|
|
<node CREATED="1535630703150" ID="ID_1252755884" MODIFIED="1535630710185" TEXT="animierter Pfeil-Button"/>
|
|
<node CREATED="1535630710781" ID="ID_194514515" MODIFIED="1535630724687" TEXT="Label-Text als ctor-Param"/>
|
|
</node>
|
|
<node CREATED="1535630745440" ID="ID_1732954181" MODIFIED="1535630748668" TEXT="Verhalten">
|
|
<node CREATED="1535557122205" ID="ID_523553375" MODIFIED="1576282357945" TEXT="resize_toplevel (=true by default)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ob beim Expand/Collapse das umschließende Widget resized werden soll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535631187965" ID="ID_586010488" MODIFIED="1576282357945" TEXT="expanded (=false by default)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ob eingeklappt oder ausgeklappt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1535631368701" ID="ID_1441730618" MODIFIED="1535631388301" TEXT="platziert Kind-Widget as-is">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1535631390194" ID="ID_356344952" MODIFIED="1535631402732" TEXT="in dessen natürlicher Größe"/>
|
|
<node CREATED="1535631403576" ID="ID_518089172" MODIFIED="1576282357944" TEXT="verhält sich anders als Frame">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein Frame setzt beim Kind property_expand() = true,
|
|
</p>
|
|
<p>
|
|
was dazu führt, daß das Kind stets allen verfügbaren Platz nimmt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1541455966429" FOLDED="true" ID="ID_973601831" MODIFIED="1557498707238">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Gtk::<b>Grid</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node COLOR="#435e98" CREATED="1541455995128" ID="ID_275278278" MODIFIED="1557498707238" TEXT="(ersetzt Gtk::Table @deprecated)">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node CREATED="1541456025225" ID="ID_1914314588" MODIFIED="1557498707238" TEXT="expand und Fill wie bei Gtk::Box"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538583396203" FOLDED="true" ID="ID_243616989" MODIFIED="1561827466226" TEXT="TextView">
|
|
<linktarget COLOR="#3251a9" DESTINATION="ID_243616989" ENDARROW="Default" ENDINCLINATION="-2060;-1360;" ID="Arrow_ID_794678010" SOURCE="ID_1836686899" STARTARROW="None" STARTINCLINATION="-3506;-148;"/>
|
|
<node CREATED="1538583408897" ID="ID_1222725022" MODIFIED="1538583418805" TEXT="das Editor-Widget">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1538583420272" ID="ID_438604441" MODIFIED="1538583449944" TEXT="Model == Buffer">
|
|
<node CREATED="1538583478040" ID="ID_511541932" MODIFIED="1538583483915" TEXT="kann getauscht werden"/>
|
|
<node CREATED="1538583484647" ID="ID_457973011" MODIFIED="1538583504768" TEXT="Buffer gemeinsam verwenden"/>
|
|
</node>
|
|
<node CREATED="1538583507988" HGAP="72" ID="ID_1806257929" MODIFIED="1538583518616" TEXT="TextBuffer" VSHIFT="18">
|
|
<node CREATED="1538583533033" ID="ID_964637986" MODIFIED="1538583734951" TEXT="Konzepte">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1538583627852" ID="ID_1431409524" MODIFIED="1538583630676" TEXT="Position">
|
|
<node CREATED="1538583632075" ID="ID_1308223917" MODIFIED="1538583654421">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
stets <i>zwischen </i>den Zeichen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1538583655744" ID="ID_415292974" MODIFIED="1538583682595">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Danke</b>! endlich bekommt das mal jemand korrekt hin
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538583535896" ID="ID_81892828" MODIFIED="1538583539908" TEXT="TextIterator">
|
|
<node CREATED="1538583541231" ID="ID_1777219378" MODIFIED="1538583544571" TEXT="flüchtig"/>
|
|
<node CREATED="1538583546679" ID="ID_1182183621" MODIFIED="1538583555801" TEXT="kann intelligent navigieren">
|
|
<node CREATED="1538583567436" ID="ID_750990432" MODIFIED="1538583573647" TEXT="Zeichen"/>
|
|
<node CREATED="1538583573995" ID="ID_881520087" MODIFIED="1538583579166" TEXT="nächstes Wort"/>
|
|
<node CREATED="1538583579754" ID="ID_198678641" MODIFIED="1538583582742" TEXT="nächste Zeile"/>
|
|
</node>
|
|
<node CREATED="1538583556374" ID="ID_661377638" MODIFIED="1538583562128" TEXT="weiß viel über seine Position"/>
|
|
</node>
|
|
<node CREATED="1538583588689" ID="ID_1850195952" MODIFIED="1538583593741" TEXT="TextMark">
|
|
<node CREATED="1538583596768" ID="ID_281650917" MODIFIED="1538583612602" TEXT="dauerhafte Positionsmarke"/>
|
|
<node CREATED="1538583613326" ID="ID_1642730307" MODIFIED="1538583618193" TEXT="wandert mit"/>
|
|
<node CREATED="1538583618989" ID="ID_870667973" MODIFIED="1538583624848" TEXT="left/right gravity"/>
|
|
</node>
|
|
<node CREATED="1538583722679" ID="ID_80198934" MODIFIED="1538583725898" TEXT="TextTag">
|
|
<node CREATED="1538583726990" ID="ID_679389681" MODIFIED="1538583730874" TEXT="Formatierung / Markup"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540643603185" ID="ID_1214860125" MODIFIED="1557498707238" TEXT="allgemein">
|
|
<node CREATED="1540643609173" ID="ID_1927927594" MODIFIED="1557498707238" TEXT="Lebenszyklus">
|
|
<node CREATED="1540645438704" ID="ID_1754311679" MODIFIED="1557498707238" TEXT="erzeugen"/>
|
|
<node CREATED="1540645441115" ID="ID_1343924195" MODIFIED="1557498707238" TEXT="verdrahten"/>
|
|
<node CREATED="1540645446023" ID="ID_1278449395" MODIFIED="1557498707238" TEXT="map"/>
|
|
<node CREATED="1540645449535" ID="ID_751713031" MODIFIED="1557498707238" TEXT="realize"/>
|
|
<node CREATED="1540645512438" ID="ID_1832277082" MODIFIED="1557498707238" TEXT="draw"/>
|
|
<node CREATED="1540645490897" ID="ID_1262425717" MODIFIED="1557498707238" TEXT="unrealize"/>
|
|
<node CREATED="1540645493913" ID="ID_1545070072" MODIFIED="1557498707238" TEXT="unmap"/>
|
|
<node CREATED="1540645497224" ID="ID_715226869" MODIFIED="1560692445648" TEXT="destroy">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_715226869" ENDARROW="Default" ENDINCLINATION="402;0;" ID="Arrow_ID_183919560" SOURCE="ID_1625378917" STARTARROW="None" STARTINCLINATION="107;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540643613003" ID="ID_404660547" MODIFIED="1557498707239" TEXT="virtuelle Methoden">
|
|
<node CREATED="1540643621458" ID="ID_893370871" MODIFIED="1557498707239" TEXT="Widget hat eine Art VTable"/>
|
|
<node CREATED="1540643627593" ID="ID_1653985182" MODIFIED="1557498707239" TEXT="diese Methoden bilden den Lebenszyklus ab"/>
|
|
<node COLOR="#435e98" CREATED="1540643649134" ID="ID_863932581" LINK="https://developer.gnome.org/gtk3/stable/GtkWidget.html#GtkWidgetClass" MODIFIED="1557498707239" TEXT="Doku">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1540647187314" ID="ID_1715030005" MODIFIED="1557498707239" TEXT="C++">
|
|
<node CREATED="1540647217067" ID="ID_470384964" MODIFIED="1576282357944" TEXT="signal_size_allocate()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
This function is only used by Gtk::Container subclasses, to assign a size, position and (optionally) baseline to their child widgets.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#1d47b3" DESTINATION="ID_1813983433" ENDARROW="Default" ENDINCLINATION="124;0;" ID="Arrow_ID_416269388" STARTARROW="None" STARTINCLINATION="58;0;"/>
|
|
</node>
|
|
<node CREATED="1540647190676" ID="ID_1813983433" MODIFIED="1557498707239" TEXT="on_size_allocate (Allocation&)">
|
|
<linktarget COLOR="#1d47b3" DESTINATION="ID_1813983433" ENDARROW="Default" ENDINCLINATION="124;0;" ID="Arrow_ID_416269388" SOURCE="ID_470384964" STARTARROW="None" STARTINCLINATION="58;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560692406129" FOLDED="true" ID="ID_1572155079" MODIFIED="1560694543203" TEXT="clean-up / destroy">
|
|
<edge COLOR="#cb8ebe"/>
|
|
<node CREATED="1560692872977" ID="ID_1999141976" MODIFIED="1560692879412" TEXT="Gtkmm (C++)">
|
|
<node CREATED="1560692891204" ID="ID_84706816" MODIFIED="1560692891204" TEXT="~Widget()">
|
|
<node CREATED="1560692901242" ID="ID_2893458" MODIFIED="1560692912872">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"Destroys the widget.
|
|
</p>
|
|
<p>
|
|
The widget will be automatically removed from the parent container."
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560693033030" ID="ID_259444052" MODIFIED="1560693033030" TEXT="Object::~Object()">
|
|
<node CREATED="1560693036387" ID="ID_1415907472" MODIFIED="1576282357943" TEXT="interessannter Kommentar...">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
  //This has probably been called already from Gtk::Object::destroy_(), which is called from derived destructors.
|
|
</p>
|
|
<p>
|
|
  _release_c_instance();
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1560693141395" ID="ID_1813407838" MODIFIED="1560693157246" TEXT="z.B. Gtk::Container::~Container()">
|
|
<node CREATED="1560693172456" ID="ID_181470727" MODIFIED="1560693192578" TEXT="ruft Object::destroy_()">
|
|
<arrowlink DESTINATION="ID_168298159" ENDARROW="Default" ENDINCLINATION="144;-4;" ID="Arrow_ID_676938939" STARTARROW="None" STARTINCLINATION="-71;40;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560693179120" ID="ID_168298159" MODIFIED="1560693192578" TEXT="Object::destroy_()">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_168298159" ENDARROW="Default" ENDINCLINATION="144;-4;" ID="Arrow_ID_676938939" SOURCE="ID_181470727" STARTARROW="None" STARTINCLINATION="-71;40;"/>
|
|
<node CREATED="1560693217354" HGAP="21" ID="ID_894873832" MODIFIED="1560693330345" TEXT="ruft _release_c_instance()" VSHIFT="14">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1560693308275" ID="ID_1045837066" MODIFIED="1560693308275" TEXT="g_object_unref(object)"/>
|
|
<node CREATED="1560693317989" ID="ID_1074811808" MODIFIED="1560693317989" TEXT="g_object_run_dispose(object)"/>
|
|
<node CREATED="1560693328241" ID="ID_249714177" MODIFIED="1560693328241" TEXT="disconnect_cpp_wrapper()"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560692856059" ID="ID_917778138" MODIFIED="1560692862956" TEXT="plain-C (GTK+)">
|
|
<node CREATED="1560692413831" ID="ID_1625378917" MODIFIED="1560692445648" TEXT="Aufruf der virtuellen Methode, incl aller geerbten Impls">
|
|
<arrowlink DESTINATION="ID_715226869" ENDARROW="Default" ENDINCLINATION="402;0;" ID="Arrow_ID_183919560" STARTARROW="None" STARTINCLINATION="107;0;"/>
|
|
</node>
|
|
<node CREATED="1560692466024" ID="ID_1630409355" MODIFIED="1560692484413" TEXT="z.B. gtk_container_destroy">
|
|
<node CREATED="1560692486510" ID="ID_725416306" MODIFIED="1560692494744" TEXT="zerstört alle enthaltenen Sub-Widgets"/>
|
|
</node>
|
|
<node CREATED="1560692458990" ID="ID_665923634" MODIFIED="1560692462637" TEXT="gtk_widget_real_destroy()">
|
|
<node CREATED="1560692545083" ID="ID_276770388" MODIFIED="1560692552432" TEXT="deregistriert diverse features"/>
|
|
<node CREATED="1560692552860" ID="ID_214266884" MODIFIED="1560692561767" TEXT="accessability, focus, keybindings"/>
|
|
<node CREATED="1560692594486" ID="ID_1484203193" MODIFIED="1560692609864" TEXT="zerstört und nullifiziert direkte Sub-Objekte"/>
|
|
</node>
|
|
<node CREATED="1560692690489" ID="ID_1769004872" MODIFIED="1560692695621" TEXT="gtk_widget_finalize()">
|
|
<node CREATED="1560692700112" ID="ID_1859728067" MODIFIED="1560692714562" TEXT="zerstört diverse Reg-Nodes, CSS-Paths"/>
|
|
<node CREATED="1560692715134" ID="ID_1366309847" MODIFIED="1560692723711" TEXT="dekrementiert Ref-Counts"/>
|
|
<node CREATED="1560692724197" ID="ID_50899806" MODIFIED="1560692741359" TEXT="GObject verwendet ein Ref-Count-System">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1560694168408" ID="ID_341202851" MODIFIED="1560694177238" TEXT="siehe auch: Gtk::manage">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1560694178543" ID="ID_1257305143" MODIFIED="1576282357943" TEXT="übernimmt Ownership an einem Pointer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. zerstört auch die Heap-Allokation,
|
|
</p>
|
|
<p>
|
|
wenn das managende Widget zerstört wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1560694188637" ID="ID_1570996543" MODIFIED="1560694215336">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ein normaler Widget/Container tut das <b>nicht</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1560694418290" ID="ID_1731595388" MODIFIED="1560694418290" TEXT="gtk_container_add"/>
|
|
<node CREATED="1560694422229" ID="ID_1702995262" MODIFIED="1560694431295" TEXT="setzt den "parent" des Widget"/>
|
|
<node CREATED="1560694472764" ID="ID_700849767" MODIFIED="1560694478618" TEXT="erhöht den Ref-Count"/>
|
|
<node CREATED="1560694439373" ID="ID_831370392" MODIFIED="1560694444751" TEXT="emittiert onAdd-Signal"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540645789033" FOLDED="true" ID="ID_1271246005" MODIFIED="1557498707239" TEXT="Framework-Verbindung">
|
|
<node CREATED="1540645818461" ID="ID_217892151" MODIFIED="1557498707239" TEXT="weitgehend automatisch"/>
|
|
<node CREATED="1540645822628" ID="ID_1316474474" MODIFIED="1576282357942" TEXT="alle Property-Änderungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...führen automatisch dazu, daß das Widget
|
|
</p>
|
|
<p>
|
|
ggfs. neu gemapped und invalidiert wird, woraufhin es neu gezeichnet wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1540645864503" ID="ID_1092751510" MODIFIED="1557498707239" TEXT="Gtk::Widget::queue_draw_region">
|
|
<node CREATED="1540645872375" ID="ID_925460502" MODIFIED="1557498707239" TEXT="hiermit kann man explizit Neuzeichnen anfordern"/>
|
|
<node CREATED="1540645882388" ID="ID_1140702189" MODIFIED="1557498707239" TEXT="nur nötig bei custom-Draw">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540645903497" ID="ID_1615887419" MODIFIED="1557498707239" TEXT="Gtk::Widget::queue_resize">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1615887419" ENDARROW="Default" ENDINCLINATION="401;-36;" ID="Arrow_ID_1278323856" SOURCE="ID_699204853" STARTARROW="None" STARTINCLINATION="1411;0;"/>
|
|
<node CREATED="1540645905746" ID="ID_1768274251" MODIFIED="1557498707239" TEXT="wenn das Widget einen geänderten Size-Request hat"/>
|
|
<node CREATED="1540645971349" ID="ID_1857749199" MODIFIED="1557498707239" TEXT="expliziter Aufruf normalerweise nie notwendig">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540646156591" ID="ID_1103556230" MODIFIED="1560693186079" TEXT="Gtk::Widget::size_allocate(Allocation const&) ">
|
|
<linktarget COLOR="#59699c" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="-876;0;" ID="Arrow_ID_72712594" SOURCE="ID_841316619" STARTARROW="None" STARTINCLINATION="-1659;0;"/>
|
|
<linktarget COLOR="#7573ab" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="763;-59;" ID="Arrow_ID_1309280117" SOURCE="ID_1615499339" STARTARROW="None" STARTINCLINATION="537;121;"/>
|
|
<linktarget COLOR="#5c5a78" DESTINATION="ID_1103556230" ENDARROW="Default" ENDINCLINATION="-618;-30;" ID="Arrow_ID_1785324866" SOURCE="ID_619170334" STARTARROW="Default" STARTINCLINATION="-4;247;"/>
|
|
<node CREATED="1540646197649" ID="ID_1973894224" MODIFIED="1557498707239" TEXT="kann ein Container auf einem Kind-Widget aufrufen"/>
|
|
<node CREATED="1540646207146" ID="ID_781482261" MODIFIED="1557498707239" TEXT="Folge: Framework adjustiert die Allocation (für Margins)"/>
|
|
<node CREATED="1540646220099" ID="ID_219594395" MODIFIED="1557498707239" TEXT="und ruft die virtuelle Funktion adjust_size_allocation"/>
|
|
<node CREATED="1540646275479" ID="ID_1278063707" MODIFIED="1557498707239" TEXT="und invalideiert -> redraw">
|
|
<arrowlink COLOR="#6396d3" DESTINATION="ID_1112354648" ENDARROW="Default" ENDINCLINATION="332;0;" ID="Arrow_ID_322983898" STARTARROW="None" STARTINCLINATION="130;7;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1676044302875" ID="ID_464303848" MODIFIED="1676044946926" TEXT="Bedeutung der Size-Getter">
|
|
<linktarget COLOR="#727fbb" DESTINATION="ID_464303848" ENDARROW="Default" ENDINCLINATION="-1975;186;" ID="Arrow_ID_1946781864" SOURCE="ID_1978068021" STARTARROW="None" STARTINCLINATION="-1869;99;"/>
|
|
<linktarget COLOR="#7584a4" DESTINATION="ID_464303848" ENDARROW="Default" ENDINCLINATION="115;-178;" ID="Arrow_ID_1938018383" SOURCE="ID_1464608958" STARTARROW="None" STARTINCLINATION="328;-32;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1676044329100" ID="ID_1232423582" MODIFIED="1676044983946" TEXT="Widget::get_allocation|width|height (aktuell gültiger Wert incl Alignment/Modifikationen)"/>
|
|
<node CREATED="1672843927836" ID="ID_477932212" MODIFIED="1672844195140" TEXT="Widget::get_allocated_size (was gesetzt wurde, aber bereits ohne Dekoration)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672842863450" FOLDED="true" ID="ID_1781957682" MODIFIED="1672842867742" TEXT="mapping">
|
|
<node CREATED="1672842868697" ID="ID_871975923" MODIFIED="1672842877133" TEXT="Widget wird einem GDK-Window zugeordnet"/>
|
|
<node CREATED="1672842878351" ID="ID_1331083783" MODIFIED="1672842893254" TEXT="Widget wird nach seinem size_request gefragt"/>
|
|
<node CREATED="1672842897112" ID="ID_1504859134" MODIFIED="1672843330529" TEXT="Widget bekommt size-Allocation">
|
|
<arrowlink COLOR="#7995ad" DESTINATION="ID_1497640739" ENDARROW="Default" ENDINCLINATION="-562;363;" ID="Arrow_ID_1967894607" STARTARROW="None" STARTINCLINATION="346;-29;"/>
|
|
<node CREATED="1672842907889" ID="ID_1244611946" MODIFIED="1672842923846" TEXT="diese wird sofort im Widget noch um Margin und Dekorationen reduziert"/>
|
|
<node CREATED="1672842924490" ID="ID_1270863386" MODIFIED="1672842931688" TEXT="nur der effektive Wert wird gespeichert"/>
|
|
</node>
|
|
<node CREATED="1672842936499" ID="ID_493624501" MODIFIED="1672842951923" TEXT="Alignment und Fill-Layout kann das noch modifizieren"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477526858307" ID="ID_676269117" MODIFIED="1557498707239" TEXT="custom widget">
|
|
<node COLOR="#ca1b00" CREATED="1477526864162" ID="ID_1385929770" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-custom-widgets.html.en" MODIFIED="1557498707239" TEXT="Beispiel">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1385929770" ENDARROW="Default" ENDINCLINATION="1055;0;" ID="Arrow_ID_1314305180" SOURCE="ID_426069181" STARTARROW="None" STARTINCLINATION="1055;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1477527104426" ID="ID_334736261" MODIFIED="1576282357942" TEXT="custom style properties">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...können vom CSS-Stylesheet aus gesetzt werden.
|
|
</p>
|
|
<p>
|
|
Siehe Beschreibung im Beispiel/Tutorial
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_334736261" ENDARROW="Default" ENDINCLINATION="228;-492;" ID="Arrow_ID_84377619" SOURCE="ID_111059124" STARTARROW="None" STARTINCLINATION="930;-42;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1540645596907" ID="ID_783586168" MODIFIED="1557498707239" TEXT="virtuelle Funktionen überlagern">
|
|
<node CREATED="1540645608249" ID="ID_1150066023" MODIFIED="1557498707239" TEXT="on_draw">
|
|
<node CREATED="1540645612137" ID="ID_1200550229" MODIFIED="1557498707239" TEXT="für custom drawing"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1540647442009" ID="ID_303011961" MODIFIED="1576282357941" TEXT="oder: an Signale anhängen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist of einfacher und der bevorzugete Weg.
|
|
</p>
|
|
<p>
|
|
Im Besonderen kann man sich an Signale <i>anderer Widgets</i> anhängen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1540647521382" ID="ID_1112354648" LINK="https://developer.gnome.org/gtk3/stable/GtkWidget.html#GtkWidget-draw" MODIFIED="1557498707239" TEXT="signal_draw()">
|
|
<linktarget COLOR="#6396d3" DESTINATION="ID_1112354648" ENDARROW="Default" ENDINCLINATION="332;0;" ID="Arrow_ID_322983898" SOURCE="ID_1278063707" STARTARROW="None" STARTINCLINATION="130;7;"/>
|
|
<node CREATED="1540647528517" ID="ID_1601064030" MODIFIED="1557498707239" TEXT="man kann den gegebenen Cairo-Kontext ändern">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1540647547755" ID="ID_577859258" MODIFIED="1557498707239" TEXT="die Clip-Region ist auf den tatsächlich zu zeichnenden Bereich gesetzt">
|
|
<linktarget COLOR="#5e86ca" DESTINATION="ID_577859258" ENDARROW="Default" ENDINCLINATION="-1494;46;" ID="Arrow_ID_1966515866" SOURCE="ID_1534655843" STARTARROW="None" STARTINCLINATION="-1797;81;"/>
|
|
</node>
|
|
<node CREATED="1554476229422" ID="ID_1814758951" MODIFIED="1557498707239" TEXT="dirty-region des Widget">
|
|
<node CREATED="1554476290649" ID="ID_1743268737" MODIFIED="1557498707239" TEXT="der Bereich welcher tatsächlich neu gezeichnet werden muß">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1554476255621" ID="ID_752995095" LINK="https://developer.gnome.org/gdk3/stable/gdk3-Cairo-Interaction.html#gdk-cairo-get-clip-rectangle" MODIFIED="1557498707239" TEXT="gdk-cairo-get-clip-rectangle()"/>
|
|
<node CREATED="1554476262846" ID="ID_712481438" LINK="https://developer.gnome.org/cairo/stable/cairo-cairo-t.html#cairo-copy-clip-rectangle-list" MODIFIED="1557498707239" TEXT="cairo-copy-clip-rectangle-list()">
|
|
<node CREATED="1554476717302" ID="ID_1025440579" LINK="https://developer.gnome.org/cairo/stable/cairo-cairo-t.html#cairo-clip-extents" MODIFIED="1557498707239" TEXT="Cairo: cairo-clip-extents()"/>
|
|
<node CREATED="1554477039164" ID="ID_1129826506" LINK="https://www.cairographics.org/documentation/cairomm/reference/classCairo_1_1Context.html#a7211a6110201b959ee46c47aa173b12a" MODIFIED="1557498707239" TEXT="CairoContext::get_clip_extents()"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1554476592342" ID="ID_21219709" MODIFIED="1619107416274" TEXT="siehe Zeichnen im Cairo-Context">
|
|
<arrowlink COLOR="#4e97d4" DESTINATION="ID_1236197922" ENDARROW="Default" ENDINCLINATION="-654;81;" ID="Arrow_ID_1110216219" STARTARROW="None" STARTINCLINATION="-308;527;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1612468919379" FOLDED="true" ID="ID_1508852681" MODIFIED="1612471386536" TEXT="Problem: explizite Größe">
|
|
<linktarget COLOR="#a09aae" DESTINATION="ID_1508852681" ENDARROW="Default" ENDINCLINATION="-2048;204;" ID="Arrow_ID_1446927054" SOURCE="ID_544296566" STARTARROW="None" STARTINCLINATION="-3602;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1612468930840" ID="ID_340039660" MODIFIED="1612468940602" TEXT="das ist von GTK nicht vorgesehen"/>
|
|
<node CREATED="1612468941622" ID="ID_1584501445" MODIFIED="1612468951097" TEXT="wegen Layout, Themes, Schriftarten"/>
|
|
<node COLOR="#435e98" CREATED="1612620409921" ID="ID_1143769023" MODIFIED="1663946886390" TEXT="explizite Größe vs automatische Größe">
|
|
<arrowlink COLOR="#4b67b0" DESTINATION="ID_615948747" ENDARROW="Default" ENDINCLINATION="-1100;0;" ID="Arrow_ID_1297405131" STARTARROW="None" STARTINCLINATION="-2000;141;"/>
|
|
<linktarget COLOR="#796ba9" DESTINATION="ID_1143769023" ENDARROW="Default" ENDINCLINATION="-733;-40;" ID="Arrow_ID_1215170372" SOURCE="ID_740164704" STARTARROW="None" STARTINCLINATION="-1892;158;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1663955547906" ID="ID_1016430790" MODIFIED="1663955571483" TEXT="Widget kann nur an zwei Stellen mitbestimmen">
|
|
<node CREATED="1663955572854" ID="ID_1528456404" MODIFIED="1663955585704" TEXT="size_request == Minimalanforderung"/>
|
|
<node CREATED="1663955586196" ID="ID_16918762" MODIFIED="1663955605462" TEXT="get_width_for_height | get_height_for_width"/>
|
|
</node>
|
|
<node CREATED="1663967697587" ID="ID_502729133" MODIFIED="1663967701287" TEXT="Platz-Zuteilung">
|
|
<node CREATED="1663967702275" ID="ID_1441338062" MODIFIED="1663967710309" TEXT="macht normalerweise das Framework(GTK)"/>
|
|
<node CREATED="1663967711002" FOLDED="true" ID="ID_1524127663" MODIFIED="1663967716503" TEXT="Container machen das für ihre Kinder">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1663967756387" ID="ID_1440467863" MODIFIED="1663967792184" TEXT="Einstieg: Gtk::Widget::size_allocate | ggfs. incl »Baseline«">
|
|
<node CREATED="1663967838832" ID="ID_930797784" MODIFIED="1663967902777" TEXT="void gtk_widget_size_allocate (GtkWidget *widget, GtkAllocation *allocation)">
|
|
<font NAME="Monospaced" SIZE="12"/>
|
|
</node>
|
|
<node COLOR="#3f1d5e" CREATED="1663967838832" ID="ID_952771766" MODIFIED="1663968099720" TEXT="void gtk_widget_size_allocate_with_baseline (GtkWidget*, GtkAllocation*, baseline) ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Hier steckt die Implementierung, und zwar die Kernimplementierung der Platzzuteilungs-Logik von GTK
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font BOLD="true" NAME="Monospaced" SIZE="12"/>
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663968217230" ID="ID_189000213" MODIFIED="1663968243111" TEXT="das ermittelt Präferenz und width-for-height | vis versa">
|
|
<node CREATED="1663973733068" ID="ID_419342062" MODIFIED="1663973735583" TEXT="delegiert an">
|
|
<node CREATED="1663973741555" ID="ID_49363701" MODIFIED="1663973742215" TEXT="gtk_widget_compute_size_for_orientation">
|
|
<node CREATED="1663973794195" ID="ID_639016320" MODIFIED="1663973821275" TEXT="for_size : Vorgabe oder -1 (=preferred)"/>
|
|
</node>
|
|
<node CREATED="1663974052296" ID="ID_1989206706" MODIFIED="1663974059035" TEXT="delegiert weiter...">
|
|
<node CREATED="1663974060249" ID="ID_186068184" MODIFIED="1663974060249" TEXT="gtk_widget_query_size_for_orientation"/>
|
|
<node CREATED="1663974135813" ID="ID_1305072943" MODIFIED="1663974144367" TEXT="dies ruft dann je nach orientation..."/>
|
|
<node CREATED="1663974315044" ID="ID_137296585" MODIFIED="1663974409384" TEXT="Warnung: hier wird ein Cache verwendet">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1663974144931" ID="ID_566577800" MODIFIED="1663976168903" TEXT="widget_class->get_preferred_width | height">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_566577800" ENDARROW="Default" ENDINCLINATION="236;14;" ID="Arrow_ID_129364884" SOURCE="ID_1912357851" STARTARROW="None" STARTINCLINATION="224;0;"/>
|
|
<node CREATED="1663975550843" ID="ID_650217219" MODIFIED="1663975618095" TEXT="gtk_widget_real_get_width">
|
|
<node CREATED="1663975562545" ID="ID_1821813272" MODIFIED="1663975567220" TEXT="basis: setzt auf 0"/>
|
|
</node>
|
|
<node CREATED="1663975607443" HGAP="62" ID="ID_1509275843" MODIFIED="1663975616192" TEXT="gtk_button_get_preferred_width" VSHIFT="-18">
|
|
<node CREATED="1663975632692" ID="ID_151194506" MODIFIED="1663975639133" TEXT="delegiert an den Content"/>
|
|
<node CREATED="1663976074208" ID="ID_1192731327" MODIFIED="1663976171045" TEXT="gtk_css_gadget_get_preferred_size">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1192731327" ENDARROW="Default" ENDINCLINATION="-210;-13;" ID="Arrow_ID_1198291141" SOURCE="ID_774587702" STARTARROW="None" STARTINCLINATION="-209;-13;"/>
|
|
</node>
|
|
<node CREATED="1663975629109" ID="ID_1277756929" MODIFIED="1663976133002" TEXT="CSS Gadget als strukturierte Layout-Repräsentation">
|
|
<arrowlink COLOR="#56719e" DESTINATION="ID_1935747548" ENDARROW="Default" ENDINCLINATION="-1149;116;" ID="Arrow_ID_875944733" STARTARROW="None" STARTINCLINATION="-702;39;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1663976709823" ID="ID_1269320643" MODIFIED="1663976752139">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font face="Monospaced" size="2">min_size = get_number (style, GTK_CSS_PROPERTY_MIN_WIDTH); </font>
|
|
</p>
|
|
<p>
|
|
<font face="Monospaced" size="2">min_for_size = get_number (style, GTK_CSS_PROPERTY_MIN_HEIGHT); </font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1663976761113" HGAP="22" ID="ID_1693421261" MODIFIED="1663976876203" TEXT="⟹ hier wird die CSS-Maschinerie verwendet" VSHIFT="-24">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
basierend auf der Widget-Struktur, welche in Widget-Paths übersetzt wurde
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663975664139" HGAP="92" ID="ID_1592877551" MODIFIED="1663976850634" TEXT="gtk_frame_get_preferred_width" VSHIFT="-93">
|
|
<node CREATED="1663975671490" ID="ID_774587702" MODIFIED="1663976171045" TEXT="macht das Gleiche">
|
|
<arrowlink DESTINATION="ID_1192731327" ENDARROW="Default" ENDINCLINATION="-210;-13;" ID="Arrow_ID_1198291141" STARTARROW="None" STARTINCLINATION="-209;-13;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663974411518" ID="ID_174035361" MODIFIED="1663974421271" TEXT="widget_class->get_preferred_width_for_height | vv"/>
|
|
<node CREATED="1663974161185" ID="ID_92203435" MODIFIED="1663974166116" TEXT="C++-Impl">
|
|
<node CREATED="1663974247357" ID="ID_848538209" MODIFIED="1663974553681" TEXT="get_preferred_width_vfunc_callback">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_848538209" ENDARROW="Default" ENDINCLINATION="-494;38;" ID="Arrow_ID_1696341233" SOURCE="ID_802152831" STARTARROW="None" STARTINCLINATION="516;0;"/>
|
|
</node>
|
|
<node CREATED="1663974480522" ID="ID_247416623" MODIFIED="1663974480522" TEXT="get_preferred_height_for_width_vfunc_callback"/>
|
|
<node CREATED="1663974483852" ID="ID_1328435851" MODIFIED="1663974485496" TEXT="..."/>
|
|
<node CREATED="1663975266562" ID="ID_193702026" MODIFIED="1663975273676" TEXT="derzeit nur wenig überschrieben">
|
|
<node CREATED="1663975287575" ID="ID_1399216426" MODIFIED="1663975290066" TEXT="cellarea"/>
|
|
<node CREATED="1663975290518" ID="ID_10312011" MODIFIED="1663975293146" TEXT="cellrenderer"/>
|
|
</node>
|
|
<node CREATED="1663975306932" ID="ID_591034887" MODIFIED="1663975310679" TEXT="default-Impl">
|
|
<node CREATED="1663975347758" ID="ID_1211531094" MODIFIED="1663975348658" TEXT="obj->get_preferred_width_vfunc"/>
|
|
<node CREATED="1663975459159" ID="ID_1719040764" MODIFIED="1663975464370" TEXT="default: forward to C"/>
|
|
<node CREATED="1663975481644" ID="ID_1912357851" MODIFIED="1663976168903" TEXT="class->get_preferred_width()">
|
|
<arrowlink DESTINATION="ID_566577800" ENDARROW="Default" ENDINCLINATION="236;14;" ID="Arrow_ID_129364884" STARTARROW="None" STARTINCLINATION="224;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663968248218" ID="ID_488172276" MODIFIED="1663968271389" TEXT="anschließend: Setzen der definitiven Allokation">
|
|
<node CREATED="1663968280678" ID="ID_1563364759" MODIFIED="1663973460119" TEXT="GTK_WIDGET_GET_CLASS (widget)->adjust_size_allocation (widget, ...">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1563364759" ENDARROW="Default" ENDINCLINATION="-180;327;" ID="Arrow_ID_1165457983" SOURCE="ID_1930369741" STARTARROW="None" STARTINCLINATION="95;0;"/>
|
|
<node CREATED="1663969331505" ID="ID_860014929" MODIFIED="1663969332124" TEXT="GTK_ORIENTATION_HORIZONTAL"/>
|
|
<node CREATED="1663969338016" ID="ID_1868599605" MODIFIED="1663969338876" TEXT="GTK_ORIENTATION_VERTICAL"/>
|
|
</node>
|
|
<node CREATED="1663969724108" ID="ID_67142013" MODIFIED="1663969726858" TEXT="..."/>
|
|
<node CREATED="1663972196609" ID="ID_913451433" MODIFIED="1663972209869" TEXT="konkrete Impl darf Alokation (nur) verkleinern!"/>
|
|
<node CREATED="1663969727523" ID="ID_550077604" MODIFIED="1663971827915" TEXT="danach WidgetClass(widget)->size_allocate (VFunk)">
|
|
<linktarget COLOR="#506199" DESTINATION="ID_550077604" ENDARROW="Default" ENDINCLINATION="-162;174;" ID="Arrow_ID_1680419356" SOURCE="ID_1979640179" STARTARROW="None" STARTINCLINATION="-159;129;"/>
|
|
<node CREATED="1663969785664" ID="ID_1143121525" MODIFIED="1663969791918" TEXT="das ruft die konkrete Impl"/>
|
|
<node CREATED="1663969803900" ID="ID_1949557883" MODIFIED="1663969806396" TEXT="z.B. gtk_button_size_allocate"/>
|
|
<node CREATED="1663969820251" ID="ID_952077630" MODIFIED="1663969826890" TEXT="und das ruft schließlich...">
|
|
<node CREATED="1663969828135" ID="ID_1626874931" MODIFIED="1663969828135" TEXT="gtk_widget_set_allocation"/>
|
|
<node CREATED="1663969842691" ID="ID_919978139" MODIFIED="1663969855134" TEXT="(speichert die konkrete Allokation)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663971550770" ID="ID_1511210757" MODIFIED="1663971557365" TEXT="C++ - Implementierung">
|
|
<node CREATED="1663971558346" ID="ID_637074498" MODIFIED="1663971558346" TEXT="Widget_Class::size_allocate_callback"/>
|
|
<node CREATED="1663971666578" ID="ID_1071539118" MODIFIED="1663971709675" TEXT="forward to derived">
|
|
<node CREATED="1663971689747" ID="ID_499744986" MODIFIED="1663973438074" TEXT="Gtk::Widget::on_size_allocate(Allocation&)">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_499744986" ENDARROW="Default" ENDINCLINATION="-267;18;" ID="Arrow_ID_1734773493" SOURCE="ID_864492298" STARTARROW="None" STARTINCLINATION="419;0;"/>
|
|
</node>
|
|
<node CREATED="1663972038503" ID="ID_1044601758" MODIFIED="1663972051960" TEXT="(anscheinend nirgends überschrieben)">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663971747679" ID="ID_525494669" MODIFIED="1663971763793" TEXT="default-Impl delegiert via C-VFunk">
|
|
<node CREATED="1663971794704" ID="ID_1979640179" MODIFIED="1663971833811" TEXT="base->size_allocate">
|
|
<arrowlink COLOR="#506199" DESTINATION="ID_550077604" ENDARROW="Default" ENDINCLINATION="-162;174;" ID="Arrow_ID_1680419356" STARTARROW="None" STARTINCLINATION="-159;129;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1663973268539" ID="ID_1503005110" MODIFIED="1663977346992" TEXT="mögliche Eingriffspunkte">
|
|
<linktarget COLOR="#6b229a" DESTINATION="ID_1503005110" ENDARROW="Default" ENDINCLINATION="-1806;-166;" ID="Arrow_ID_1347071203" SOURCE="ID_1507590849" STARTARROW="None" STARTINCLINATION="-2004;582;"/>
|
|
<node CREATED="1663973286144" ID="ID_933960506" MODIFIED="1663973296163" TEXT="size_request auf absolutes Minimum"/>
|
|
<node CREATED="1663973298002" ID="ID_802152831" MODIFIED="1663974553681" TEXT="gtk_widget_get_preferred_width">
|
|
<arrowlink DESTINATION="ID_848538209" ENDARROW="Default" ENDINCLINATION="-494;38;" ID="Arrow_ID_1696341233" STARTARROW="None" STARTINCLINATION="516;0;"/>
|
|
</node>
|
|
<node CREATED="1663973353379" ID="ID_309346877" MODIFIED="1663974513324" TEXT="gtk_widget_get_preferred_height_for_width"/>
|
|
<node CREATED="1663973369308" ID="ID_1930369741" MODIFIED="1663974669350" TEXT="man könnte die C-VFunk adjust_size_allocation überlagern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Keine gute Idee: diese Funtktion wird verwendet, um die Dekoration zu entfernen, und Stil-Anpassungen zu machen; sie sollte daher besser als <i>pure function </i>betrachtet werden
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink DESTINATION="ID_1563364759" ENDARROW="Default" ENDINCLINATION="-180;327;" ID="Arrow_ID_1165457983" STARTARROW="None" STARTINCLINATION="95;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1663973396270" ID="ID_864492298" MODIFIED="1663973438074" TEXT="rein informativ: Widget::on_size_allocate()">
|
|
<arrowlink DESTINATION="ID_499744986" ENDARROW="Default" ENDINCLINATION="-267;18;" ID="Arrow_ID_1734773493" STARTARROW="None" STARTINCLINATION="419;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612468955668" ID="ID_719115150" MODIFIED="1612468971046" TEXT="Workaround">
|
|
<node CREATED="1612468972770" ID="ID_54239834" MODIFIED="1612468994420" TEXT="set_size_request">
|
|
<node CREATED="1612468999397" ID="ID_766492418" MODIFIED="1612469008793" TEXT="das legt aber nur die minimal-Ausdehnung fest"/>
|
|
<node CREATED="1612469009709" ID="ID_378480430" MODIFIED="1612469044092" TEXT="Umgebung: Canvas oder Box mit pack_shrink"/>
|
|
<node CREATED="1612469193268" ID="ID_881317091" MODIFIED="1612469202517" TEXT="danach: queue_resize()">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1612469049536" ID="ID_382411942" MODIFIED="1612469057208" TEXT="size_allocate">
|
|
<node CREATED="1612469059390" ID="ID_545938622" MODIFIED="1612469079936" TEXT="man tut so, als wäre man der Container / das Framework"/>
|
|
<node CREATED="1612469081850" ID="ID_138109291" MODIFIED="1612469185623" TEXT="Problem: braucht beide Dimensionen incl Dekoration">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in dem Widget, das diesen Aufruf empfängt, wird der Margin abgezogen, und nur dieser reduzierte Wert wird im Widget selber als Allocation gespeichert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1672764993934" ID="ID_123234016" MODIFIED="1672765455562" TEXT="Erfahrungen: custom Layout-Management">
|
|
<arrowlink COLOR="#6575b0" DESTINATION="ID_327539453" ENDARROW="Default" ENDINCLINATION="-654;33;" ID="Arrow_ID_47233640" STARTARROW="None" STARTINCLINATION="-417;28;"/>
|
|
<node CREATED="1672765077242" ID="ID_925455980" MODIFIED="1672765379771" TEXT="stehen in Konkurrenz zu GTK's eigenen Management-Operationen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...per Design von GTK sind nur wenig Eingriffsmöglichkeiten vorgesehen; stattdessen soll man die Layout-Manager nutzen, die das Layout-reflow automatisch erledigen. Was man definitiv tun kann ist, aus den get_preferred_*()-VFunks dynamisch angepaßte Werte zu liefern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1672765109492" ID="ID_1611765335" MODIFIED="1672765254689">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
man kann sich nur <i>dazwischen schalten</i> und auf Stabilisierung hoffen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn man in der Phase der Layout-Steuerung eingreift, und einzelne Elemente verändert, muß man durch <i>"invalidation" </i>dafür sorgen, daß GTK die Layout-Berechnung später nochmal macht, und dann hoffen, daß sich in diesem zweiten (oder N-ten) Durchgang keine Änderung mehr ergibt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1672765394824" ID="ID_1136392333" MODIFIED="1672765423034">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sofern in dieser Phase ein Widget <i>visible </i>ist, stimmen auch seine Layout-Antworten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1476375676818" FOLDED="true" ID="ID_1029920942" MODIFIED="1557498707239" TEXT="Canvas">
|
|
<node CREATED="1476375696215" ID="ID_1397403295" MODIFIED="1557498707239" TEXT="GtkDrawingArea">
|
|
<node CREATED="1476375709157" ID="ID_981405457" MODIFIED="1557498707239" TEXT="custom drawing"/>
|
|
</node>
|
|
<node CREATED="1476375702166" ID="ID_290806424" MODIFIED="1557498707239" TEXT="GtkLayout">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1476375715644" ID="ID_1233704735" MODIFIED="1557498707239" TEXT="scrollable"/>
|
|
<node CREATED="1476375723915" ID="ID_72518723" MODIFIED="1557498707239" TEXT="can place sub-widgets"/>
|
|
<node CREATED="1476375733298" ID="ID_1024321268" MODIFIED="1557498707239" TEXT="allows custom drawing"/>
|
|
<node CREATED="1476468254712" HGAP="64" ID="ID_1424353399" MODIFIED="1564926360754" TEXT="Eigenschaften" VSHIFT="45">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#338800" CREATED="1476468265399" FOLDED="true" HGAP="2" ID="ID_257790579" MODIFIED="1612018172610" TEXT="Test-Setup schaffen" VSHIFT="-15">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1476468390830" ID="ID_1922633406" MODIFIED="1557498707239" TEXT="soll">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1476468393174" ID="ID_412857359" MODIFIED="1557498707239" TEXT="schnell gehen"/>
|
|
<node CREATED="1476468395941" ID="ID_1419405883" MODIFIED="1557498707239" TEXT="nicht das UI kaputtmachen"/>
|
|
<node CREATED="1476468402085" ID="ID_1171941848" MODIFIED="1557498707239" TEXT="realistisch sein"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1476468272510" FOLDED="true" ID="ID_150722005" MODIFIED="1564926351238" TEXT="Untersuchung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477595404814" HGAP="37" ID="ID_1078486680" MODIFIED="1518487921100" TEXT="Goals" VSHIFT="-12">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1476468292804" ID="ID_283291482" MODIFIED="1518487921100" TEXT="overlapping widgets"/>
|
|
<node CREATED="1476468292805" ID="ID_140846763" MODIFIED="1518487921100" TEXT="resizing of widgets"/>
|
|
<node CREATED="1476468292805" ID="ID_1075320324" MODIFIED="1541088154684" TEXT="partially covered widgets">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....how does the event dispatching deal with partially covered widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1476468292805" ID="ID_1670607748" MODIFIED="1541088154692" TEXT="tabbing / focus order">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...for embedded widgets
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1476468292805" ID="ID_472068538" MODIFIED="1518487921100" TEXT="custom drawing and widget drawing"/>
|
|
</node>
|
|
<node CREATED="1477595408918" ID="ID_387371672" MODIFIED="1518487921100" TEXT="Tasks">
|
|
<node CREATED="1477595418669" ID="ID_1316314985" MODIFIED="1518487921100" TEXT="# place some simple widgets (Buttons)">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477601706168" ID="ID_130395672" MODIFIED="1518487921100" TEXT="Kind-Klasse anlegen"/>
|
|
<node CREATED="1477601712063" ID="ID_1720776876" MODIFIED="1518487921100" TEXT="Kinder managen"/>
|
|
</node>
|
|
<node CREATED="1477595418669" ID="ID_517122292" MODIFIED="1518487921100" TEXT="# learn how to draw">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-2"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477788816168" ID="ID_904860978" MODIFIED="1518487921100" TEXT="documentation">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1477788823751" ID="ID_111966354" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/chapter-drawingarea.html.en" MODIFIED="1614467022336" TEXT="read the custom drawing chapter">
|
|
<arrowlink DESTINATION="ID_1600280983" ENDARROW="Default" ENDINCLINATION="893;0;" ID="Arrow_ID_1707544457" STARTARROW="None" STARTINCLINATION="893;0;"/>
|
|
</node>
|
|
<node CREATED="1477788855234" ID="ID_426069181" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-custom-widgets.html.en" MODIFIED="1518487921100" TEXT="read the example code of a custom widget">
|
|
<arrowlink COLOR="#a9b4c1" DESTINATION="ID_1385929770" ENDARROW="Default" ENDINCLINATION="1055;0;" ID="Arrow_ID_1314305180" STARTARROW="None" STARTINCLINATION="1055;0;"/>
|
|
</node>
|
|
<node CREATED="1477789514451" ID="ID_84890591" LINK="https://www.cairographics.org/documentation/cairomm/reference/" MODIFIED="1518487921100" TEXT="Cairomm API-doc"/>
|
|
</node>
|
|
<node CREATED="1477784938038" ID="ID_93104177" MODIFIED="1518487921100" TEXT="how-to...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477788718965" ID="ID_1354942176" MODIFIED="1518487921100" TEXT="derived class"/>
|
|
<node CREATED="1477788722228" ID="ID_720985572" MODIFIED="1518487921100" TEXT="override on_draw()"/>
|
|
<node CREATED="1477788731163" ID="ID_421749777" MODIFIED="1518487921100" TEXT="invoke inherited on_draw()">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1477788749289" ID="ID_1466181075" MODIFIED="1541088154747" TEXT="returns false">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...meaning, "this event is not yet fully processed",
|
|
</p>
|
|
<p>
|
|
i.e. the enclosing parent widget also gets a chance to redraw itself
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477791881630" HGAP="37" ID="ID_1823256674" MODIFIED="1518487921100" TEXT="coordinates" VSHIFT="11">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477791885614" ID="ID_380369648" MODIFIED="1518487921100">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<font color="#bd0053">Warning</font>: allocation is the <i>visible</i> area
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1477791921953" ID="ID_555455740" MODIFIED="1518487921100" TEXT="...not the extension of the canvas!"/>
|
|
<node CREATED="1477841655353" ID="ID_1533125137" MODIFIED="1518487921100" TEXT="adjust to compensate">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1477841600713" ID="ID_1319450558" LINK="http://stackoverflow.com/questions/40325668/scrollable-drawing-in-gtklayout" MODIFIED="1541088154768" TEXT="Question: can the framework adjust for us">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
asked on stackoverflow...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1477841687997" ID="ID_1267996486" MODIFIED="1533608414144" TEXT="explicitly by code">
|
|
<node CREATED="1477841706107" ID="ID_1685967940" MODIFIED="1518487921100" TEXT="use get_value() from adjustment"/>
|
|
<node CREATED="1477841728496" ID="ID_935017463" MODIFIED="1518487921100" TEXT="because this represents coord. of visible viewport"/>
|
|
<node CREATED="1477841753180" ID="ID_501431504" MODIFIED="1541088154781" TEXT="max(value) + viewport-size == canvas size">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...as can be observed
|
|
</p>
|
|
<p>
|
|
by printing values from the on_draw() callback
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1477841809741" ID="ID_1400891730" MODIFIED="1561827466236" TEXT="context->translate">
|
|
<node CREATED="1477841816516" ID="ID_642580279" MODIFIED="1518487921100" TEXT="by -value"/>
|
|
<node CREATED="1477841842512" ID="ID_1549119493" MODIFIED="1518487921100" TEXT="allows us to use absolute coords."/>
|
|
<node CREATED="1477841854807" ID="ID_1202368941" MODIFIED="1518487921100" TEXT="clipping happens automatically"/>
|
|
<node CREATED="1477841860278" ID="ID_208350074" MODIFIED="1518487921100" TEXT="need to ctx->save() and ctx->restore()">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...otherwise adjustment values will cummulate,
|
|
</p>
|
|
<p>
|
|
causing us to adjust too much
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477843534095" ID="ID_1261380784" MODIFIED="1518487921100" TEXT="Problem: widget extension">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1477843543126" ID="ID_1096450231" MODIFIED="1518487921100" TEXT="seems to be defined only after drawing it"/>
|
|
<node CREATED="1478032584364" ID="ID_1961636905" MODIFIED="1518487921100" TEXT="need to find the right signal">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1478032598165" ID="ID_275509060" MODIFIED="1533608414145" TEXT="need to get foreach working">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1478032633704" ID="ID_1067159761" MODIFIED="1518487921101" TEXT="Hint: show_all_children"/>
|
|
<node CREATED="1478032642310" ID="ID_246127915" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-custom-containers.html.en" MODIFIED="1518487921101" TEXT="Tutorial: custom container"/>
|
|
<node CREATED="1478037794935" HGAP="41" ID="ID_614099643" MODIFIED="1561827466236" TEXT="geht doch" VSHIFT="38">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1478037802776" ID="ID_1706111079" MODIFIED="1518487921101" TEXT="keine Ahnung warums neulich einen SEGFAULT gab"/>
|
|
<node CREATED="1478037818037" ID="ID_1257597772" MODIFIED="1518487921101" TEXT="wichtig: Funktor inline bestehen lassen"/>
|
|
<node CREATED="1478037849449" ID="ID_171841689" MODIFIED="1518487921101" TEXT="habe diesmal sogar ein Lambda verwendet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1478037888539" ID="ID_1261247197" MODIFIED="1533608414146" TEXT="wie">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1478037893658" ID="ID_1711061664" MODIFIED="1518487921101" TEXT="trigger-Variable"/>
|
|
<node CREATED="1478037899458" ID="ID_132096735" MODIFIED="1561827466238" TEXT="im on_draw()-Callback">
|
|
<node CREATED="1478037908465" ID="ID_1414994452" MODIFIED="1518487921101" TEXT="erst hier sind die Allokationen gesetzt"/>
|
|
<node CREATED="1478037916303" ID="ID_1781865207" MODIFIED="1518487921101" TEXT="konnte keine anderen sinnvollen callbacks finden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die anderen, die noch in Frage kommen würden,
|
|
</p>
|
|
<p>
|
|
sind nur für den Fall, daß ein Widget neu instantiiert wird
|
|
</p>
|
|
<p>
|
|
oder neu in das Window-System gemappt wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1478037986046" ID="ID_1293899679" MODIFIED="1518487921101">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
on_check_resize() wird nicht aufgerufen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1478038003892" ID="ID_477362495" MODIFIED="1518487921101" TEXT="rufe foreach mit inline-Lambda auf"/>
|
|
<node CREATED="1478038011427" ID="ID_399044896" MODIFIED="1518487921101" TEXT="melde per max in die lokalen Variablen zurück"/>
|
|
<node CREATED="1478038020338" ID="ID_541293489" MODIFIED="1518487921101" TEXT="Layout->set_size()"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477784943797" ID="ID_298493039" MODIFIED="1518487921101" TEXT="layering">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477791842091" ID="ID_671463871" MODIFIED="1518487921101" TEXT="depends on order of parent call"/>
|
|
<node CREATED="1477791849578" ID="ID_96793101" MODIFIED="1518487921101" TEXT="and on order of cairo draw operations">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477784949533" ID="ID_1496795315" MODIFIED="1518487921101" TEXT="custom styling"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_770195423" MODIFIED="1518487921101" TEXT="# place a huge number of widgets, to scrutinise scrolling and performance">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_423514526" MODIFIED="1518487921101" TEXT="# place widgets overlapping / irregularily">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-4"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477668663507" ID="ID_1576657272" MODIFIED="1518487921101" TEXT="order: later on top">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477668674577" ID="ID_431152757" MODIFIED="1518487921101" TEXT="place widgets out of sight">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477694911349" ID="ID_93004070" MODIFIED="1518487921101" TEXT="widgets beyond the scrollable area">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_1370967982" MODIFIED="1518487921101" TEXT="# bind signals to those widgets, to verify event dispatching">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-5"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_1603374862" MODIFIED="1518487921101" TEXT="# bind some further signal(s) to the GtkLayout container">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-6"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_496085779" MODIFIED="1518487921101" TEXT="# hide and re-show a partially and a totally overlapped widget">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-7"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_1516591439" MODIFIED="1518487921101" TEXT="# move and delete widgets">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-8"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477703725690" ID="ID_554135449" MODIFIED="1518487921101" TEXT="move">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1477703730073" ID="ID_1070867956" MODIFIED="1518487921101" TEXT="foreach doesn't work">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1479424603959" ID="ID_194428894" MODIFIED="1541088154846" TEXT="works on second attempt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...keine Ahnung, was ich beim ersten Mal falsch gemacht habe.
|
|
</p>
|
|
<p>
|
|
jedenfalls hab ich da sofort beim ersten Aufruf der Closure einen SEGFAULT bekommen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Auch im zweiten Anlauf habe ich ein Lambda verwendet.
|
|
</p>
|
|
<p>
|
|
Möglicherweise ist der einzige Unterschied, daß ich es nun aus dem draw-callback
|
|
</p>
|
|
<p>
|
|
aufrufe, und daß demgegenüber bei der ersten Verwendung die Allocation des jeweiligen
|
|
</p>
|
|
<p>
|
|
Kind-Widgets noch gar nicht festgelegt war (denn das passiert erst beim draw).
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
<node CREATED="1477703741232" ID="ID_942790225" MODIFIED="1518487921101" TEXT="get_children returns copy">
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477748350140" ID="ID_1672717051" MODIFIED="1518487921101" TEXT="align all in a row">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477749635577" ID="ID_592134506" MODIFIED="1518487921101" TEXT="delete arbitrary children">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_1275908576" MODIFIED="1518487921101" TEXT="# expand an existing widget (text change)">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-9"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_700977265" MODIFIED="1564926307003" TEXT="# build a custom "''clip''" widget">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="full-0"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1564926319100" ID="ID_1730630443" MODIFIED="1564926336261" TEXT="unnötig! gleich im richtigen UI bauen!">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477595418670" ID="ID_1708640864" MODIFIED="1564926313799" TEXT="# retrofit all preceding tests to use this "''clip''" widget">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1564926367453" ID="ID_943270007" MODIFIED="1564926396554" TEXT="research/gtk-canvas-experiment">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504215729848" ID="ID_518260540" MODIFIED="1557498707239" TEXT="howto">
|
|
<node CREATED="1446515847047" FOLDED="true" ID="ID_290915762" MODIFIED="1557498707239" TEXT="GtkCssProvider">
|
|
<node CREATED="1446515865029" ID="ID_1503616150" MODIFIED="1557498707239" TEXT="parsing errors"/>
|
|
<node CREATED="1477784584821" ID="ID_1810760662" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-custom-widgets.html.en" MODIFIED="1576282357941" TEXT="Beispiel im GTKmm-Guide (custom widget)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in der Implementierung, mywidget.cc
|
|
</p>
|
|
<p>
|
|
ist eine komplette Sequenz, wie man einen CSS-StyleProvider setzt
|
|
</p>
|
|
<p>
|
|
und auch ein Signal für Parse-Fehler anschließt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1810760662" ENDARROW="Default" ENDINCLINATION="1600;-25;" ID="Arrow_ID_1610122569" SOURCE="ID_1164942946" STARTARROW="None" STARTINCLINATION="-840;95;"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504215750653" FOLDED="true" ID="ID_110831069" MODIFIED="1557498707239" TEXT="Textanzeige">
|
|
<node CREATED="1504215755484" ID="ID_1858414199" MODIFIED="1557498707239" TEXT="TextView widget"/>
|
|
<node CREATED="1504215761547" ID="ID_925639969" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-textview-examples.html.en" MODIFIED="1557498707239">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel im <font color="#d4020a">Guide</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504215825762" ID="ID_429138159" MODIFIED="1557498707239" TEXT="zur letzten Zeile scrollen">
|
|
<linktarget COLOR="#9bbabd" DESTINATION="ID_429138159" ENDARROW="Default" ENDINCLINATION="-1413;0;" ID="Arrow_ID_1025095859" SOURCE="ID_653669269" STARTARROW="None" STARTINCLINATION="-1151;202;"/>
|
|
<node CREATED="1504220167228" ID="ID_622474093" MODIFIED="1557498707239" TEXT="scroll_to(iterator) ist ungenau">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1504215849336" ID="ID_832996389" MODIFIED="1557498707239" TEXT="Marker setzen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1504220053691" ID="ID_905781900" MODIFIED="1557498707239" TEXT="benannt oder anonym"/>
|
|
<node CREATED="1504220061178" ID="ID_474843943" MODIFIED="1576282357940" TEXT=""Gravity" beachten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
left gravity: Marker bleibt beim Einfügen an dieser Stelle links von der Einfügung stehen
|
|
</li>
|
|
<li>
|
|
right gravity: Marker wird durch Einfügen an dieser Stelle nach rechts geschoben
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Beachte: der Text-Cursor (Marker "insert") hat right gravity
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1504215832746" ID="ID_751207346" LINK="https://developer.gnome.org/gtkmm-tutorial/stable/sec-multithread-example.html.en" MODIFIED="1557498707239">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Multithreded-Beispiel
|
|
</p>
|
|
<p>
|
|
im Guide demonstriert das
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504219929260" ID="ID_1037649590" MODIFIED="1557498707239" TEXT="Trick: Cursor ist ein Marker namens "insert"">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534511566130" FOLDED="true" HGAP="93" ID="ID_833641481" MODIFIED="1557498707239" TEXT="libGDL" VSHIFT="-58">
|
|
<linktarget COLOR="#39478f" DESTINATION="ID_833641481" ENDARROW="Default" ENDINCLINATION="-1307;0;" ID="Arrow_ID_214595057" SOURCE="ID_358403014" STARTARROW="None" STARTINCLINATION="-2073;0;"/>
|
|
<node CREATED="1534511647623" ID="ID_586745535" MODIFIED="1557498707239" TEXT=""Gnome Docking Library"">
|
|
<node CREATED="1534511675819" ID="ID_458805224" MODIFIED="1557498707239" TEXT="wird auch von Anjuta genutzt"/>
|
|
<node CREATED="1534511663333" ID="ID_1116756676" MODIFIED="1557498707239" TEXT="historisch: Gnome Design Library"/>
|
|
</node>
|
|
<node CREATED="1534511978427" ID="ID_409550752" MODIFIED="1557498707240" TEXT="Dokumentation">
|
|
<node CREATED="1534511984706" ID="ID_463901760" MODIFIED="1557498707240" TEXT="kaum online zu fnden">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1534511992737" ID="ID_555023917" LINK="file:///Werk/devel/a/gdlmm3-3.7.3/doc/reference/html/inherits.html" MODIFIED="1557498707240" TEXT="GDLmm Doxygen im Quellbaum">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1534512202029" ID="ID_1785775758" LINK="file:///Werk/devel/a/gdl-3.28.0/docs/reference/html/index.html" MODIFIED="1557498707240" TEXT="die GDL-Doxygen ist etwas ergiebiger">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534511695553" ID="ID_1631118283" MODIFIED="1557498707240" TEXT="Begriffe">
|
|
<node CREATED="1534512435774" HGAP="58" ID="ID_560032324" MODIFIED="1557498707240" TEXT="Widgets...." VSHIFT="-12">
|
|
<node CREATED="1534512446077" ID="ID_1284930136" MODIFIED="1557498707240" TEXT="gdl::Dock">
|
|
<arrowlink DESTINATION="ID_657079851" ENDARROW="Default" ENDINCLINATION="118;-10;" ID="Arrow_ID_1904059368" STARTARROW="None" STARTINCLINATION="118;-10;"/>
|
|
</node>
|
|
<node CREATED="1534512456307" ID="ID_1461586214" MODIFIED="1557498707240" TEXT="gdl::DockNotebook">
|
|
<node COLOR="#84292b" CREATED="1534512627860" ID="ID_1972742181" MODIFIED="1557498707240" TEXT=" nicht GDLmm">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534512470265" ID="ID_1122516503" MODIFIED="1557498707240" TEXT="gdl::DockPaned">
|
|
<node COLOR="#84292b" CREATED="1534512627860" ID="ID_570071709" MODIFIED="1557498707240" TEXT=" nicht GDLmm">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534512476873" ID="ID_405367338" MODIFIED="1557498707240" TEXT="gdl::DockItem">
|
|
<arrowlink DESTINATION="ID_1059219569" ENDARROW="Default" ENDINCLINATION="125;-6;" ID="Arrow_ID_315465766" STARTARROW="None" STARTINCLINATION="107;-19;"/>
|
|
</node>
|
|
<node CREATED="1534512482992" ID="ID_615241196" MODIFIED="1557498707240" TEXT="gdl::DockBar"/>
|
|
</node>
|
|
<node CREATED="1534511737131" ID="ID_1114860371" MODIFIED="1557498707240" TEXT="DockObject">
|
|
<node CREATED="1534512301864" ID="ID_949111740" MODIFIED="1557498707240" TEXT="abstrakte Basisklasse">
|
|
<node CREATED="1534512313238" ID="ID_614492337" MODIFIED="1557498707240" TEXT=""for all docking widgets""/>
|
|
<node CREATED="1534512329540" ID="ID_661309088" MODIFIED="1557498707240" TEXT="implementiert GtkBuildable"/>
|
|
</node>
|
|
<node CREATED="1534512053505" ID="ID_1534912911" MODIFIED="1557498707240" TEXT="Subklassen">
|
|
<node CREATED="1534512059048" ID="ID_657079851" MODIFIED="1557498707240" TEXT="gdl::Dock">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_657079851" ENDARROW="Default" ENDINCLINATION="118;-10;" ID="Arrow_ID_1904059368" SOURCE="ID_1284930136" STARTARROW="None" STARTINCLINATION="118;-10;"/>
|
|
<node CREATED="1534512361544" ID="ID_172039334" MODIFIED="1557498707240" TEXT="docking area"/>
|
|
</node>
|
|
<node CREATED="1534512065896" ID="ID_1059219569" MODIFIED="1557498707240" TEXT="gdl::DockItem">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1059219569" ENDARROW="Default" ENDINCLINATION="125;-6;" ID="Arrow_ID_315465766" SOURCE="ID_405367338" STARTARROW="None" STARTINCLINATION="107;-19;"/>
|
|
<node CREATED="1534512387109" ID="ID_173562614" MODIFIED="1576282357940" TEXT="Adds docking capability to its child widget">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
A dock item is a container widget that can be docked at different place.
|
|
</p>
|
|
<p>
|
|
It accepts a single child and adds a grip allowing the user to click on it
|
|
</p>
|
|
<p>
|
|
to drag and drop the widget.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
The grip is implemented as a GdlDockItemGrip
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534512072391" ID="ID_1008938926" MODIFIED="1557498707240" TEXT="gdl::DockPlaceholder">
|
|
<node CREATED="1534512416601" ID="ID_1452643437" MODIFIED="1557498707240" TEXT="A widget marking a docking place"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534511742274" ID="ID_11568474" MODIFIED="1557498707240" TEXT="DockMaster"/>
|
|
<node CREATED="1534512085021" ID="ID_269318967" MODIFIED="1557498707240" TEXT="DockLayout"/>
|
|
<node CREATED="1534512093148" ID="ID_767756183" MODIFIED="1557498707240" TEXT="DockBar">
|
|
<node CREATED="1534512097459" ID="ID_1126576292" MODIFIED="1557498707240" TEXT="hält minimierte Docks als Icons">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1534511699368" ID="ID_243375657" MODIFIED="1557498707240" TEXT="C++ Bindings"/>
|
|
</node>
|
|
<node CREATED="1619107069744" FOLDED="true" HGAP="69" ID="ID_132670678" MODIFIED="1619107100691" TEXT="Cairo (Vektorgraphik-Lib)" VSHIFT="13">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1619107266947" ID="ID_1506011612" MODIFIED="1619107277974" TEXT="Doku und Konzepte">
|
|
<node CREATED="1554476592342" ID="ID_1236197922" LINK="https://developer.gnome.org/cairo/stable/cairo-cairo-t.html" MODIFIED="1619107409051" TEXT="Zeichnen: Cairo-Context">
|
|
<linktarget COLOR="#4e97d4" DESTINATION="ID_1236197922" ENDARROW="Default" ENDINCLINATION="-654;81;" ID="Arrow_ID_1110216219" SOURCE="ID_21219709" STARTARROW="None" STARTINCLINATION="-308;527;"/>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1554476799366" ID="ID_977796922" LINK="https://www.cairographics.org/documentation/cairomm/reference/" MODIFIED="1557498707239" TEXT="Cairomm"/>
|
|
<node CREATED="1554476906923" ID="ID_437420072" MODIFIED="1557498707239" TEXT="Cairo-Doku(allgemein)"/>
|
|
<node CREATED="1554476956084" ID="ID_541824716" LINK="https://www.cairographics.org/documentation/cairomm/reference/classCairo_1_1Context.html" MODIFIED="1557498707239" TEXT="CairoContext(C++)"/>
|
|
</node>
|
|
<node CREATED="1561412911257" ID="ID_1173541827" LINK="https://www.cairographics.org/tutorial/" MODIFIED="1677771875029" TEXT="Zusammenfassung: Cairo-Konzepte">
|
|
<linktarget COLOR="#6460c9" DESTINATION="ID_1173541827" ENDARROW="Default" ENDINCLINATION="-1791;132;" ID="Arrow_ID_1651743539" SOURCE="ID_711895669" STARTARROW="None" STARTINCLINATION="-2602;211;"/>
|
|
<linktarget COLOR="#5579dd" DESTINATION="ID_1173541827" ENDARROW="Default" ENDINCLINATION="-2465;188;" ID="Arrow_ID_1216025940" SOURCE="ID_1322665426" STARTARROW="None" STARTINCLINATION="-2437;323;"/>
|
|
<node CREATED="1561412945044" FOLDED="true" ID="ID_1336013492" MODIFIED="1677772243199" TEXT="»Source«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
der Druck-Metapher gemäß ist das die „Farbwalze“ oder das „Stempelkissen“
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1561412970112" ID="ID_358371042" MODIFIED="1561412984826" TEXT="Colour"/>
|
|
<node CREATED="1561412985423" ID="ID_761624981" MODIFIED="1561412991540" TEXT="Gradient"/>
|
|
<node CREATED="1561412992114" ID="ID_457063785" MODIFIED="1561412994561" TEXT="Image"/>
|
|
<node CREATED="1677770744973" ID="ID_987770773" MODIFIED="1677770772509" TEXT="andere Cairo-Surface mit bereits bestehender Zeichnung"/>
|
|
</node>
|
|
<node CREATED="1677418174529" FOLDED="true" ID="ID_546569349" MODIFIED="1677772244319" TEXT="»Path« ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wird mit jeder stroke() oder fill()-Operation geleert. Ist Teil des Context, und weitere Zeichen-Operationen fügen zu dem Pfad hinzu
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677771112172" ID="ID_1976690582" MODIFIED="1677771113744" TEXT="die aktive Kontur, welche die Maske definiert"/>
|
|
<node CREATED="1677771139011" ID="ID_1072620989" MODIFIED="1677771161856" TEXT="wird durch die Zeichen-Operationen sukzessive aufgebaut"/>
|
|
<node CREATED="1677771165277" ID="ID_166622924" MODIFIED="1677771182455" TEXT="kann aus offenen, geschlossenen und mehreren Pfaden bestehen, auch überlappend"/>
|
|
<node CREATED="1677771190338" ID="ID_1049161431" MODIFIED="1677771299425" TEXT="Beim Füllen bestimmt die Fill-Rule, wie mit Verschachtelung umgegangen wird">
|
|
<arrowlink DESTINATION="ID_1306302451" ENDARROW="Default" ENDINCLINATION="218;-202;" ID="Arrow_ID_128834298" STARTARROW="None" STARTINCLINATION="216;8;"/>
|
|
</node>
|
|
<node CREATED="1677419117535" ID="ID_1895718071" MODIFIED="1677419158897" TEXT="close_path() : schließt den Pfad durch eine Linie zum Startpunkt zurück"/>
|
|
</node>
|
|
<node CREATED="1561412948428" FOLDED="true" ID="ID_66649578" MODIFIED="1677772245551" TEXT="»Mask«">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Source wird durch die Mask hindurch „gestempelt“
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1561412996428" ID="ID_621110720" MODIFIED="1561413006567" TEXT="stroke, fill, text, set_mask()"/>
|
|
<node CREATED="1561413034863" ID="ID_1207183549" MODIFIED="1677770935312" TEXT="je nach Druck-Operation wird die Maske genutzt als Kontur oder Inhaltsfläche"/>
|
|
</node>
|
|
<node CREATED="1561412961226" FOLDED="true" ID="ID_670962008" MODIFIED="1677772246591" TEXT="»Surface« ">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
Kann angezeigt werden
|
|
</li>
|
|
<li>
|
|
Kann in ein Bitmap gerendered werden
|
|
</li>
|
|
<li>
|
|
Kann als »source« für weitere Zeichenvorgänge dienen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1561413010338" ID="ID_773980893" MODIFIED="1677770961844" TEXT="Ausgabeformat / Destination"/>
|
|
<node CREATED="1677771008070" ID="ID_538046316" MODIFIED="1677771016717" TEXT="die Zeichenfläche, auf der Cairo arbeitet."/>
|
|
<node CREATED="1561413017945" ID="ID_362589945" MODIFIED="1677771022698" TEXT="...auf diese wird "gestempelt""/>
|
|
</node>
|
|
<node CREATED="1677417850939" FOLDED="true" ID="ID_1653836867" MODIFIED="1677772254958" TEXT="Druck-Operationen">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1677417629676" ID="ID_1746207798" MODIFIED="1677417638096" TEXT="stroke() : Kontur zeichnen"/>
|
|
<node CREATED="1677417639087" ID="ID_1449245923" MODIFIED="1677417654897" TEXT="fill() : Masken-Inneres füllen">
|
|
<node CREATED="1677419615244" ID="ID_1306302451" MODIFIED="1677771301129" TEXT="Fill-Rule">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1306302451" ENDARROW="Default" ENDINCLINATION="218;-202;" ID="Arrow_ID_128834298" SOURCE="ID_1049161431" STARTARROW="None" STARTINCLINATION="216;8;"/>
|
|
<node CREATED="1677420366268" ID="ID_1749745867" LINK="https://www.cairographics.org/manual/cairo-cairo-t.html#cairo-set-fill-rule" MODIFIED="1677420398715" TEXT="cairo_set_fill_rule"/>
|
|
<node CREATED="1677420412998" ID="ID_1655853556" LINK="https://www.cairographics.org/manual/cairo-cairo-t.html#cairo-fill-rule-t" MODIFIED="1677420423252" TEXT="cairo_fill_rule_t">
|
|
<node CREATED="1677420567785" ID="ID_1786405165" MODIFIED="1677420597785" TEXT="WINDING : Drehsinn der Begrenzung zählt"/>
|
|
<node CREATED="1677420598805" ID="ID_709687384" MODIFIED="1677420627615" TEXT="EVENODD: Begrenzungen nach Außen werden gezählt"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677417818031" ID="ID_469249374" MODIFIED="1677417837746" TEXT="paint() : überträgt Quelle ohne Maske auf die Zeichenfläche"/>
|
|
<node CREATED="1677772081020" ID="ID_866086233" MODIFIED="1677772135873" TEXT="siehe auch save() / restore()">
|
|
<arrowlink DESTINATION="ID_242254806" ENDARROW="Default" ENDINCLINATION="-114;-3;" ID="Arrow_ID_184125692" STARTARROW="None" STARTINCLINATION="-159;16;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677419358419" FOLDED="true" ID="ID_414920706" LINK="https://www.cairographics.org/manual/cairo-Transformations.html#cairo-translate" MODIFIED="1677772258018" TEXT="Koordinaten-Transformation">
|
|
<node CREATED="1677419162869" ID="ID_305831750" MODIFIED="1677419232544" TEXT="translate(dx,dy)) : verschiebt den Ursprung der »user space coordinates« um (dx,dy)"/>
|
|
<node CREATED="1677419197776" ID="ID_1423561245" MODIFIED="1677419226680" TEXT="scale(sx,xy) : skaliert die aktuellen Achen der »user space coordinates«"/>
|
|
<node CREATED="1677419275529" ID="ID_572343688" MODIFIED="1677419324939" TEXT="rotate(rad) : dreht die Achsen der »user space coordinates« um rad Radians"/>
|
|
<node CREATED="1677771358116" HGAP="10" ID="ID_1729875163" MODIFIED="1677772189246" TEXT="Hinweise" VSHIFT="14">
|
|
<edge COLOR="#4f4d8b" STYLE="linear"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677771402302" ID="ID_1290869611" MODIFIED="1677771639221">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>current transformation matrix</b> (CTM) : User-Space ⟼ Device-Space
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677419509304" ID="ID_1727557351" MODIFIED="1677419543819" TEXT="Transformationen können jederzeit gesetzt werden; auch zwischen Zeichnen und stroke()">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1677771427923" ID="ID_1957253312" MODIFIED="1677771629176">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Transformations-Definition wird <i>eingangsseitig vor</i> die aktuelle CTM <b>vorgeschaltet</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1677771499633" ID="ID_1610038161" MODIFIED="1677771625408" TEXT="⟹ Transformations-Definitionen muß man rückwärts lesen">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677771522070" ID="ID_420870935" MODIFIED="1677771622365">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiel:
|
|
</p>
|
|
<p>
|
|
<code http-equiv="content-type" content="text/html; charset=utf-8"><font color="#4c3acb">   cairo_scale (cr, 100, 100); </font></code>
|
|
</p>
|
|
<p>
|
|
<code http-equiv="content-type" content="text/html; charset=utf-8"><font color="#4c3acb">   cairo_translate (cr, 0.1, 0.1);</font></code>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1677771582158" ID="ID_1556298030" MODIFIED="1677771598223" TEXT="zuerst den Origin verschieben nach (0.1, 0.1)"/>
|
|
<node CREATED="1677771599488" ID="ID_678482027" MODIFIED="1677771618101" TEXT="dann um diesen Origin homogen skalieren mit Faktor 100"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677771926848" HGAP="-16" ID="ID_242254806" MODIFIED="1677772189251" TEXT="save() / restore() : ein Stack für aktuelle Zeichen/Druckeinstellungen" VSHIFT="4">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...die aktuellen Transformations-Einstellungen (current transformation matrix CTM)
|
|
</p>
|
|
<p>
|
|
...und nicht nur das, auch die Source-Einstellungen wie Linienstärke und Zeichenfarben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<edge COLOR="#4f4d8b" STYLE="linear"/>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_242254806" ENDARROW="Default" ENDINCLINATION="-114;-3;" ID="Arrow_ID_184125692" SOURCE="ID_866086233" STARTARROW="None" STARTINCLINATION="-159;16;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1624113528316" ID="ID_727104900" MODIFIED="1624113773596" TEXT="Zeichnen in Cairo">
|
|
<linktarget COLOR="#6980d1" DESTINATION="ID_727104900" ENDARROW="Default" ENDINCLINATION="-1870;290;" ID="Arrow_ID_1515795020" SOURCE="ID_705175220" STARTARROW="None" STARTINCLINATION="-2646;354;"/>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1624113640224" ID="ID_1539514230" MODIFIED="1624113662485" TEXT="»turtle graphic«">
|
|
<node CREATED="1624113669428" ID="ID_18866635" MODIFIED="1624113679143" TEXT="man zeichnet eine Linien/Bogen-Folge"/>
|
|
<node CREATED="1624113680636" ID="ID_453379928" MODIFIED="1624113690528" TEXT="stets implizit von der aktuellen Position weg"/>
|
|
<node CREATED="1624113691812" ID="ID_1163351000" MODIFIED="1624113728401" TEXT="für eine abgetrennte Form muß man den Startpunkt explizit per move_to(x,y) setzen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677191161908" HGAP="69" ID="ID_1598706179" MODIFIED="1677191736708" TEXT="Umgang mit SVG" VSHIFT="29">
|
|
<linktarget COLOR="#4660c4" DESTINATION="ID_1598706179" ENDARROW="Default" ENDINCLINATION="-1583;-200;" ID="Arrow_ID_1296361422" SOURCE="ID_1618186555" STARTARROW="Default" STARTINCLINATION="-2177;271;"/>
|
|
<node CREATED="1677191174685" ID="ID_1839405957" MODIFIED="1677191200069" TEXT="Basiswissen">
|
|
<node CREATED="1677191211677" ID="ID_897956475" MODIFIED="1677191216323" TEXT="es ist ein XML-Standard"/>
|
|
</node>
|
|
<node CREATED="1677191231654" FOLDED="true" ID="ID_1597077699" MODIFIED="1677191933161" TEXT="Koordinaten und Transformationen">
|
|
<linktarget COLOR="#6f90b6" DESTINATION="ID_1597077699" ENDARROW="Default" ENDINCLINATION="-895;71;" ID="Arrow_ID_1698154465" SOURCE="ID_1613786140" STARTARROW="None" STARTINCLINATION="-1020;86;"/>
|
|
<node CREATED="1677191243092" ID="ID_1422042718" MODIFIED="1677191246287" TEXT="Bezugssystem">
|
|
<node CREATED="1677191248717" ID="ID_1388848012" MODIFIED="1677198334322" TEXT="Ursprung: obere linke Ecke des Dokuments"/>
|
|
<node CREATED="1677191272112" ID="ID_1654409714" MODIFIED="1677198338441" TEXT="positive Werte nach rechts und unten"/>
|
|
<node CREATED="1677198686263" ID="ID_1665325090" MODIFIED="1677198773687" TEXT="UI-Anzeige: Lineal und Transformationen von unten nach oben">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
anscheinend gibt es eine Konvention, welche die im UI sichtbaren Koordinaten in vertikaler Richtung spiegelt; auch ist der auf dem Lineal angezeigte Ursprung unten links
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677191323713" ID="ID_1754370087" MODIFIED="1677191337403" TEXT="Gruppen werden gemeinsam transformiert">
|
|
<node CREATED="1677191339255" ID="ID_836434984" MODIFIED="1677191361440" TEXT="alle Gruppen auflösen ⟹ Transformationen im Element angewendet"/>
|
|
<node CREATED="1677191395503" ID="ID_890070784" MODIFIED="1677191443488">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Koordinaten<i> »versäubern«</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1677191449424" ID="ID_732340507" MODIFIED="1677191541569" TEXT="Objekte in einer (flachen) Gruppe">
|
|
<icon BUILTIN="full-1"/>
|
|
</node>
|
|
<node CREATED="1677191477803" ID="ID_731083583" MODIFIED="1677191544059" TEXT="logischer Bezugspunkt ⟼ Dokument-Ursprung">
|
|
<icon BUILTIN="full-2"/>
|
|
</node>
|
|
<node CREATED="1677191507606" ID="ID_509272377" MODIFIED="1677191546655" TEXT="Gruppierung auflösen (⟹ anwenden)">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1677191525514" ID="ID_1625442685" MODIFIED="1677191549352" TEXT="erneut gruppieren und beliebig transformieren">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677373645637" FOLDED="true" ID="ID_484697692" MODIFIED="1677373653724" TEXT="Element-Specs">
|
|
<node CREATED="1677373442909" ID="ID_1744669640" MODIFIED="1677373454279" TEXT="Format für Bogensegment">
|
|
<node CREATED="1677373673789" ID="ID_1603437139" MODIFIED="1677373683997" TEXT="Kenndaten des Bogens als Attribute">
|
|
<node CREATED="1677373686724" ID="ID_410559852" MODIFIED="1677373711793" TEXT="cx,cy : Centre"/>
|
|
<node CREATED="1677373699871" ID="ID_231844287" MODIFIED="1677373709661" TEXT="rx,ry : Radien"/>
|
|
<node CREATED="1677373723327" ID="ID_776243075" MODIFIED="1677373772988" TEXT="start : Startwinkel in Radians"/>
|
|
<node CREATED="1677373777535" ID="ID_1410316571" MODIFIED="1677373784603" TEXT="end : Endwinkel in Radians"/>
|
|
<node CREATED="1677373774108" ID="ID_1395506738" MODIFIED="1677373775422" TEXT="(↻ Uhrzeigersinn, Start 3 Uhr)"/>
|
|
</node>
|
|
<node CREATED="1677373491955" ID="ID_1533321869" MODIFIED="1677373499451" TEXT=""M" : move to"/>
|
|
<node CREATED="1677373500462" ID="ID_170499055" MODIFIED="1677373508487" TEXT="Koordinaten des Startpunktes"/>
|
|
<node CREATED="1677373509715" ID="ID_1696160837" MODIFIED="1677373513727" TEXT=""A" : arc"/>
|
|
<node CREATED="1677373537578" ID="ID_1997577833" MODIFIED="1677373557177" TEXT="Radius-x , Radius-y"/>
|
|
<node CREATED="1677373558173" ID="ID_1990371384" MODIFIED="1677373562240" TEXT="einige Flags"/>
|
|
<node CREATED="1677373564420" ID="ID_1371186362" MODIFIED="1677373572211" TEXT=""L" "/>
|
|
<node CREATED="1677373597315" ID="ID_935281905" MODIFIED="1677373603048" TEXT="Koordinaten des Endpunktes"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677193200445" FOLDED="true" ID="ID_992404239" MODIFIED="1677193225288" TEXT="Konventionen: sauber für Git">
|
|
<node CREATED="1665801312049" ID="ID_987434179" MODIFIED="1677193745466" TEXT="Tip: Styles vereinfachen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und Inkscape wird das erhalten, solange man die betr. Features nicht wieder aktiviert. Im Besonderen kann man
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
alle "Stroke"-Features entfernen, wenn der Stroke deaktiviert ist
|
|
</li>
|
|
<li>
|
|
opacity:1 weglassen
|
|
</li>
|
|
<li>
|
|
die Defaults "color:#000000;display:inline;overflow:visible;visibility:visible;"  kann man meist weglassen
|
|
</li>
|
|
<li>
|
|
diverse Vector-Filter und display-styles weglassen (wenn sie auf dem default-Wert stehen)
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1677193557813" ID="ID_1283963549" MODIFIED="1677193576432" TEXT="Beispiel-1">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
style="fill:black;fill-opacity:0.5;stroke:#5a8fb2;stroke-opacity:1;stroke-width:0.1"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677193578234" ID="ID_1553838226" MODIFIED="1677193626515" TEXT="Beispiel-2">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
style="fill:#ffffff;fill-opacity:0.75;stroke:none;stroke-width:0.05"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1677197293221" ID="ID_119422640" MODIFIED="1677197370570" TEXT="Verhalten stark konfigurierbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber leider nur als globales Verhalten der Inkscape-Installation
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1677197311790" ID="ID_680061629" MODIFIED="1677197317737" TEXT="Grad der XML-Vereinfachung"/>
|
|
<node CREATED="1677197318326" ID="ID_237170915" MODIFIED="1677197322760" TEXT="numerische Präzesion"/>
|
|
<node CREATED="1677197324300" ID="ID_807721887" MODIFIED="1677197330719" TEXT="automatisches Reduzieren von Styles"/>
|
|
<node CREATED="1677197342730" ID="ID_452445462" MODIFIED="1677197424732" TEXT="ob Transformationen angewendet werden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Behaviour > Transforms > store optimised
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1677197426650" ID="ID_1370427344" MODIFIED="1677197447842" TEXT="ob Gradienten und Pattern transformiert werden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1482365415326" HGAP="71" ID="ID_886002365" MODIFIED="1557498707240" TEXT="Standard C++" VSHIFT="-25">
|
|
<node CREATED="1482365430484" ID="ID_1414724077" MODIFIED="1557498707240" TEXT="chrono">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1482365434203" ID="ID_1026694670" MODIFIED="1557498707240" TEXT="lernen">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1482365448257" ID="ID_1648116305" MODIFIED="1557498707240">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ticket <font color="#ba0c3f">#886</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1620405445951" ID="ID_1127258714" MODIFIED="1620405460977" TEXT="»perfect forwarding«">
|
|
<node CREATED="1620405462300" ID="ID_1712821553" MODIFIED="1620405478341" TEXT="hatte nun mehrfach Probleme in Kombination mit Variadic-Templates"/>
|
|
<node CREATED="1620405479689" ID="ID_53418276" MODIFIED="1620405514581" TEXT="std::forward<ARGS>(args) ... ">
|
|
<node CREATED="1620405515532" ID="ID_89296387" MODIFIED="1620405524655" TEXT="wenn man damit einen ctor aufruft..."/>
|
|
<node CREATED="1620405525238" ID="ID_728173351" MODIFIED="1620405542709" TEXT="dann wählt das den copy-ctor, nicht den move-ctor"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1620405545856" ID="ID_766649583" MODIFIED="1620405565420" TEXT="mehrfach untersucht, bisher nicht verstanden">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1620405577484" ID="ID_1691540337" MODIFIED="1620405876689" TEXT="a57799d0186">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
09.05.19 17:10
|
|
</p>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
<font face="Bitstream Vera Sans Mono" size="9pt">Library: further narrowing down the tuple-forwarding problem</font>
|
|
</p>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> </font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> ...yet still not successful.</font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> </font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> The mechanism used for std::apply(tuple&) works fine when applied directly to the target function,</font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> but fails to select the proper overload when passed to a std::forward-call for</font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> "perfect forwarding". I tried again to re-build the situation of std::forward</font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> with an explicitly coded function, but failed in the end to supply a type parameter</font></pre>
|
|
<pre style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px"><font face="Bitstream Vera Sans Mono" size="9pt"> to std::forward suitably for all possible cases</font></pre>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a98ca6" DESTINATION="ID_1691540337" ENDARROW="Default" ENDINCLINATION="2957;477;" ID="Arrow_ID_1272525320" SOURCE="ID_1773619805" STARTARROW="None" STARTINCLINATION="-1064;82;"/>
|
|
</node>
|
|
<node CREATED="1620405634252" ID="ID_1554664514" MODIFIED="1620406559164" TEXT="7.5.2021">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
OpaqueUncheckedBuffer_test für InPlaceBuffer
|
|
</p>
|
|
<p>
|
|
Wieder das Gleiche: die create<ARGS....> - Funktion delegiert an den copy-ctor, selbst wenn dieser deleted ist
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#9a74a0" DESTINATION="ID_1554664514" ENDARROW="Default" ENDINCLINATION="1930;405;" ID="Arrow_ID_1066770776" SOURCE="ID_154149353" STARTARROW="None" STARTINCLINATION="-6776;285;"/>
|
|
<node CREATED="1620409111535" HGAP="73" ID="ID_1792287707" MODIFIED="1620409151241" VSHIFT="27">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
vielleicht doch
|
|
</p>
|
|
<p>
|
|
etwas Anderes
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Problem sind implizit definierte Konstruktoren in der Vererbuns-Hierarchie
|
|
</p>
|
|
<p>
|
|
sobald ich alle Move-Konstruktoren explizit definiere, funktionieren alle Fälle
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1622386272743" ID="ID_1645901699" MODIFIED="1622386277362" TEXT="I/O">
|
|
<node CREATED="1622386278646" ID="ID_359102162" MODIFIED="1622386285472" TEXT="sehr große Dateien">
|
|
<node CREATED="1622386212262" ID="ID_1502979331" LINK="https://stackoverflow.com/a/11564931" MODIFIED="1622386241238" TEXT="Stackoverflow: schreiben einer sehr großen Datei (C++14)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617648902994" ID="ID_276316646" MODIFIED="1617648906362" TEXT="C++20">
|
|
<node CREATED="1617648907316" ID="ID_899199723" MODIFIED="1617650703506" TEXT="Coroutine">
|
|
<node COLOR="#435e98" CREATED="1617648912609" ID="ID_996261679" LINK="https://lewissbaker.github.io/2017/09/25/coroutine-theory" MODIFIED="1617648936772" TEXT="Theorie und Definitionen">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1617650510224" ID="ID_537278734" MODIFIED="1617650515623" TEXT="Einsichten">
|
|
<node CREATED="1617650518471" ID="ID_1004580056" MODIFIED="1617650549015" TEXT="Coroutinen schaffen einen lokalen Scope losgelöst vom klassischen Stack(Frame)"/>
|
|
<node CREATED="1617650550016" ID="ID_1391380626" MODIFIED="1617650576747">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Coroutinen sind nicht <i>per se asynchron</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1617650606227" ID="ID_416722817" MODIFIED="1617650622874" TEXT="Coroutinen in C++20 sind ein low-level-Framework">
|
|
<node CREATED="1617650631616" ID="ID_139816499" MODIFIED="1617650648065" TEXT="auf dieser Basis werden high-level Primitive geschaffen"/>
|
|
<node CREATED="1617650648518" ID="ID_817552618" MODIFIED="1617650728738" TEXT="z.B. ein Generator ("yield value")"/>
|
|
<node CREATED="1617650655741" ID="ID_1425746097" MODIFIED="1617650665884" TEXT="oder eine asynchrone Continuation"/>
|
|
<node CREATED="1617653847900" ID="ID_921128772" MODIFIED="1617654081995" TEXT="oder leichtgewichtige Synchronisations-Primitive">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
welche dann jedoch stets aus einer Coroutine heraus per co_await aktiviert werden. Beispiel: ein lock-free mutex
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617650754576" ID="ID_716091070" MODIFIED="1617650874465">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Kontrollübergänge erfolgen ausschließlich an den <b>suspend points</b> in der Coroutine selber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das untermauert nochmal, daß Coroutinen inhärent synchron und deterministisch sind. Man kann allerdings das low-level-Framework nutzen, um an einem bestimmten suspend-point den "eingefrorenen" Zustand der Coroutine asynchron an einen anderen Thread zu übertragen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1617650891093" ID="ID_437757373" MODIFIED="1617650895248" TEXT="co_await"/>
|
|
<node CREATED="1617650895909" ID="ID_1237269411" MODIFIED="1617650899008" TEXT="co_yield"/>
|
|
<node CREATED="1617650899843" ID="ID_1357448847" MODIFIED="1617650902190" TEXT="co_return"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617653924444" ID="ID_1196316784" MODIFIED="1617653933147" TEXT="Konfiguration des konkreten Verhaltens">
|
|
<node CREATED="1617653934065" ID="ID_141023118" MODIFIED="1617653953451" TEXT="wird per Trait aus dem deklarierten Rückgabewert der Coroutine gewonnen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1617653960317" ID="ID_137807168" MODIFIED="1617653980002" TEXT="dieser ist typischerweise ein RAII-handle für die Coroutine selber"/>
|
|
<node CREATED="1617653981935" ID="ID_1379306731" MODIFIED="1617654010674" TEXT="...und implementiert geeignet die Interfaces Promise und Awaiter/Awaitable"/>
|
|
<node CREATED="1617654011852" ID="ID_1777400524" MODIFIED="1617654029031" TEXT="darüber wird das tatsächliche Verhalten gesteuert">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1617654109856" ID="ID_232615938" MODIFIED="1617654116092" TEXT="high-level-Libraries">
|
|
<node CREATED="1617654117016" ID="ID_1078296581" LINK="https://github.com/lewissbaker/cppcoro" MODIFIED="1617654125575" TEXT="Cppcoro"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1636143147825" ID="ID_224980157" MODIFIED="1636143159589" TEXT="Assembly">
|
|
<node CREATED="1636143161969" ID="ID_1119605136" MODIFIED="1636143179445" TEXT="r?x : 64-Bit-Regixter"/>
|
|
<node CREATED="1636143180154" ID="ID_858272401" MODIFIED="1636143194684" TEXT="e?x : 32-Bit-Sicht auf die gleichen Register">
|
|
<node CREATED="1636143276893" ID="ID_594751359" MODIFIED="1636143297151" TEXT="Zuweisungen/Laden füllt die oberen 32bit mit Nullen"/>
|
|
</node>
|
|
<node CREATED="1636143195465" ID="ID_1616965661" MODIFIED="1636143201882" TEXT="AT&T-Syntax">
|
|
<node CREATED="1636143203026" ID="ID_933207767" MODIFIED="1636143220340" TEXT="% vor den Registern"/>
|
|
<node CREATED="1636143221216" ID="ID_641364971" MODIFIED="1636143234231" TEXT="runde Klammer für Dereferenzierung"/>
|
|
<node CREATED="1636143235054" ID="ID_1739317797" MODIFIED="1636143243374" TEXT="Zuweisung (mov) von links nach rechts"/>
|
|
</node>
|
|
<node CREATED="1636143494277" ID="ID_1080108853" MODIFIED="1636143500226" TEXT="Anweisungen">
|
|
<node CREATED="1636143501180" ID="ID_1211472193" MODIFIED="1636143506273" TEXT="mov : Zuweisung"/>
|
|
<node CREATED="1636143506942" ID="ID_1875495168" MODIFIED="1636143548281" TEXT="lea : Adresse laden">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"load effective address"<br />Es entspricht also dem &-Operator in C
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1512178947582" ID="ID_1778761323" MODIFIED="1557498707240">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lessons
|
|
</p>
|
|
<p>
|
|
learned
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1512178960281" ID="ID_1847018554" MODIFIED="1557498707240" TEXT="SFINAE">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1512178984189" ID="ID_226963358" MODIFIED="1557498707240" TEXT="Fehler im Check scheitern stillschweigend">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1512179012761" FOLDED="true" ID="ID_1425607905" MODIFIED="1557498707240">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf <i>incomplete type</i> achten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1512179030982" ID="ID_895612426" MODIFIED="1557498707240" TEXT="sizeof()"/>
|
|
<node CREATED="1512179035013" ID="ID_1663591306" MODIFIED="1557498707240" TEXT="member-pointer"/>
|
|
<node CREATED="1512179039109" ID="ID_746391928" MODIFIED="1557498707240">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Vorsicht bei
|
|
</p>
|
|
<p>
|
|
mutually dependent templates
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1512179063250" ID="ID_933791979" MODIFIED="1576282357939" TEXT="während der Instantiierung....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kann eines der Templates im Zyklus vorrübergehend als "incomplete" gelten.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512179134400" ID="ID_1738202679" MODIFIED="1576282357939" TEXT="....kann die Metafunktion scheitern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wenn man dummerweise auf verschlungenen Pfaden
|
|
</p>
|
|
<p>
|
|
genau in dieser Phase die Metafunktion anfragt,
|
|
</p>
|
|
<p>
|
|
kann der betreffende Check stillschweigend scheitern.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Konsequenz: man wählt dann z.B. eine subtil falsche Spezialisierung.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1512179201831" ID="ID_1577563892" MODIFIED="1557498707240" TEXT="tückischer Fehler">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576410376184" FOLDED="true" ID="ID_1999847041" MODIFIED="1576413594967" TEXT="C++: Regeln für implizite Ctor">
|
|
<linktarget COLOR="#4963d8" DESTINATION="ID_1999847041" ENDARROW="Default" ENDINCLINATION="-4316;0;" ID="Arrow_ID_809724531" SOURCE="ID_1010651919" STARTARROW="None" STARTINCLINATION="-6312;349;"/>
|
|
<node COLOR="#435e98" CREATED="1576411524771" ID="ID_1113045308" LINK="https://stackoverflow.com/a/13345578" MODIFIED="1576411545061" TEXT="Stackoverflow">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1576410536554" ID="ID_283720267" MODIFIED="1576410686060">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
werden u.U sillschweigend <b>nicht</b> generiert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wenn bestimmte Vorraussetzungen <i>nicht erfüllt</i> sind, dann unterbleibt das automatische Injizieren eines generierten Konstruktors. Die Klasse verhält sich dann so, als wäre die btr. Definition nicht gegeben...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1576410705370" ID="ID_1306160146" MODIFIED="1576410795799" TEXT="tückisch: ggfs erwartetes implizites Verhalten findet nicht statt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. Member-Init kann unterbleiben (bei elementaren Typen, wenn die Klasse damit ein POD wird).
|
|
</p>
|
|
<p>
|
|
Und noch häufiger: wir schwenken von Move-Konstruktion auf Copy-Konstruktion um
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1576410798222" ID="ID_589275948" MODIFIED="1576410813888" TEXT="Abhilfe: was wichtig ist, stets explizit definieren"/>
|
|
<node CREATED="1576412962086" ID="ID_714316723" MODIFIED="1576412969679" TEXT="Tip: Fehler provozieren">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1576412971076" ID="ID_310988477" MODIFIED="1576412980494" TEXT="indem man explizit mal aufruft, was man erwartet"/>
|
|
<node CREATED="1576412981491" ID="ID_1451048709" MODIFIED="1576413215568" TEXT="Template-Traces lesen lernen....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
error: use of deleted function Derived::Derived(const Derived &)
|
|
</p>
|
|
<p>
|
|
note: Derived::Derived(const Derived &) is implicitly deleted because the default definition would be ill-formed:
|
|
</p>
|
|
<p>
|
|
...und dann kommt der Fehler, der passieren <b>würde</b>....
|
|
</p>
|
|
<p>
|
|
error: use of deleted function Base::Base(const Base&)
|
|
</p>
|
|
<p>
|
|
note: Base::Base(const Base&)  is implicitly deleted because the default definition would be ill-formed:
|
|
</p>
|
|
<p>
|
|
error: use of deleted function SomeMember::SomeMember(const SomeMember &)
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
<p>
|
|
...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1576413219987" ID="ID_601627408" MODIFIED="1576413226208" TEXT="der Compiler ist Dein Froind"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1576411548659" ID="ID_1088124413" MODIFIED="1576411553075" TEXT="default-ctor">
|
|
<node CREATED="1576411555738" ID="ID_810441855" MODIFIED="1576411577563" TEXT="nicht wenn irgend ein Member inline initialisiert wird!"/>
|
|
</node>
|
|
<node CREATED="1576411594053" ID="ID_181876076" MODIFIED="1576411598691" TEXT="copy/move">
|
|
<node CREATED="1576411599805" ID="ID_492402771" MODIFIED="1576411615709" TEXT="nicht wenn auch nur einer der "big five" definiert ist"/>
|
|
<node CREATED="1576411616722" ID="ID_38658612" MODIFIED="1576411634218" TEXT="Achtung: im Besonderen der dtor schaltet damit Auto-Generierun ab"/>
|
|
</node>
|
|
<node CREATED="1576411685336" ID="ID_168955305" MODIFIED="1576411687363" TEXT="move">
|
|
<node CREATED="1576411688040" ID="ID_430174340" MODIFIED="1576411707490" TEXT="wenn der generierte move-Code irgendwo einen Fehler produzieren würde"/>
|
|
<node CREATED="1576411708150" ID="ID_728246628" MODIFIED="1576411719224" TEXT="das kann mehrere Ebenen tief rekursiv der Fall sein"/>
|
|
<node CREATED="1576411733367" ID="ID_1365339586" MODIFIED="1576411734752" TEXT="Tips">
|
|
<node CREATED="1576411735874" ID="ID_240070307" MODIFIED="1576411738544" TEXT="Referenzen"/>
|
|
<node CREATED="1576411739241" ID="ID_1459661901" MODIFIED="1576411778582" TEXT="Member/Basisklassen bei denen ebenfalls die implizite Generierung unterbleibt"/>
|
|
<node CREATED="1576411779540" ID="ID_816697044" MODIFIED="1576411801603" TEXT="ein nicht verfügbarer/aufrufbarer dtor (wegen move!)"/>
|
|
<node CREATED="1576411803728" ID="ID_1798497956" MODIFIED="1576411812841" TEXT="Variant-Typen (unions)"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1625963909013" FOLDED="true" ID="ID_772999255" MODIFIED="1625963914852" TEXT="std::initializer_list">
|
|
<node CREATED="1625963919421" ID="ID_898662178" MODIFIED="1625963952504">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die <i>uniform initialisation</i> ist leider unrund geraten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1625963954723" ID="ID_867098334" MODIFIED="1625963998275" TEXT="ein eigens definierter initializer_list-Ctor setzt praktisch alle anderen Ctors "außer Gefecht"">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1625964012581" ID="ID_725341195" LINK="https://akrzemi1.wordpress.com/2016/07/07/the-cost-of-stdinitializer_list" MODIFIED="1625964083266">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die Werte in der initializer_list sind Values und werden <b>per copy-Konstruktion erstellt</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1450488895106" ID="ID_1586185818" MODIFIED="1557498707240" TEXT="Threading">
|
|
<node CREATED="1450488902049" ID="ID_1126260262" MODIFIED="1557498707240" TEXT="static init">
|
|
<linktarget COLOR="#9a97b5" DESTINATION="ID_1126260262" ENDARROW="Default" ENDINCLINATION="-1465;211;" ID="Arrow_ID_372705466" SOURCE="ID_1086493226" STARTARROW="None" STARTINCLINATION="-1025;0;"/>
|
|
<linktarget COLOR="#9e9bae" DESTINATION="ID_1126260262" ENDARROW="Default" ENDINCLINATION="-1485;213;" ID="Arrow_ID_1269745634" SOURCE="ID_1921668956" STARTARROW="None" STARTINCLINATION="-1534;0;"/>
|
|
<node CREATED="1450489361187" ID="ID_1013681859" LINK="http://stackoverflow.com/a/17803616/444796" MODIFIED="1557498707240" TEXT="Zusammenfassung (SO)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1525123890877" ID="ID_558698687" LINK="http://en.cppreference.com/w/cpp/language/initialization#Non-local_variables" MODIFIED="1557498707240" TEXT="ausführlich in der CPPreference">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1525130640512" ID="ID_856205786" LINK="https://stackoverflow.com/a/1825872/444796" MODIFIED="1557498707240" TEXT="wichtig: Triggern der statischen Instanz (SO)">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1525191808145" FOLDED="true" ID="ID_228531407" MODIFIED="1557498707240" TEXT="ungeklärtes Problem mit Initialisierungs-Reihenfolge">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1525191859371" ID="ID_1136158199" MODIFIED="1576282357938" TEXT="tritt auf in statischem init-Kontext">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ein Template ein statisches member-Feld hat,
|
|
</p>
|
|
<p>
|
|
dann ist zusätzlich eine getemplatete <i>Definition</i> dieses Feldes notwendig.
|
|
</p>
|
|
<p>
|
|
Diese wird erst generiert, wenn der erste <b>odr-use</b> des statischen Member-Feldes passiert.
|
|
</p>
|
|
<p>
|
|
Dieser odr-use kann nun z.B. aus einer Funktion des Template heraus erfolgen
|
|
</p>
|
|
<p>
|
|
Allerdings beobachte ich, daß dann der ctor-Aufruf zur Initialisierung erst <i>nach dem Zugriff</i> auf
|
|
</p>
|
|
<p>
|
|
das member-Feld passiert, sofern der Aufruf und damit die Instanz des umschließenden Template
|
|
</p>
|
|
<p>
|
|
selber aus einem statischen Initialisierungs-Kontext heraus erfolgt.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1525192054281" ID="ID_414612523" MODIFIED="1557498707240" TEXT="#1142 initialisation of static template members">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1525192237928" ID="ID_1523643615" MODIFIED="1576282357937" TEXT="Demo-Beispiel: g++ --std=gnu++14 blei.cpp -o blei">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
#include <iostream>
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
using std::cout;
|
|
</p>
|
|
<p>
|
|
using std::endl;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
template<typename T>
|
|
</p>
|
|
<p>
|
|
class Factory
|
|
</p>
|
|
<p>
|
|
  {
|
|
</p>
|
|
<p>
|
|
  public:
|
|
</p>
|
|
<p>
|
|
    T val;
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    Factory()
|
|
</p>
|
|
<p>
|
|
      : val{}
|
|
</p>
|
|
<p>
|
|
      {
|
|
</p>
|
|
<p>
|
|
        cout << "Factory-ctor  val="<<val<<endl;
|
|
</p>
|
|
<p>
|
|
      }
|
|
</p>
|
|
<p>
|
|
  };
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
template<typename T>
|
|
</p>
|
|
<p>
|
|
class Front
|
|
</p>
|
|
<p>
|
|
  {
|
|
</p>
|
|
<p>
|
|
  public:
|
|
</p>
|
|
<p>
|
|
    static Factory<T> fac;
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    Front()
|
|
</p>
|
|
<p>
|
|
      {
|
|
</p>
|
|
<p>
|
|
        cout << "Front-ctor    val="<<fac.val<<endl;
|
|
</p>
|
|
<p>
|
|
        fac.val += 100;
|
|
</p>
|
|
<p>
|
|
      }
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    T&
|
|
</p>
|
|
<p>
|
|
    operate ()
|
|
</p>
|
|
<p>
|
|
      {
|
|
</p>
|
|
<p>
|
|
        cout << "Front-operate val="<<fac.val<<endl;
|
|
</p>
|
|
<p>
|
|
        ++ fac.val;
|
|
</p>
|
|
<p>
|
|
        return fac.val;
|
|
</p>
|
|
<p>
|
|
      }
|
|
</p>
|
|
<p>
|
|
  };
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
template<typename T>
|
|
</p>
|
|
<p>
|
|
Factory<T> Front<T>::fac;
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
namespace {
|
|
</p>
|
|
<p>
|
|
  Front<int> front;
|
|
</p>
|
|
<p>
|
|
  int global_int = front.operate();
|
|
</p>
|
|
<p>
|
|
}
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
int
|
|
</p>
|
|
<p>
|
|
main (int, char**)
|
|
</p>
|
|
<p>
|
|
  {
|
|
</p>
|
|
<p>
|
|
    Front<int> fint;
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    int& i = fint.operate();
|
|
</p>
|
|
<p>
|
|
    cout << "main:         val="<<i<<endl;
|
|
</p>
|
|
<p>
|
|
    cout << "global_int.......="<<global_int<<endl;
|
|
</p>
|
|
<p>
|
|
   
|
|
</p>
|
|
<p>
|
|
    return 0;
|
|
</p>
|
|
<p>
|
|
  }
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1450489388912" ID="ID_1935538293" MODIFIED="1557498707240" TEXT="function-static">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1450489395711" ID="ID_1661542298" MODIFIED="1557498707240" TEXT="when ctrl flow enters first"/>
|
|
<node CREATED="1450489412364" ID="ID_965405072" LINK="http://stackoverflow.com/a/8102145/444796" MODIFIED="1557498707240" TEXT="threadsafe since C++11"/>
|
|
<node CREATED="1450489421795" ID="ID_12247357" MODIFIED="1557498707240" TEXT="lives until the end of the program"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521779331036" FOLDED="true" ID="ID_1416813337" MODIFIED="1561827466249" TEXT="memory access ordering">
|
|
<linktarget COLOR="#5a6caa" DESTINATION="ID_1416813337" ENDARROW="Default" ENDINCLINATION="-1755;162;" ID="Arrow_ID_751165448" SOURCE="ID_1772115642" STARTARROW="None" STARTINCLINATION="-4287;-237;"/>
|
|
<node CREATED="1521779387708" ID="ID_663855061" MODIFIED="1521779394271" TEXT="C++ memory model"/>
|
|
<node CREATED="1521779395219" ID="ID_1890752917" MODIFIED="1521779403446" TEXT="C++11 Atomic library"/>
|
|
<node CREATED="1521783284922" ID="ID_970193431" MODIFIED="1521783295429" TEXT="Quellen & Erläuterungen">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521783300728" ID="ID_789225244" LINK="http://preshing.com/20120913/acquire-and-release-semantics/" MODIFIED="1521783329728" TEXT="Blog: Preshing on Programming"/>
|
|
<node CREATED="1521783335195" ID="ID_722067069" LINK="http://en.cppreference.com/w/cpp/atomic/memory_order" MODIFIED="1521783351104" TEXT="CPP-Reference"/>
|
|
</node>
|
|
<node CREATED="1521779409601" FOLDED="true" ID="ID_1607777448" MODIFIED="1576282357936" TEXT="fences vs. barriers vs ordering constraints">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das sind verschiedene Blickwinkel auf das gleiche Thema
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1521779467554" ID="ID_257299836" MODIFIED="1521779468925" TEXT="fence">
|
|
<node CREATED="1521779469969" ID="ID_178160333" MODIFIED="1521779473476" TEXT="total-global"/>
|
|
<node CREATED="1521779489966" ID="ID_113452488" MODIFIED="1521779500040" TEXT="das ganze System sieht alle Änderungen"/>
|
|
<node CREATED="1521779502213" ID="ID_503013735" MODIFIED="1521779525101" TEXT="Keine Umordnung durch Compiler oder CPU"/>
|
|
</node>
|
|
<node CREATED="1521779532728" ID="ID_263784335" MODIFIED="1521779534459" TEXT="barrier">
|
|
<node CREATED="1521779535264" ID="ID_1004323525" MODIFIED="1521779541691" TEXT="bestimmte Umordnungen werden verboten"/>
|
|
<node CREATED="1521779542351" ID="ID_219555790" MODIFIED="1576282357936" TEXT="vier Typen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bedeutung dieser Schreibweise:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
der erste Zugriff liegt vor der Barriere, der zweite danach
|
|
</li>
|
|
<li>
|
|
die Barriere garantiert jeweils nur, daß der zweitgenannte Zugriff nicht vor den erstgenannten verschoben werden kann
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1521779549150" ID="ID_754401646" MODIFIED="1521779560424" TEXT="ReadRead"/>
|
|
<node CREATED="1521779561540" ID="ID_177816200" MODIFIED="1521779564336" TEXT="ReadWrite"/>
|
|
<node CREATED="1521779565188" ID="ID_1059751946" MODIFIED="1521779570999" TEXT="WriteWrite"/>
|
|
<node CREATED="1521779572470" ID="ID_853931655" MODIFIED="1521779576702" TEXT="WriteRead"/>
|
|
</node>
|
|
<node CREATED="1521779611813" ID="ID_1803991638" MODIFIED="1521779620277" TEXT="Vorsicht">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1521779621764" ID="ID_818642871" MODIFIED="1521779630422" TEXT="garantiert keine Atomizität"/>
|
|
<node CREATED="1521779631386" ID="ID_548078416" MODIFIED="1521779642021" TEXT="garantiert keine data-dependency consistency"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521779647000" ID="ID_641325372" MODIFIED="1521779651836" TEXT="constraints">
|
|
<node CREATED="1521779654007" ID="ID_1897577946" MODIFIED="1521779668209" TEXT="werden an eine (meist atomare) Guard-Variable gebunden"/>
|
|
<node CREATED="1521779776975" ID="ID_594964930" MODIFIED="1521779831563" TEXT="erzeugen Relation für Zugriffe auf Payload">
|
|
<node CREATED="1521779923346" ID="ID_725815164" MODIFIED="1521779936380" TEXT="geregelt wird Sichtbarkeit von Änderungen"/>
|
|
<node CREATED="1521779943743" ID="ID_433064665" MODIFIED="1521779963241" TEXT="Payload == bestimmte nicht-atomare Variablen"/>
|
|
<node CREATED="1521779978451" ID="ID_459766743" MODIFIED="1521779988549" TEXT="welche?">
|
|
<node CREATED="1521779990345" ID="ID_6762933" MODIFIED="1521779995036" TEXT="normalerweise "alle""/>
|
|
<node CREATED="1521779996480" ID="ID_1211879916" MODIFIED="1521780022216" TEXT="für "consume"-Semantik aber nur solche mit data-dependency"/>
|
|
</node>
|
|
<node CREATED="1521780026668" ID="ID_1047639499" MODIFIED="1521780044109" TEXT="Zusammenhang wird durch Nutzungspattern hergestellt">
|
|
<node CREATED="1521780047969" ID="ID_1812009696" MODIFIED="1521780057251" TEXT="Zugriff/Mutation nur..."/>
|
|
<node CREATED="1521780057775" ID="ID_216370648" MODIFIED="1521780074977" TEXT="wenn Signaliisierung via Guard sichtbar wird"/>
|
|
<node CREATED="1521780076253" ID="ID_708835482" MODIFIED="1521780116390">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eine <i>Solche</i> konstituiert die synchronizes-with-Beziehuung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521779841462" ID="ID_1131913901" MODIFIED="1521779896124">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Grundbeziehung</b>: synchronizes-with
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521780332842" ID="ID_968730029" MODIFIED="1521780339536" TEXT="Mutex">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1521780355015" ID="ID_1565927718" MODIFIED="1521780366841" TEXT="erzeugt einen vollen Fence auf beiden Seiten"/>
|
|
<node CREATED="1521780375364" ID="ID_816580184" MODIFIED="1521780391453" TEXT="d.h. am Eingang und Ausgang gelten alle vier barriers"/>
|
|
<node CREATED="1521780411423" ID="ID_1904243826" MODIFIED="1521780423585" TEXT="das impliziert auch Atomizität"/>
|
|
<node CREATED="1521780424149" ID="ID_1787016583" MODIFIED="1521780430670" TEXT="aber">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1521780432156" ID="ID_583365135" MODIFIED="1521780487933">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das gilt nur im Rahmen der <b>synchronizes-with</b>-Beziehung
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521780488708" ID="ID_945270217" MODIFIED="1521780517520">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, nur für einen <b>vom gleichen Mutex geschützen</b>  Bereich!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521782262223" HGAP="30" ID="ID_1323377815" MODIFIED="1576282357935" TEXT="Typisches Gegenbeispiel: Double Checked Locking" VSHIFT="18">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
In der <i>naiven Implementierung</i> greift der prüfende Thread auf die instance-Variable
|
|
</p>
|
|
<p>
|
|
<i>ohne jedwede Beziehung</i> zum anderen Thread zu; er verwendet keinen Mutex und keinen Atomic.
|
|
</p>
|
|
<p>
|
|
Und genau deshalb kann er das Setzen des Instanz-Pointers sehen, ohne daß eine
|
|
</p>
|
|
<p>
|
|
Ordnungsbeziehung zur der restlichen Initialisierung oder lazy computation besteht.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Fix: die Beziehung herstellen. Das ist verursacht stets zusätzliche Kosten.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Allerdinsg nicht auf einer Plattform, die ohnehin sequentiell-konsistent ist. Wie "zum Beispiel" x86/64
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521791354104" HGAP="-1" ID="ID_287671137" MODIFIED="1521791364604" TEXT="grundsätzlich...." VSHIFT="7">
|
|
<node CREATED="1521791365590" ID="ID_1571110438" MODIFIED="1521791379580">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...haben wir es hier mit einem <b>Pattern</b> zu tun
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521791417311" ID="ID_668833788" MODIFIED="1521791528549">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich nenne es "<b>synchronised visibility cones</b>"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1521791441996" ID="ID_656786136" MODIFIED="1521791513129">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dieses errichtet die Fiktion,
|
|
</p>
|
|
<p>
|
|
als würden wir nur auf einer gemeinsamen (shared) Instanz arbeiten.
|
|
</p>
|
|
<p>
|
|
In Realität arbeiten mehrere Threads/Cores mit mehreren Entitäten
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1521791567491" ID="ID_328701027" MODIFIED="1576282357934" TEXT="Code muß das Bestehen der Beziehung aktiv prüfen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...und andernfalls überhaupt vermeiden,
|
|
</p>
|
|
<p>
|
|
die shared zone anzufassen!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491098340549" ID="ID_938211341" MODIFIED="1557498707240" TEXT="Toolchain">
|
|
<node CREATED="1491098346053" ID="ID_1333373693" MODIFIED="1557498707240" TEXT="Doxygen">
|
|
<node CREATED="1491098370281" ID="ID_1904535196" MODIFIED="1557498707240" TEXT="Konfig"/>
|
|
<node CREATED="1491098373816" ID="ID_1022990703" MODIFIED="1557498707240" TEXT="Fallen">
|
|
<node CREATED="1491099064125" ID="ID_651937703" MODIFIED="1557498707240" TEXT="Dateien ohne @file werden nicht dokumentiert"/>
|
|
<node CREATED="1491099088362" ID="ID_1507484869" MODIFIED="1576282357934" TEXT="Template-Parameter in Klassennamen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn eine getemplatete Klasse zum Qualifizieren eines Feldes verwendet wird,
|
|
</p>
|
|
<p>
|
|
dann müssen die formalen Template-Parameter in spitzen Klammern mit angegeben werden.
|
|
</p>
|
|
<p>
|
|
D.h. Doxygen ist hier genauso penibel wie C++ selber
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Beispiel
|
|
</p>
|
|
<p>
|
|
Query<RES>::resolveBy
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1491099311253" ID="ID_307124479" MODIFIED="1576282357933">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
@param hat <b>stets</b> einen Parameternamen als Argument
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...der ist <i>nicht</i> optional
|
|
</p>
|
|
<p>
|
|
vielmehr wird blindlings immer das erste Wort genommen.
|
|
</p>
|
|
<p>
|
|
Wenn der Parameter selber nicht benannt ist (z.B. pure virtual function),
|
|
</p>
|
|
<p>
|
|
kann man ersatzweise einfach einen Typnamen angeben.
|
|
</p>
|
|
<p>
|
|
Sofern alle Parameter dokumentiert sind, klappt das.
|
|
</p>
|
|
<p>
|
|
sonst kommt Doxygen durcheinander
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1611414331032" ID="ID_772377087" MODIFIED="1611414385896" TEXT="Dokumentations-Kommentar muß mit "/**" beginnen (exakt zwei Sterne!)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
also keine "Banner" aus Sternen.<br />Abhilfe: /*********************//**
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491098382888" FOLDED="true" ID="ID_1568153886" MODIFIED="1557498707240" TEXT="Probleme">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1491098385823" ID="ID_801230289" MODIFIED="1557498707240" TEXT="Auto-Links">
|
|
<node CREATED="1491098393405" ID="ID_1408589913" MODIFIED="1557498707240" TEXT="funktionieren in vielen Fällen nicht"/>
|
|
<node CREATED="1491098402197" ID="ID_1572559975" MODIFIED="1557498707240" TEXT="Verdacht: muß Namespaces qualifizieren?"/>
|
|
<node CREATED="1491098427785" ID="ID_719835617" MODIFIED="1576282357933" TEXT="Beispiel: alle Unit-Tests">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....haben in ihrem @file-Kommentar
|
|
</p>
|
|
<p>
|
|
einen Verweis \ref DieserUnit_test
|
|
</p>
|
|
<p>
|
|
Und obwohl das der exakte Klassennahme ist,
|
|
</p>
|
|
<p>
|
|
und obwohl genau diese Klasse im Klassenindex zu finden ist
|
|
</p>
|
|
<p>
|
|
wird hier kein Link erzeugt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611412636691" ID="ID_972826576" MODIFIED="1611412651452" TEXT="Fehlersuche">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1611412673543" ID="ID_1658996929" MODIFIED="1611412691750" TEXT="versuchshalber explizit einen Link per \ref erzweingen"/>
|
|
<node CREATED="1611412652657" ID="ID_1149640138" MODIFIED="1611412667586" TEXT="doxygen-warning.txt durchsuchen"/>
|
|
<node CREATED="1611412694100" ID="ID_1782021607" MODIFIED="1611412711705" TEXT="sicherstellen daß...">
|
|
<node CREATED="1611412712385" ID="ID_1286698190" LINK="https://stackoverflow.com/a/46895346" MODIFIED="1611416096145" TEXT="der umschließende Namespace dokumentiert ist">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1611412720896" ID="ID_1416946834" MODIFIED="1611412732531" TEXT="das definierende File einen @file-Kommentar hat"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1611414193640" ID="ID_1495280173" MODIFIED="1611414203972" TEXT="Markdown">
|
|
<node CREATED="1611414205207" ID="ID_1304449575" MODIFIED="1611414215413" TEXT="funktioniert generell recht zuverlässig"/>
|
|
<node CREATED="1611414215893" ID="ID_1250665044" MODIFIED="1611414235234" TEXT="Header-Hierarchie muß konsistent sein">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1611414254368" ID="ID_1103685826" MODIFIED="1611414275946" TEXT="d.h. die erste Zwischenüberschrift auf Level-1 (Präfix "#")"/>
|
|
<node CREATED="1611414236218" ID="ID_1711467407" MODIFIED="1611414253828" TEXT="sonst werden die btrf. Überschriften komplett unterdrückt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1491098487889" ID="ID_1401713015" MODIFIED="1611412586548" TEXT="Sqlite-Support">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1491098494497" ID="ID_1565133197" MODIFIED="1557498707241" TEXT="ist wohl noch sehr vorläufig"/>
|
|
<node CREATED="1491098499712" ID="ID_1643743799" MODIFIED="1557498707241" TEXT="wenn eine Sqlite-DB gefunden wird...."/>
|
|
<node CREATED="1491098515845" ID="ID_1313255620" MODIFIED="1557498707241" TEXT="produziert er jede Menge Constraint-Verletzungen"/>
|
|
<node CREATED="1491098525396" ID="ID_1962242264" MODIFIED="1557498707241" TEXT="Tip: Sqlite-DB weglöschen!!!"/>
|
|
<node CREATED="1611412589929" ID="ID_1865414656" MODIFIED="1611412626461" TEXT="Doxygen 1.8.13 generiert jetzt per default kein Sqlite mehr"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1538838573613" ID="ID_1610361741" MODIFIED="1557498707241" TEXT="Graphic">
|
|
<node CREATED="1538838576956" ID="ID_1174319279" MODIFIED="1665346614450" TEXT="SVG-Icons">
|
|
<linktarget COLOR="#668497" DESTINATION="ID_1174319279" ENDARROW="Default" ENDINCLINATION="-533;-310;" ID="Arrow_ID_1274211300" SOURCE="ID_465159869" STARTARROW="None" STARTINCLINATION="-2393;215;"/>
|
|
<node CREATED="1504201038435" ID="ID_1569870904" MODIFIED="1557498707241" TEXT="Anleitung">
|
|
<linktarget COLOR="#8697d2" DESTINATION="ID_1569870904" ENDARROW="Default" ENDINCLINATION="-935;-133;" ID="Arrow_ID_421953450" SOURCE="ID_1898190659" STARTARROW="None" STARTINCLINATION="-861;94;"/>
|
|
<node CREATED="1504201044122" ID="ID_612955500" MODIFIED="1557498707241" TEXT="SVG in data/icons/svg"/>
|
|
<node CREATED="1504201192870" ID="ID_823572488" MODIFIED="1576282357932" TEXT="Dokument-Größe anscheinend egal">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...wird zwar vom Skript ausgelesen,
|
|
</p>
|
|
<p>
|
|
aber nicht weiterverwendet.
|
|
</p>
|
|
<p>
|
|
Die Icon-Größen ergeben sich aus den Boxes auf 'plate'
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1504201055449" ID="ID_1652674635" MODIFIED="1557498707241" TEXT="braucht 'artwork:'-Layer"/>
|
|
<node CREATED="1504201074566" ID="ID_1803123712" MODIFIED="1557498707241" TEXT="braucht Sub-Layer 'plate'">
|
|
<node CREATED="1504201085348" ID="ID_971103885" MODIFIED="1557498707241" TEXT="dort bounding-boxes"/>
|
|
<node CREATED="1504201089491" ID="ID_1411697919" MODIFIED="1557498707241" TEXT="deren Größe in PX ist die Icon-Größe"/>
|
|
<node CREATED="1504201101314" ID="ID_813225733" MODIFIED="1557498707241" TEXT="brauche 16, 22, 32"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1437693678626" HGAP="117" ID="ID_1536988357" MODIFIED="1557498707241" POSITION="left" TEXT="Doku" VSHIFT="-47">
|
|
<node CREATED="1437693687650" ID="ID_1484874437" MODIFIED="1557498707241" TEXT="Sound-Systeme">
|
|
<node CREATED="1437693693617" ID="ID_955932218" LINK="https://wiki.debian.org/Sound" MODIFIED="1576282357932" TEXT="siehe die Debian-Übersichtsseite">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...im Besonderen die guten Diagramme für Pulse, ALSA und Jack
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1522933281517" HGAP="79" ID="ID_1743316782" MODIFIED="1557498707241" POSITION="left" TEXT="Entwicklung" VSHIFT="-6">
|
|
<edge COLOR="#9e7171" STYLE="linear"/>
|
|
<font NAME="SansSerif" SIZE="16"/>
|
|
<node CREATED="1522933436743" ID="ID_669941386" MODIFIED="1557498707241" TEXT="Architektur">
|
|
<node CREATED="1522933471266" ID="ID_1652255203" MODIFIED="1557498707241" TEXT="GUI">
|
|
<node COLOR="#435e98" CREATED="1522933474914" FOLDED="true" ID="ID_1612113311" MODIFIED="1561238415968" TEXT="Backbone">
|
|
<linktarget COLOR="#6278c0" DESTINATION="ID_1612113311" ENDARROW="Default" ENDINCLINATION="94;100;" ID="Arrow_ID_879038794" SOURCE="ID_1835644126" STARTARROW="None" STARTINCLINATION="-3;-77;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1522934000737" ID="ID_1881825617" MODIFIED="1557498707241" TEXT="brauche top-Level">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561238405397" ID="ID_1386160088" MODIFIED="1561238413453" TEXT="verbesserte Dependency-Injection">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1522934018175" ID="ID_463339540" MODIFIED="1561238164819" TEXT="muß Komponente allozieren können">
|
|
<linktarget COLOR="#34a79a" DESTINATION="ID_463339540" ENDARROW="Default" ENDINCLINATION="355;0;" ID="Arrow_ID_636625875" SOURCE="ID_34008801" STARTARROW="None" STARTINCLINATION="55;1;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#435e98" CREATED="1561238166116" ID="ID_1440602260" MODIFIED="1561238254089" TEXT="neues mächtiges Framework hierfür angelegt">
|
|
<node COLOR="#338800" CREATED="1561238195872" ID="ID_403413272" MODIFIED="1561238208076" TEXT="UI-Koordinaten">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561238199759" ID="ID_1160624360" MODIFIED="1561238207378" TEXT="ein Resolver-Mechanismus">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561238209064" ID="ID_470273768" MODIFIED="1561238232000" TEXT="TODO: Implementierung auf real-existierendem GUI">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1561238233366" ID="ID_947719044" MODIFIED="1561238242701" TEXT="es existiert noch nicht real">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561238181398" ID="ID_796742878" MODIFIED="1561238255857" TEXT="vorläufige Abkürzungs-Lösung bereitgestellt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#642842" CREATED="1522933478066" FOLDED="true" ID="ID_533257050" MODIFIED="1679082529294" TEXT="Timeline">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="back"/>
|
|
<node COLOR="#8e0099" CREATED="1522934041940" ID="ID_706725110" MODIFIED="1561238284015" TEXT="ist kamputt">
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1522934923858" ID="ID_369497864" MODIFIED="1561238291010" TEXT="braucht bessere Architektur">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561238293019" FOLDED="true" ID="ID_567481580" MODIFIED="1679080850947" TEXT="Komplette Reimplementierung auf den Weg gebracht">
|
|
<linktarget COLOR="#6971ce" DESTINATION="ID_567481580" ENDARROW="Default" ENDINCLINATION="450;38;" ID="Arrow_ID_1010232773" SOURCE="ID_1016002524" STARTARROW="None" STARTINCLINATION="124;16;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1561238424279" HGAP="63" ID="ID_705841731" MODIFIED="1679082496688" TEXT="offene Enden" VSHIFT="-23">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
auf diese Stellen konzentrierte sich für längere Zeit die Aktivität, und keines dieser Themen konnte ich wirklich abschließen, denn es sind noch zu viele strategische Fragen ungeklärt — mit 2022 ist immerhin jedes dieser Themen auf einen längerfristig tragfähigen Grund gestellt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_705841731" ENDARROW="Default" ENDINCLINATION="41;43;" ID="Arrow_ID_628057734" SOURCE="ID_52008403" STARTARROW="None" STARTINCLINATION="120;5;"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="info"/>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_1875608147" MODIFIED="1679084657085" STYLE="bubble" TEXT="ElementBox-Widget">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_1863177537" ENDARROW="Default" ENDINCLINATION="-366;30;" ID="Arrow_ID_1412423566" STARTARROW="None" STARTINCLINATION="-2400;-277;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_430878592" MODIFIED="1679084618404" STYLE="bubble" TEXT="Layout-Steuerung">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_82409060" ENDARROW="Default" ENDINCLINATION="-1352;202;" ID="Arrow_ID_1110289108" STARTARROW="None" STARTINCLINATION="-2400;-277;"/>
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_35592741" ENDARROW="Default" ENDINCLINATION="-366;30;" ID="Arrow_ID_949004312" STARTARROW="None" STARTINCLINATION="-2163;252;"/>
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_1600275521" ENDARROW="Default" ENDINCLINATION="-506;31;" ID="Arrow_ID_694017211" STARTARROW="None" STARTINCLINATION="-2163;252;"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#eb1854" CREATED="1611035931543" HGAP="329" ID="ID_1578788883" MODIFIED="1654441303329" STYLE="bubble" TEXT="⌛ Stand 2020-4 ⁐ 2022-6" VSHIFT="5">
|
|
<edge COLOR="#eb1854" STYLE="sharp_linear" WIDTH="4"/>
|
|
<arrowlink COLOR="#faeab8" DESTINATION="ID_1392905607" ENDARROW="Default" ENDINCLINATION="-1498;-119;" ID="Arrow_ID_871958604" STARTARROW="None" STARTINCLINATION="-2110;202;"/>
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node COLOR="#435e98" CREATED="1611036115693" ID="ID_797238968" MODIFIED="1611036457975" TEXT="Design für Canvas-Attachment gelöst">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611036133179" ID="ID_129940687" MODIFIED="1611036440243" TEXT="Grundlage der der Clip-Anzeige gelegt">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1611036133179" ID="ID_1591008815" MODIFIED="1654441292474" TEXT="Grundlage für Gesten-controller gelegt">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1611036133179" ID="ID_1763333735" MODIFIED="1611036535606" TEXT="Nahziel: einfachste »abridged«-Anzeige">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679082437934" ID="ID_52008403" MODIFIED="1679082496688" TEXT="viele offene Enden warten auf eine weiter ausgearbeitete Applikation">
|
|
<arrowlink DESTINATION="ID_705841731" ENDARROW="Default" ENDINCLINATION="41;43;" ID="Arrow_ID_628057734" STARTARROW="None" STARTINCLINATION="120;5;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933489912" ID="ID_909250916" MODIFIED="1557498707241" TEXT="Session">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1522934151421" ID="ID_580296278" MODIFIED="1557498707241" TEXT="Element-Erzeugung implementieren">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1522934106715" ID="ID_1908249834" MODIFIED="1557498707241" TEXT="Placement-Logik implementieren">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933496807" ID="ID_30713901" MODIFIED="1557498707241" TEXT="Builder">
|
|
<node CREATED="1522934179425" ID="ID_1599594477" MODIFIED="1557498707241" TEXT="keine Ahnung was der machen soll">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933500430" ID="ID_1555205420" MODIFIED="1557498707241" TEXT="Player">
|
|
<node CREATED="1522934197478" ID="ID_237029868" MODIFIED="1557498707241" TEXT="wartet auf Scheduler">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933505078" ID="ID_1376308250" MODIFIED="1557498707241" TEXT="Engine">
|
|
<node CREATED="1522934210324" ID="ID_254801901" MODIFIED="1557498707241" TEXT="wartet auf Fixture/Backbone">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664058018889" HGAP="70" ID="ID_1933523990" MODIFIED="1664058038958" TEXT="Leit-Aufgaben" VSHIFT="13">
|
|
<font NAME="SansSerif" SIZE="14"/>
|
|
<node CREATED="1664058052677" ID="ID_671587918" MODIFIED="1664058055024" TEXT="aktiv">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1664059317203" ID="ID_995858352" MODIFIED="1679784026877" TEXT="#1221 Playback Vertical Slice">
|
|
<icon BUILTIN="back"/>
|
|
<node BACKGROUND_COLOR="#fefc4e" COLOR="#351d75" CREATED="1679082378934" HGAP="90" ID="ID_1513396947" MODIFIED="1679082411019" TEXT="hier spielt die Musik" VSHIFT="-28">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="knotify"/>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_596408518" MODIFIED="1679084719279" STYLE="bubble" TEXT="ElementBox-Content-Renderer">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_1938112956" ENDARROW="Default" ENDINCLINATION="-1219;85;" ID="Arrow_ID_1826503668" STARTARROW="None" STARTINCLINATION="-2360;-214;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_1435039515" MODIFIED="1680567145813" STYLE="bubble" TEXT="GUI: Video Viewer">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_7752918" ENDARROW="Default" ENDINCLINATION="-612;79;" ID="Arrow_ID_1986887171" STARTARROW="None" STARTINCLINATION="-2008;-180;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_1704865245" MODIFIED="1680565151548" STYLE="bubble" TEXT="Fixture-Backbone">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_1180632123" ENDARROW="Default" ENDINCLINATION="-985;-61;" ID="Arrow_ID_1052251062" STARTARROW="None" STARTINCLINATION="-2243;270;"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e2ce95" COLOR="#ec6b17" CREATED="1654441361325" ID="ID_59027079" MODIFIED="1680565125463" STYLE="bubble" TEXT="Scheduler">
|
|
<arrowlink COLOR="#f6e1c2" DESTINATION="ID_1657236591" ENDARROW="Default" ENDINCLINATION="-1219;85;" ID="Arrow_ID_49470357" STARTARROW="None" STARTINCLINATION="-2189;368;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1679783158745" HGAP="36" ID="ID_25937632" MODIFIED="1679783197261" TEXT="Definition" VSHIFT="11">
|
|
<icon BUILTIN="pencil"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1679783214377" ID="ID_749983123" MODIFIED="1679783224010" TEXT="Leitbild">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1679783225727" ID="ID_539130765" MODIFIED="1679783303320" TEXT="die Engine läuft und liefert"/>
|
|
<node CREATED="1679783250652" ID="ID_1689653343" MODIFIED="1679783285911" TEXT="Laufende Wiedergabe im GUI"/>
|
|
<node CREATED="1679783329217" ID="ID_435773138" MODIFIED="1679783336173" TEXT="Interaktivität: Start/Stop"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#a31e84" CREATED="1679783338080" ID="ID_413822351" MODIFIED="1679783359057" TEXT="nicht eingeschlossen">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1679783372811" ID="ID_176708253" MODIFIED="1679783377199" TEXT="beliebige Medien"/>
|
|
<node CREATED="1679783377787" ID="ID_409466607" MODIFIED="1679783383022" TEXT="Effekt-Berechnung"/>
|
|
<node CREATED="1679783460711" ID="ID_829148645" MODIFIED="1679783508686" TEXT="spezielle Wiedergabe-Modi">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
kein Vorwärts/Rückwärts spulen, kein Springen, kein Looping, keine variable Geschwindigkeit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679783404111" ID="ID_683032118" MODIFIED="1679783410154" TEXT="Editieren der Session"/>
|
|
<node CREATED="1679783416477" ID="ID_42041000" MODIFIED="1679783430320" TEXT="keinerlei Persistenz"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679783620138" HGAP="84" ID="ID_670198616" MODIFIED="1679924451225" TEXT="Themen" VSHIFT="4">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1679783781677" ID="ID_1639721271" MODIFIED="1679783785761" TEXT="Video-Widergabe"/>
|
|
<node CREATED="1679783808329" ID="ID_1106262034" MODIFIED="1679783853111" TEXT="Timings und Zeitmaße"/>
|
|
<node CREATED="1679783813232" ID="ID_1304310724" MODIFIED="1679783838969" TEXT="asynchrone Steuerung"/>
|
|
<node CREATED="1679784101725" ID="ID_460682594" MODIFIED="1679784117473" TEXT="Komponenten-Verdrahtung"/>
|
|
<node CREATED="1679783876975" ID="ID_925510369" MODIFIED="1679783885196" TEXT="iterativ-rekursive Planung"/>
|
|
<node CREATED="1679783903431" ID="ID_1108872846" MODIFIED="1679783909684" TEXT="Processing-Pipeline"/>
|
|
<node CREATED="1679783913523" ID="ID_547371323" MODIFIED="1679783916474" TEXT="Buffer-Handling"/>
|
|
<node CREATED="1679869882217" ID="ID_174091758" MODIFIED="1679869884609" TEXT="Scheduling"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679783728675" HGAP="44" ID="ID_1018746279" MODIFIED="1679924444960" TEXT="Probleme" VSHIFT="-2">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1679784197692" ID="ID_985663123" MODIFIED="1679784238682" TEXT="Abgrenzung: Event ↔ Command ↔ Signal">
|
|
<node CREATED="1679924510213" ID="ID_1130144074" MODIFIED="1679924512729" TEXT="Fragen">
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1679924515877" ID="ID_1035252569" MODIFIED="1679924552673" TEXT="Was ist kein Event?">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1679924571653" ID="ID_372899682" MODIFIED="1679924593451" TEXT="sind direkte Signale sinnvoll/nachteilig?">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f0d5c5" COLOR="#990033" CREATED="1679924622686" ID="ID_305707096" MODIFIED="1679924634055" TEXT="Rolle des persistenten UI-State? ">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679787873721" ID="ID_1605476827" MODIFIED="1679787888964" TEXT="Konzept der »ViewConnection« klären">
|
|
<node CREATED="1679925014948" ID="ID_456112267" MODIFIED="1679925034602" TEXT="Bezüge">
|
|
<icon BUILTIN="info"/>
|
|
<node CREATED="1679925037278" ID="ID_905293925" MODIFIED="1679963467821" TEXT="es gibt einen alten Entwurf ~2011"/>
|
|
<node CREATED="1679925063849" ID="ID_1319708934" MODIFIED="1679925074861" TEXT="hängt stark mit dem OutputManagement zusammen"/>
|
|
<node CREATED="1679925075665" ID="ID_559486706" MODIFIED="1679925094037">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
involviert Problem des <i>Output Network</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1679925104405" ID="ID_1189292722" MODIFIED="1679925111124" TEXT="wird als persistent verstanden"/>
|
|
<node CREATED="1679925122459" ID="ID_1652087608" MODIFIED="1679925135682" TEXT="Abgrenzung zum UI-State notwendig">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1679963672551" ID="ID_1017171402" MODIFIED="1679963682838" TEXT="Verhältnis zur Timeline zu klären">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1679963688093" ID="ID_173898614" MODIFIED="1679963694758" TEXT="fest steht">
|
|
<node CREATED="1679963695915" ID="ID_1244552807" MODIFIED="1679963703686" TEXT="die Timeline ist selber nur eine Facade"/>
|
|
<node CREATED="1679963704322" ID="ID_1295833791" MODIFIED="1679963710038" TEXT="dahinter steht ein Binding"/>
|
|
<node CREATED="1679963710674" ID="ID_793156306" MODIFIED="1679963727259" TEXT="es stellt die Verbindung her zu Globalen Pipes"/>
|
|
<node CREATED="1679963736854" ID="ID_1450985814" MODIFIED="1679963770909" TEXT="aber eine ViewConnection ist essentiell das Gleiche">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nur eben dahinter geschaltet, und flexibler
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679925023776" ID="ID_1511633470" MODIFIED="1679925030816" TEXT="Konzept">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1679963537217" ID="ID_817658978" MODIFIED="1679963543971" TEXT="beteiligte Entitäten"/>
|
|
<node CREATED="1679963562358" ID="ID_1884557779" MODIFIED="1679963566721" TEXT="Eigenschaften"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679788319094" ID="ID_1132613527" MODIFIED="1679788340040" TEXT="wo kann die Fixture geFAKEd werden?">
|
|
<node CREATED="1679924699883" ID="ID_769718712" MODIFIED="1679924704744" TEXT="Wechselwirkungen">
|
|
<node CREATED="1679924721585" ID="ID_218030921" MODIFIED="1679924760967" TEXT="braucht Setup-Operatoin im Player"/>
|
|
<node CREATED="1679924766987" ID="ID_549141712" MODIFIED="1679924776557" TEXT="kann Weiterentwicklung behindern"/>
|
|
<node CREATED="1679924804534" ID="ID_412706766" MODIFIED="1679924817096" TEXT="Fixture muß tatsächlich nutzbar sein"/>
|
|
<node CREATED="1679924820196" ID="ID_1070429445" MODIFIED="1679924930483" TEXT="braucht (ggfs) minimale Steuerbarkeit durch das UI">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
zumindest die Clip-ID muß irgendwie auf high-level-Ebene repräsentiert werden
|
|
</li>
|
|
<li>
|
|
<i>sofern die Timeline involviert ist:<b> </b></i>es könnte Änderungen der Start/Stopzeit geben
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1679924931277" ID="ID_488176513" MODIFIED="1679924942537">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Entscheidung: im <b>Builder</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1679924946698" ID="ID_39408058" MODIFIED="1679924960325" TEXT="dort eine magische Abzweigung schaffen"/>
|
|
<node CREATED="1679924961345" ID="ID_1283747458" MODIFIED="1679924988809" TEXT="kann damit ersten Entwurf der Fixture-Konstruktion implementieren"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679924399181" ID="ID_1247355489" MODIFIED="1679924407085" TEXT="minimale high-level-Repräsentation">
|
|
<node CREATED="1679945280469" ID="ID_1179888739" MODIFIED="1679945299793" TEXT="Problematik: high-level-Modell ist noch unreif">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1679945481691" ID="ID_1023272842" MODIFIED="1679945493995" TEXT="Repräsentation von Assets?"/>
|
|
<node CREATED="1679945449876" ID="ID_159098137" MODIFIED="1679945458718" TEXT="ID-Management ungeklärt"/>
|
|
</node>
|
|
<node CREATED="1679924423491" ID="ID_1610214036" MODIFIED="1679924428565" TEXT="Datenquelle für die Frames">
|
|
<node CREATED="1679925151984" ID="ID_1439861274" MODIFIED="1679925153595" TEXT="Belange">
|
|
<node CREATED="1679925154520" ID="ID_1163621279" MODIFIED="1679925180679" TEXT="bedingt Abhängigkeit auf Medien-Library"/>
|
|
<node CREATED="1679925181243" ID="ID_8108243" MODIFIED="1679925197333" TEXT="involviert das Plugin-System (unreif)"/>
|
|
<node CREATED="1679925213967" ID="ID_1795291263" MODIFIED="1679925224985" TEXT="Stream-Type-Repräsentation"/>
|
|
<node CREATED="1679925236433" ID="ID_315993169" MODIFIED="1679925251724" TEXT="Auslieferung (Storage)">
|
|
<node CREATED="1679925263816" ID="ID_757916379" MODIFIED="1679925275741" TEXT="Keine Mediendaten im Git"/>
|
|
<node CREATED="1679925276494" ID="ID_133458520" MODIFIED="1679925290712" TEXT="benötigt zusätzliche Infrastruktur"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679925300587" ID="ID_415001259" MODIFIED="1679925303534" TEXT="Lösungen">
|
|
<node CREATED="1679925304930" ID="ID_57552007" MODIFIED="1679925377305" TEXT="FFMpeg vorläufig integrieren">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1679925323303" ID="ID_510463166" MODIFIED="1679925379903" TEXT="RGB8-Raw-Video verwenden">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
<node CREATED="1679925355633" ID="ID_1778236782" MODIFIED="1679925382868" TEXT="Video-Generator implementieren">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1680396222047" ID="ID_1641749969" MODIFIED="1680396278980">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p style="text-align: center">
|
|
Baum-Monaden-Framework für Job-Planung<br /><font size="4" color="#cc1342">fragwürdiges Design</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1680396285443" ID="ID_285930244" MODIFIED="1680396457815" TEXT="der Code ist (selbst für mich) nahezu unverständlich">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habe das wohl schon damals gemerkt... der Quelltext ist voller "entschuldigender Kommentare"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-angry"/>
|
|
</node>
|
|
<node CREATED="1680396300209" ID="ID_1838580113" MODIFIED="1680396410375" TEXT="das bestätigt alle meine Zweifel am Monaden-Konzept aus der funktionalen Programmierung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das primäre Problem ist hier nicht C++, oder eine ungeschickte Implementierung meinerseits, sondern das brennende Problem ist, daß die Monaden-Struktur nichts zum Verständnis der Verwendung beiträgt, sondern diese durch eine <i>rein-mathematische</i> Symmetrie <b>verstellt und verschleiert</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1680396464104" ID="ID_216719314" MODIFIED="1680396585105" TEXT="Beschluß: weg damit">
|
|
<arrowlink COLOR="#963345" DESTINATION="ID_1805461369" ENDARROW="Default" ENDINCLINATION="367;0;" ID="Arrow_ID_271837208" STARTARROW="None" STARTINCLINATION="175;160;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680396470946" ID="ID_970682100" MODIFIED="1680396490033" TEXT="Aufgabe: noch ein letztes Mal verstehen, was das sollte">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680396490895" ID="ID_1991292419" MODIFIED="1680396509638" TEXT="Umbauen auf das Pipeline / TreeExplorer-Framework">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1680396521021" ID="ID_1520286749" MODIFIED="1680396527735" TEXT="das hat sich inzwischen viel besser bewährt"/>
|
|
<node CREATED="1680396528171" ID="ID_1369183009" MODIFIED="1680396546921">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und bietet monadische-Expansion als <i>Spezialfall</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1679783751608" ID="ID_1207767119" MODIFIED="1679924460221" TEXT="Struktur">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1679788541561" ID="ID_246646204" MODIFIED="1679788547296" TEXT="Setup im GUI bereitstellen"/>
|
|
<node CREATED="1679784183070" ID="ID_392713581" MODIFIED="1679784192104" TEXT="Player-Steuerung"/>
|
|
<node CREATED="1679788559094" ID="ID_1138489245" MODIFIED="1679788569544" TEXT="Play-Process erzeugen"/>
|
|
<node CREATED="1679788574372" ID="ID_1504364531" MODIFIED="1679788584308" TEXT="Dispatcher fertigstellen"/>
|
|
<node CREATED="1679788589727" ID="ID_1461146166" MODIFIED="1679788603056" TEXT="Scheduler">
|
|
<node CREATED="1679788604226" ID="ID_671337380" MODIFIED="1679788608411" TEXT="Basis-Implementierung"/>
|
|
<node CREATED="1679788608984" ID="ID_1995627934" MODIFIED="1679788618138" TEXT="Grundlagen Dependency-Management"/>
|
|
</node>
|
|
<node CREATED="1679788636636" ID="ID_1242125154" MODIFIED="1679788644742" TEXT="Technologie: Video-Ausgabe im GUI"/>
|
|
<node CREATED="1679788655473" ID="ID_1037767417" MODIFIED="1679788661748" TEXT="running Time-display"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1679783177087" HGAP="29" ID="ID_1020455743" MODIFIED="1679783192799" TEXT="vorantreiben" VSHIFT="3">
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1679783641511" ID="ID_212214057" MODIFIED="1679783643195" TEXT="Tickets">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680141126520" ID="ID_1147697662" LINK="https://issues.lumiera.org/ticket/1273" MODIFIED="1680141154614" TEXT="#1273 Viewer-Connection Concept">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1680141166647" ID="ID_1634794257" MODIFIED="1680141390579" TEXT="Das Wiring-Konzept von 2015 ist in dieser Hinsicht noch nicht fertig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es ist zwar schon klar, daß ein separates Output-Network gebaut werden muß, um die generierten Frames für den konkreten Viewer in der GUI aufzubereiten. Aber es ist noch nicht wirklich geklärt, wie dieses in das generelle Design mit High-Level-Model, Builder und Low-Level-Model zu integrieren ist. Bisher hatte ich immer nur den Begriff "ViewConnection" verwendet (Siehe TiddlyWiki) und dazu festgehalten, daß es sich um ein »Binding« handeln soll. Unklar ist aber die genaue Verhältnisbestimmung zu dem Binding, das für Timeline und VirtualClip zum Tragen kommen wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680195770073" ID="ID_1611142501" LINK="https://issues.lumiera.org/ticket/1274" MODIFIED="1680219860901" TEXT="#1274 rigged setup for clip playback">
|
|
<linktarget COLOR="#5297c3" DESTINATION="ID_1611142501" ENDARROW="Default" ENDINCLINATION="51;3;" ID="Arrow_ID_1273706751" SOURCE="ID_1946005498" STARTARROW="None" STARTINCLINATION="62;-3;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680193604370" ID="ID_1946005498" LINK="https://issues.lumiera.org/ticket/1231" MODIFIED="1680219871020" TEXT="#1231 trigger clip playback on the GUI">
|
|
<arrowlink COLOR="#5297c3" DESTINATION="ID_1611142501" ENDARROW="Default" ENDINCLINATION="51;3;" ID="Arrow_ID_1273706751" STARTARROW="None" STARTINCLINATION="62;-3;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680193640309" ID="ID_1108084572" LINK="https://issues.lumiera.org/ticket/1232" MODIFIED="1680193652395" TEXT=" #1232 Process request for playback command in SteamDispatcher ">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680193667730" ID="ID_1957971901" LINK="https://issues.lumiera.org/ticket/1233" MODIFIED="1680193682441" TEXT="#1233 Activate playback mode on a Player instance ">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680193712051" ID="ID_409993593" LINK="https://issues.lumiera.org/ticket/1243" MODIFIED="1680222976872" TEXT="#1243 Build low-level model from high-level model (mocked) of a clip">
|
|
<linktarget COLOR="#5fa6c1" DESTINATION="ID_409993593" ENDARROW="Default" ENDINCLINATION="199;8;" ID="Arrow_ID_222915618" SOURCE="ID_699634936" STARTARROW="None" STARTINCLINATION="167;-10;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680195883938" ID="ID_699634936" LINK="https://issues.lumiera.org/ticket/1275" MODIFIED="1680562039055" TEXT="#1275 dispatch simple calculation stream">
|
|
<arrowlink COLOR="#5fa6c1" DESTINATION="ID_409993593" ENDARROW="Default" ENDINCLINATION="199;8;" ID="Arrow_ID_222915618" STARTARROW="None" STARTINCLINATION="167;-10;"/>
|
|
<arrowlink COLOR="#6a92a9" DESTINATION="ID_1805461369" ENDARROW="Default" ENDINCLINATION="190;-8;" ID="Arrow_ID_1209058185" STARTARROW="None" STARTINCLINATION="61;-2;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680305211903" ID="ID_1805461369" LINK="https://issues.lumiera.org/ticket/1276" MODIFIED="1681165797441" TEXT="#1276 reassess design of render job deadline planning">
|
|
<arrowlink COLOR="#f42f34" DESTINATION="ID_896127270" ENDARROW="Default" ENDINCLINATION="-1096;-80;" ID="Arrow_ID_1764912075" STARTARROW="None" STARTINCLINATION="-511;24;"/>
|
|
<linktarget COLOR="#963345" DESTINATION="ID_1805461369" ENDARROW="Default" ENDINCLINATION="367;0;" ID="Arrow_ID_271837208" SOURCE="ID_216719314" STARTARROW="None" STARTINCLINATION="175;160;"/>
|
|
<linktarget COLOR="#6a92a9" DESTINATION="ID_1805461369" ENDARROW="Default" ENDINCLINATION="190;-8;" ID="Arrow_ID_1209058185" SOURCE="ID_699634936" STARTARROW="None" STARTINCLINATION="61;-2;"/>
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680316647510" ID="ID_1793327086" LINK="https://issues.lumiera.org/ticket/1277" MODIFIED="1680316670021" TEXT="#1277 implement Timings descriptor for simple playback">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680316684910" ID="ID_908207982" MODIFIED="1680316774339" TEXT="woot: aus dem Code wird nicht ganz klar was ein Timings descriptor leistet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...dieser Monaden-Code ist undurchdringlich (selbst für micht, und ich kann mich noch gut daran erinnern, was er leisten soll)
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680195925069" ID="ID_1715377601" LINK="https://issues.lumiera.org/ticket/1278" MODIFIED="1680317916818" TEXT="#1278 Schedule simple sequence of render jobs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680380228657" ID="ID_14638704" LINK="https://issues.lumiera.org/ticket/1279" MODIFIED="1680382013522" TEXT="#1279 provide technology for worker threads">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680381903590" ID="ID_833824994" LINK="https://issues.lumiera.org/ticket/1280" MODIFIED="1680382032313" TEXT="#1280 build Scheduler implementation">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680383011232" ID="ID_1091550126" LINK="https://issues.lumiera.org/ticket/1281" MODIFIED="1680383105154" TEXT="#1281 build deadline-bound scheduler for worker pool">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680384502979" ID="ID_1328538589" LINK="https://issues.lumiera.org/ticket/1282" MODIFIED="1680384525394" TEXT="#1282 build dependency tracking and notification framework for jobs">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680387404540" ID="ID_1470255504" LINK="https://issues.lumiera.org/ticket/1283" MODIFIED="1680387428043" TEXT="#1283 draft observation of calculation times">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680389032371" ID="ID_663979640" LINK="https://issues.lumiera.org/ticket/1285" MODIFIED="1680389054385" TEXT="#1285 draft integration of asynchronous IO with rendering">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680388296693" ID="ID_283603911" LINK="https://issues.lumiera.org/ticket/1284" MODIFIED="1680388318115" TEXT="#1284 Render Engine operational control">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680389959705" ID="ID_1139462793" LINK="https://issues.lumiera.org/ticket/1286" MODIFIED="1680389986151" TEXT="#1286 Timing Observable">
|
|
<arrowlink COLOR="#a54e77" DESTINATION="ID_1046752034" ENDARROW="Default" ENDINCLINATION="-1519;212;" ID="Arrow_ID_1830118942" STARTARROW="None" STARTINCLINATION="836;79;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680196018888" ID="ID_874815999" LINK="https://issues.lumiera.org/ticket/1287" MODIFIED="1680391903482" TEXT="#1287 invoke simple render job">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1682810738487" ID="ID_48632766" MODIFIED="1682810875535" TEXT="#1295 draft job invocation parameter representation">
|
|
<arrowlink COLOR="#b22e63" DESTINATION="ID_1493396541" ENDARROW="Default" ENDINCLINATION="-1383;-51;" ID="Arrow_ID_847435526" STARTARROW="None" STARTINCLINATION="-753;40;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680196129567" ID="ID_988036389" LINK="https://issues.lumiera.org/ticket/1288" MODIFIED="1680392639594" TEXT="#1288 simple video display widget">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680394326847" ID="ID_1990423949" LINK="https://issues.lumiera.org/ticket/950" MODIFIED="1680394346975" TEXT="#950 GTK-3: Video display in the GUI">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680196149518" ID="ID_525567081" LINK="https://issues.lumiera.org/ticket/1289" MODIFIED="1680393497536" TEXT="#1289 output manager for GUI video display">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680196059211" ID="ID_672047126" LINK="https://issues.lumiera.org/ticket/1290" MODIFIED="1680394137011" TEXT="#1290 exchange buffers between GUI and Engine">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679783648215" ID="ID_1843221543" MODIFIED="1680561728507" TEXT="Diskussion/Entscheidungen">
|
|
<node CREATED="1680561739893" ID="ID_1277050322" MODIFIED="1680561744515" TEXT="Technologie">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680561745270" ID="ID_264248978" MODIFIED="1680561760037" TEXT="Video-Display-UI">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1680561751261" ID="ID_1799759884" MODIFIED="1680561760040" TEXT="Worker-Thradpool">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679783675979" ID="ID_312162112" MODIFIED="1679783688045" TEXT="neu bauen">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561793925" ID="ID_961883511" MODIFIED="1680567189685" TEXT="Video-Widget">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_1636806116" ENDARROW="Default" ENDINCLINATION="-757;117;" ID="Arrow_ID_820803219" STARTARROW="None" STARTINCLINATION="-239;41;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561798377" ID="ID_962521952" MODIFIED="1680567194869" TEXT="GUI-OutputManager">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_754563967" ENDARROW="Default" ENDINCLINATION="-691;58;" ID="Arrow_ID_1893379752" STARTARROW="None" STARTINCLINATION="-230;29;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561843520" ID="ID_51005656" MODIFIED="1680566910795" TEXT="Fixture">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_176106926" ENDARROW="Default" ENDINCLINATION="-584;114;" ID="Arrow_ID_1229368159" STARTARROW="None" STARTINCLINATION="-150;36;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561847832" ID="ID_988488968" MODIFIED="1680566930976" TEXT="Content/Generator">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_460039330" ENDARROW="Default" ENDINCLINATION="-632;68;" ID="Arrow_ID_1437229627" STARTARROW="None" STARTINCLINATION="-241;31;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561888985" ID="ID_1736473881" MODIFIED="1680563326133" TEXT="Scheduler">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561892270" ID="ID_12567096" MODIFIED="1680566937368" TEXT="Layer-1 : PriQueue">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_250843894" ENDARROW="Default" ENDINCLINATION="-644;84;" ID="Arrow_ID_1702721830" STARTARROW="None" STARTINCLINATION="-233;30;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680561901447" ID="ID_695181807" MODIFIED="1680566934008" TEXT="Layer-2 : Notification">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_1218283238" ENDARROW="Default" ENDINCLINATION="-664;74;" ID="Arrow_ID_443600884" STARTARROW="None" STARTINCLINATION="-240;29;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679783678682" ID="ID_136895805" MODIFIED="1679783681526" TEXT="integrieren">
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680562222631" ID="ID_1661673229" MODIFIED="1680563316834" TEXT="GUI ⟷ Player">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680562222631" ID="ID_573821275" MODIFIED="1680562222631" TEXT="Mock ⟷ Builder ‣‣ Fixture">
|
|
<arrowlink COLOR="#fec499" DESTINATION="ID_804147257" ENDARROW="Default" ENDINCLINATION="-696;77;" ID="Arrow_ID_521000760" STARTARROW="None" STARTINCLINATION="-206;21;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680562222631" ID="ID_1899779347" MODIFIED="1680563316835" TEXT="Node-Invocation ⟷ Generator">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1680562698618" ID="ID_722733788" MODIFIED="1680563316836" TEXT="Buffer-Management">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679783694673" ID="ID_455505067" MODIFIED="1679783698044" TEXT="dokumentieren"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#174f60" CREATED="1664058057316" FOLDED="true" ID="ID_1582660555" MODIFIED="1679362833655" TEXT="vergessen">
|
|
<icon BUILTIN="licq"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679088360136" ID="ID_602432496" LINK="#ID_613160281" MODIFIED="1679088563026" TEXT="relatives Positionieren auf die »Ruler« verallgemeinern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das ViewHook / CanvasHook-Konzept hat sich hervorragend bewährt, und durch das zoom-metric-Mix-in gibt es auch bereits eine sehr elaborierte und robuste Implementierung für alle Belange der temporalen Ausdehnung (horizontal). Allerdings funktionieren alle diese Basis-Implementierungen bisher nur für den <i>eigentlichen Content </i>in der Timeline — ganz einfach weil ich noch nicht so recht weiß, was es mit den »Rulern« so auf sich hat ....  ⌛
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664058236108" ID="ID_616634560" LINK="#ID_633007604" MODIFIED="1664058551602" TEXT="Design um den Display-Frame im Timeline-Layout">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Das Thema »Layout-Steuerung in der Timeline« lief aus dem Ruder (wie erwartet — warum soll's mir besser gehen, als Joel Holdsworth?). Ich habe dahinter aber ein Architektur-Problem identifiziert, nämlich daß hier eine selbs-ähnliche rekursive Struktur notwendig ist, welche aber mehrere separate Kontexte überspannt. Dafür habe ich die Entität <font face="Monospaced" size="3">DisplayFrame</font>  erfunden, und die Idee war, diesen als Kristallisationskern zu verwenden, um die gesamte Struktur um das Timeline-Layout zu reinigen. Leider konnte ich das aber (Stand 9/2022) nicht weiterführen, weil ich nun das GUI wieder verlassen muß, um an der RenderEngine weiterzuarbeiten...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664058723731" ID="ID_14178897" LINK="#ID_838803024" MODIFIED="1664058890277" TEXT="generisches Konzept zur Zoom/View-Steuerung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
....dieses Thema sollte generisch gelöst werden, und dann weiter entwickelt in Richtung »Interaction Design« — also mit einem aktuellen Fokus verbunden, und mit jeweils eigener Historie pro Fokus, so daß man in die verschiedenen Fokus-Zonen über gut etablierte "Leitern" wieder einsteigen könnte. Leider muß ich (Stand 9/2022) das GUI nun wieder verlassen, und es ist ganz und gar ungeklärt, unter welchen Umständen dieses zentrale Thema wieder aufgenommen werden kann...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1679086888811" ID="ID_1529439049" LINK="#ID_226245696" MODIFIED="1679087074074" TEXT="GUI-Start ist noch nicht ganz „sauber“">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Es gibt immer noch Zweifel ob gewisser Race-Conditions....
|
|
</p>
|
|
<p>
|
|
Diese hängen jedoch eng mit dem Design des Subsystem-Runners zusammen, welches zwar grundsätzlich in Ordnung ist, aber alles in allem „etwas zu knapp gehalten“: man sollte hier explizit und fein differenziert die Lebenszyklus-Phasen ausformulieren, denn dann ist man nicht mehr von Subtilitäten der Implementierungs-Reihenfolge abhängig
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664059040648" ID="ID_335528916" LINK="#ID_1734927969" MODIFIED="1664059164915" TEXT="GTK+GIO : Interna dokumentieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...beim Herauslösen aus dem Gnome-Application / GIO-Framework habe ich detailiert die Strukturen um die Main-Loop untersucht und verstanden. Leider stehen diese Infos bisher (Stand 9/2022) nur in meiner Mindmap; ich sollte eine eigene Kategorie in der Webseite/Dokumentation schaffen, in der solche Einsichten aufgezeichnet werden können...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664058062651" ID="ID_1510416990" MODIFIED="1664058067537" TEXT="abgschlossen">
|
|
<node CREATED="1679081386692" ID="ID_1835644126" MODIFIED="1679081423483" TEXT="GUI-Backbone gründen">
|
|
<arrowlink COLOR="#6278c0" DESTINATION="ID_1612113311" ENDARROW="Default" ENDINCLINATION="94;100;" ID="Arrow_ID_879038794" STARTARROW="None" STARTINCLINATION="-3;-77;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664630921300" FOLDED="true" HGAP="183" ID="ID_1033335255" MODIFIED="1681004514646" TEXT="Dokumentation" VSHIFT="40">
|
|
<edge COLOR="#815b70"/>
|
|
<cloud COLOR="#d7c3a8"/>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="list"/>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1664630997672" FOLDED="true" ID="ID_237099051" MODIFIED="1681004517180" STYLE="bubble" TEXT="mitführen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>Leitlinie</u>: so viel tun, daß uns das Thema nicht über den Kopf wächst
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1664631055889" ID="ID_1519064192" MODIFIED="1664631546287" STYLE="fork" TEXT="TiddlyWiki">
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1664631069343" ID="ID_905113359" LINK="file:///Lager/heim/devel/lumi/wiki/renderengine.html#GuiTopLevel%20GuiTimelineView%20TimelineDisplayManager%20TrackPresenter%20ClipPresenter%20GuiTimelineDraw%20GuiClipWidget%20GuiElementBoxWidget" MODIFIED="1664631546287" TEXT="Themenkomplex: GuiConnection">
|
|
<icon BUILTIN="pencil"/>
|
|
<node COLOR="#5b166e" CREATED="1611035931543" HGAP="77" ID="ID_936662203" MODIFIED="1664631233866" STYLE="bubble" TEXT="2022-10 aktiv" VSHIFT="-3">
|
|
<edge COLOR="#eb1854" STYLE="sharp_linear" WIDTH="2"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="11"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664631256231" ID="ID_967028256" MODIFIED="1664631546288" TEXT="Session: aktualisieren!">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier stammt die Darstellung im Wesentlichen aus den ersten Jahren, ist aber mit dem teilweisen Re-Design verflochten ⟹ verwirrende Mix aus überholten Ansichten und Konzepten für die <i>ferne Zukunft</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664631363943" ID="ID_879637950" MODIFIED="1664631546287" STYLE="fork" TEXT="Doxygen">
|
|
<node CREATED="1664631381728" ID="ID_479695439" MODIFIED="1664631546287" TEXT="Übersichten"/>
|
|
</node>
|
|
<node CREATED="1664631398891" ID="ID_1010017470" MODIFIED="1664631559120" STYLE="fork" TEXT="LumiDok">
|
|
<edge COLOR="#8e6074" STYLE="linear" WIDTH="thin"/>
|
|
<node CREATED="1664631418128" ID="ID_1118945815" MODIFIED="1664631559116" TEXT="Stand">
|
|
<node COLOR="#435e98" CREATED="1664632273717" ID="ID_546161915" MODIFIED="1681004578460" TEXT="10/22: master/online deutlich zurückgefallen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aber es gibt auch stellenweise Überarbeitungen (von Benny) auf der offizielen Linie
|
|
</p>
|
|
<p>
|
|
Im Zuge der laufenden Entwicklung wurden...
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Seiten umbenannt
|
|
</li>
|
|
<li>
|
|
neue Bereiche begonnen
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
<i><font color="#4a025e">alles dies ist noch nicht auf dem offiziellen "dok"-Branch und deshalb noch nicht publiziert! </font></i>
|
|
</p>
|
|
<p>
|
|
<font color="#b81d10" size="2">⟹ lokal/gui auschecken und Dok-Site auf localhost verwenden</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="11"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node COLOR="#338800" CREATED="1681004586743" ID="ID_1584303708" MODIFIED="1681006360117" TEXT="Merge 4.4.23 (automatisch)">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...ging völlig problemlos, und das Resultat/Changeset sieht plausibel aus...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1681006362667" ID="ID_1972975901" MODIFIED="1681006379321" TEXT="nochmal prüfen ob es Änderungen von Benny gab...?">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664632408539" ID="ID_5303509" MODIFIED="1664632540359" TEXT="Link-Generator notwendig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
das ist das größte Impediment, weshalb Informationen nicht aus dem TidlyWiki migrieren können
|
|
</li>
|
|
<li>
|
|
wir hatten das vor Jahren bereits besprochen, und Christian hat eine »Link-Farm« vorgeschlagen
|
|
</li>
|
|
<li>
|
|
Benny wollte sich darum kümmern, hat das aber<i>  vergessen/verdrängt</i>
|
|
</li>
|
|
<li>
|
|
ich selber könnte das in ca. 4 Tagen auf die Beine stellen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664631424771" ID="ID_30685930" MODIFIED="1664631559117" TEXT="User"/>
|
|
<node CREATED="1664631468424" ID="ID_206416201" MODIFIED="1664631559117" TEXT="Design"/>
|
|
<node CREATED="1664631471329" ID="ID_1395212182" MODIFIED="1664631559117" TEXT="Technical">
|
|
<node CREATED="1664631954289" ID="ID_20498937" MODIFIED="1664631956996" TEXT="GTK">
|
|
<node CREATED="1664631960544" ID="ID_366289631" MODIFIED="1664631964860" TEXT="Layout"/>
|
|
<node CREATED="1664631965465" ID="ID_417783849" LINK="http://localhost:8888/documentation/technical/stage/style/index.html" MODIFIED="1664658971571" TEXT="Styling">
|
|
<linktarget COLOR="#684e97" DESTINATION="ID_417783849" ENDARROW="Default" ENDINCLINATION="-182;50;" ID="Arrow_ID_321858822" SOURCE="ID_782976986" STARTARROW="None" STARTINCLINATION="143;23;"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664664177964" ID="ID_1856995238" LINK="http://localhost:8888/documentation/technical/stage/style/Navigation.html" MODIFIED="1664664211512" TEXT="Navigation">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#2f37ba" CREATED="1664664350429" ID="ID_24552371" MODIFIED="1664664420238" TEXT="(wartet auf Implementierung)">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#2f37ba" CREATED="1664664350429" ID="ID_1684238945" MODIFIED="1664664439785" TEXT="(und ausgearbeitetes Konzept)">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664664188674" ID="ID_1825141058" LINK="http://localhost:8888/documentation/technical/stage/style/PropEditor.html" MODIFIED="1664664220307" TEXT="Property Edit">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#2f37ba" CREATED="1664664350429" ID="ID_1138451370" MODIFIED="1664664381842" TEXT="(wartet auf Konzept)">
|
|
<font NAME="SansSerif" SIZE="10"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664664224732" ID="ID_1724606978" LINK="http://localhost:8888/documentation/technical/stage/style/Timeline.html" MODIFIED="1664664245948" TEXT="Timeline">
|
|
<icon BUILTIN="bell"/>
|
|
<node COLOR="#338800" CREATED="1664664261120" ID="ID_1963212373" MODIFIED="1679088751661" TEXT="synthetische Elemente dokumentieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1664664271055" ID="ID_1800483629" MODIFIED="1679088753286">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Beispiele zur Verwendung
|
|
</p>
|
|
<p>
|
|
der Styles dokumentieren
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#690f14" CREATED="1664664482451" ID="ID_1140150901" MODIFIED="1664664499990" TEXT="allgemein">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
<node CREATED="1664664505903" ID="ID_998661397" MODIFIED="1664664592880" TEXT="Info zu "binary Themes" woanders hin">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Diese Info hatte ich vor längerer Zeit mal "aufgegabelt" und sie wer der erste Content auf dieser Styling-Doku-Seite. Inzwischen hat sich der Scope verschoben, und sowas gehört ehr in die CodeBase-Sektion
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eef0c5" COLOR="#990000" CREATED="1664664649375" ID="ID_1486988234" MODIFIED="1664664658299" TEXT="Details zum ElementBoxWidget">
|
|
<icon BUILTIN="pencil"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664664602615" HGAP="51" ID="ID_1014621671" MODIFIED="1664664615430" TEXT="Code Base" VSHIFT="7"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1664631634178" ID="ID_679126801" MODIFIED="1664631636964" TEXT="Themen">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664631986708" ID="ID_1854898414" MODIFIED="1664632010768" TEXT="coding news">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1664632012297" ID="ID_241631213" MODIFIED="1664632016491" TEXT="Interaction Design"/>
|
|
<node CREATED="1664632040517" ID="ID_143213655" MODIFIED="1664632043864" TEXT="Interface Layout">
|
|
<node CREATED="1664632066418" ID="ID_782976986" MODIFIED="1664632244719" TEXT="style scheme">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TODO: dokumentieren, wie das Lumiera-Interface ausgelegt und angeordnet wird, bis hinab zu den Details der Widget-Anordnung, damit ein Außenstehender im Stande ist, am Styling mitzuarbeiten...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<arrowlink COLOR="#684e97" DESTINATION="ID_417783849" ENDARROW="Default" ENDINCLINATION="-182;50;" ID="Arrow_ID_321858822" STARTARROW="None" STARTINCLINATION="143;23;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681004448374" FOLDED="true" HGAP="14" ID="ID_1536537244" MODIFIED="1681004503408" TEXT="Theorie / allgemein" VSHIFT="5">
|
|
<edge COLOR="#5e537f"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1681004288570" ID="ID_641232618" MODIFIED="1681004362635">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Darstellung: <i>about Monads</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Dezember 2017 ausgearbeitet und im TiddlyWiki vergraben.
|
|
</p>
|
|
<p>
|
|
<i>bin baff... das hatte ich völlig vergessen</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933444542" ID="ID_1027224176" MODIFIED="1557498707241" TEXT="Themen">
|
|
<node CREATED="1522933640027" ID="ID_191198072" MODIFIED="1557498707241" TEXT="UI-Connection">
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1522933746716" ID="ID_504819861" MODIFIED="1557498707241" TEXT="Dummy-Connection">
|
|
<node COLOR="#338800" CREATED="1522933752939" FOLDED="true" ID="ID_58888775" MODIFIED="1561238386898" TEXT="DemoGuiRoundtrip">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522933935346" ID="ID_1197314745" MODIFIED="1557498707241" TEXT="Knopf sendet Signale"/>
|
|
<node CREATED="1522933947737" ID="ID_59789786" MODIFIED="1557498707241" TEXT="diese werden zu Commands"/>
|
|
<node CREATED="1522933955463" ID="ID_212135952" MODIFIED="1557498707241" TEXT="diese werden in Proc ausgeführt"/>
|
|
<node CREATED="1522933964302" ID="ID_504912590" MODIFIED="1557498707241" TEXT="und senden Meldungen zurück"/>
|
|
<node CREATED="1522933973965" ID="ID_34008801" MODIFIED="1561238382143" TEXT="...in das Benachrichtigungsfenster">
|
|
<arrowlink COLOR="#34a79a" DESTINATION="ID_463339540" ENDARROW="Default" ENDINCLINATION="355;0;" ID="Arrow_ID_636625875" STARTARROW="None" STARTINCLINATION="55;1;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1522933859797" FOLDED="true" ID="ID_1381384508" MODIFIED="1679081171785" TEXT="Dummy-Population">
|
|
<icon BUILTIN="pencil"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node COLOR="#338800" CREATED="1522933880242" ID="ID_1851602883" MODIFIED="1561238124538" TEXT="automatisch beim Start">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522933886401" ID="ID_1546164262" MODIFIED="1561238122259" TEXT="Pseudo-Session-Inhalte erfinden">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522933899951" ID="ID_1191671954" MODIFIED="1561238123293" TEXT="in das UI hochschieben">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1522933913837" FOLDED="true" ID="ID_1879142349" MODIFIED="1557498707241" TEXT="Ziel: man sieht was">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1561238128126" ID="ID_1016002524" MODIFIED="1679081150741" TEXT="wir arbeiten daran">
|
|
<arrowlink COLOR="#6971ce" DESTINATION="ID_567481580" ENDARROW="Default" ENDINCLINATION="450;38;" ID="Arrow_ID_1010232773" STARTARROW="None" STARTINCLINATION="124;16;"/>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1561238485225" ID="ID_1044507535" MODIFIED="1679081150741" TEXT="treibt die Entwicklung voran">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933624861" ID="ID_1008186406" MODIFIED="1557498707241" TEXT="Timeline-Widget">
|
|
<icon BUILTIN="full-2"/>
|
|
<node COLOR="#338800" CREATED="1661448478272" ID="ID_235141959" MODIFIED="1661448487541" TEXT="Track-Body-Anzeige">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1661448488695" ID="ID_974534798" MODIFIED="1679081188802" TEXT="Track-Head-Anzeige">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1661448495494" ID="ID_1252888028" MODIFIED="1679081190899" STYLE="fork" TEXT="brauche ElementBox-Widget">
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1679081210995" ID="ID_1146310558" MODIFIED="1679081218934" TEXT="Clip-Content-Anzeige">
|
|
<node CREATED="1679081221526" ID="ID_660855565" MODIFIED="1679081311771" TEXT="brauche Content-Renderer im ElementBoxWidget"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522933545616" ID="ID_193999125" MODIFIED="1557498707241" TEXT="Fixture">
|
|
<icon BUILTIN="full-3"/>
|
|
</node>
|
|
<node CREATED="1522933565157" ID="ID_651020600" MODIFIED="1557498707241" TEXT="Render-Jobs">
|
|
<icon BUILTIN="full-4"/>
|
|
</node>
|
|
<node CREATED="1522933604296" ID="ID_596148799" MODIFIED="1557498707241" TEXT="Node-Invocation">
|
|
<icon BUILTIN="full-5"/>
|
|
</node>
|
|
<node CREATED="1522933577884" ID="ID_1298252635" MODIFIED="1557498707241" TEXT="Frame-Dispatch">
|
|
<icon BUILTIN="full-6"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439176872457" HGAP="15" ID="ID_355008543" MODIFIED="1557498707241" POSITION="left" TEXT="Plattform" VSHIFT="41">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1561736857971" ID="ID_662811521" MODIFIED="1561736871424" TEXT="Dependencies">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561736649007" FOLDED="true" ID="ID_1295139073" MODIFIED="1583523610926" TEXT="GTK in Debian">
|
|
<linktarget COLOR="#355ad5" DESTINATION="ID_1295139073" ENDARROW="Default" ENDINCLINATION="-816;0;" ID="Arrow_ID_1376879556" SOURCE="ID_1920301340" STARTARROW="None" STARTINCLINATION="-753;0;"/>
|
|
<icon BUILTIN="info"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1561733634234" ID="ID_283837231" MODIFIED="1561734827667" TEXT="libcairomm-1.0-dev">
|
|
<node CREATED="1561734539908" ID="ID_1171069121" MODIFIED="1561734577386" TEXT="Stretch(stable): 1.12.0-1+b1"/>
|
|
<node CREATED="1561734579119" ID="ID_261683999" MODIFIED="1561734596480" TEXT="Buster(testing): 1.12.2-4"/>
|
|
<node CREATED="1561734793676" ID="ID_124869066" MODIFIED="1561734804673" TEXT="Abhängigkeiten identisch: libcairo2-dev (>= 1.10.0), libsigc++-2.0-dev (>= 2.5.1)"/>
|
|
</node>
|
|
<node CREATED="1561734821281" ID="ID_1548932504" MODIFIED="1561734822892" TEXT="libcairo2-dev">
|
|
<node CREATED="1561736106556" ID="ID_447781913" MODIFIED="1561736112145" TEXT="Stretch(stable): 1.14.8-1"/>
|
|
<node CREATED="1561736119157" ID="ID_223457676" MODIFIED="1561736124491" TEXT="Buster(testing): 1.16.0-4"/>
|
|
</node>
|
|
<node CREATED="1561736244241" ID="ID_21972769" MODIFIED="1561736247507" TEXT="libgtkmm-3.0-dev">
|
|
<node CREATED="1561736106556" ID="ID_1654459671" MODIFIED="1561736267242" TEXT="Stretch(stable): 3.22.0-1"/>
|
|
<node CREATED="1561736119157" ID="ID_302515222" MODIFIED="1561736292712" TEXT="Buster(testing): 3.24.0-2"/>
|
|
<node CREATED="1561736364329" ID="ID_604772455" MODIFIED="1561736371506" TEXT="Abhängigkeiten nahezu identisch">
|
|
<node CREATED="1561736372871" ID="ID_1255591782" MODIFIED="1561736389392" TEXT="GTK: libgtk-3-dev (>= 3.22.0)"/>
|
|
<node CREATED="1561736412505" ID="ID_1655385358" MODIFIED="1561736418460" TEXT="GLib">
|
|
<node CREATED="1561736494237" ID="ID_932039111" MODIFIED="1561736613896" TEXT="libglibmm-2.4-dev (>= 2.54.0) -- Buster: 2.58.0-2"/>
|
|
<node CREATED="1561736533682" ID="ID_1029564694" MODIFIED="1561736602657" TEXT="libglibmm-2.4-dev (>= 2.49.1) -- Stretch: 2.50.0-1"/>
|
|
</node>
|
|
<node CREATED="1561736419592" ID="ID_1821608630" MODIFIED="1561736436441" TEXT="Cairo: libcairomm-1.0-dev (>= 1.12.0)"/>
|
|
<node CREATED="1561736440629" ID="ID_851030197" MODIFIED="1561736454086" TEXT="Pango: libpangomm-1.4-dev (>= 2.38.2)"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561736766454" ID="ID_1746397592" MODIFIED="1561736768899" TEXT="libgtk-3-dev">
|
|
<node CREATED="1561736106556" ID="ID_957399714" MODIFIED="1561736786976" TEXT="Stretch(stable): 3.22.11-1"/>
|
|
<node CREATED="1561736119157" ID="ID_1252132002" MODIFIED="1561736803582" TEXT="Buster(testing): 3.24.5-1"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583523613062" ID="ID_601841679" MODIFIED="1583523726831" TEXT="für Debian/Buster prüfen und aktualisieren">
|
|
<linktarget COLOR="#c35b60" DESTINATION="ID_601841679" ENDARROW="Default" ENDINCLINATION="53;0;" ID="Arrow_ID_198244235" SOURCE="ID_1032664307" STARTARROW="None" STARTINCLINATION="53;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1583523694636" HGAP="56" ID="ID_446319704" MODIFIED="1583523704860" TEXT="Build-Umgabung" VSHIFT="6">
|
|
<node COLOR="#338800" CREATED="1583523705722" ID="ID_1278670650" MODIFIED="1583523709609" TEXT="Eclipse-Projekt">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1583523710795" ID="ID_1032664307" MODIFIED="1583523732513" TEXT="wichtige Abhängigkeiten im Quellcode">
|
|
<arrowlink COLOR="#c35b60" DESTINATION="ID_601841679" ENDARROW="Default" ENDINCLINATION="53;0;" ID="Arrow_ID_198244235" STARTARROW="None" STARTINCLINATION="53;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439176875682" HGAP="47" ID="ID_1487331591" MODIFIED="1582315396874" TEXT="Referenzplattform" VSHIFT="60">
|
|
<icon BUILTIN="prepare"/>
|
|
<node COLOR="#435e98" CREATED="1439176875682" FOLDED="true" ID="ID_263510975" MODIFIED="1581813331909" TEXT="Debian/Jessie">
|
|
<edge COLOR="#648f70" STYLE="linear"/>
|
|
<icon BUILTIN="licq"/>
|
|
<node CREATED="1439176890840" FOLDED="true" ID="ID_99751679" MODIFIED="1561237091609" TEXT="Probleme">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439176900293" ID="ID_972499182" MODIFIED="1557498707241" TEXT="Linker rpath $ORIGIN">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439593020264" ID="ID_1565713533" LINK="https://sourceware.org/bugzilla/show_bug.cgi?id=16936" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bekannter Bug <b>binutils</b> <font color="#c72011">#16936</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439593578558" ID="ID_808711591" LINK="http://issues.lumiera.org/ticket/965" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Lumiera-Ticket <font color="#90011d">#965</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439593646645" ID="ID_633732119" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
gelöst in <font color="#4c1383">4e8e63ebe</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...man "hilft" dem Linker mit
|
|
</p>
|
|
<p style="margin-top: 0px; margin-bottom: 0px; margin-left: 0px; margin-right: 0px; text-indent: 0px">
|
|
"-Wl,-rpath-link=target/modules"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1439176912636" ID="ID_1261107088" MODIFIED="1561237078734" TEXT="failed tests">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
laufen wieder alle
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439176982698" HGAP="59" ID="ID_1313800263" MODIFIED="1557498707241" TEXT="Beobachtung: Meldungen im journal" VSHIFT="2"/>
|
|
<node CREATED="1439176948063" HGAP="54" ID="ID_885669922" MODIFIED="1557498707241" TEXT="5 Thread/Parallel" VSHIFT="1">
|
|
<node CREATED="1439566266701" ID="ID_525193086" MODIFIED="1557498707241" TEXT="hängt mit ulimit zusammen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1439566274091" ID="ID_589175513" MODIFIED="1557498707241" TEXT="ohne ulimit gehts">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
test.sh Zeile 138
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439566868460" ID="ID_1483801405" MODIFIED="1557498707241" TEXT="Untersuchung">
|
|
<node CREATED="1439566872203" ID="ID_1412884783" MODIFIED="1557498707241" TEXT="ulimit -T funktioniert nicht">
|
|
<node CREATED="1439566882418" ID="ID_267430691" MODIFIED="1557498707241" TEXT="bekanntes Problem"/>
|
|
<node CREATED="1439566886513" ID="ID_439373884" LINK="https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=724461" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Debian-Bug <font color="#9b0226">#724461</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439588367804" ID="ID_369587621" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nebenbei <i>ohweh:</i>
|
|
</p>
|
|
<p>
|
|
ulimit -t 1 ist wirkungslos
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1439592731687" ID="ID_404027904" MODIFIED="1557498707241">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Christian:  bash -c "ulimit -t 1; while :; do :; done"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439592774041" ID="ID_1425557829" MODIFIED="1557498707242" TEXT="ist reine CPU-Zeit">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und wir verbringen unsere Zeit mit contention
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439176927657" ID="ID_145666096" MODIFIED="1557498707242" TEXT="EntryID">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ist klar, hab ich gebrochen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439608908133" ID="ID_1142031172" MODIFIED="1557498707242" TEXT="Problem mit der Hash-Funktion"/>
|
|
<node CREATED="1439609043316" ID="ID_523440203" MODIFIED="1557498707242" TEXT="hatte ich schon mal untersucht"/>
|
|
<node CREATED="1439608917061" ID="ID_1747491586" LINK="http://issues.lumiera.org/ticket/587" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
siehe Ticket <font color="#991130">#587</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439609055443" ID="ID_794021326" MODIFIED="1557498707242" TEXT="Problem hat sich verschärft">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Kollisionen jetzt bereits nach 4000 lfd. Nummern
|
|
</p>
|
|
<p>
|
|
Vorher hatte ich erste Kollisionen nach 25000 Nummern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439609098853" ID="ID_1375367812" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
erinnere mich an den
|
|
</p>
|
|
<p>
|
|
guten alten "Knuth-Trick"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439609127137" ID="ID_46539031" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wow: es genügt,
|
|
</p>
|
|
<p>
|
|
die letzten beiden Zeichen mit der Knuth-Konstante zu spreizen,
|
|
</p>
|
|
<p>
|
|
und ich komme locker auf 100000 Nummern ohne Kollision
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1439176963604" ID="ID_1448738464" MODIFIED="1561237061397" TEXT="test-lib nicht zu debuggern">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439177141197" FOLDED="true" ID="ID_1753441069" MODIFIED="1561237041546" TEXT="Segfault in GDB">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aug 10 04:51:39 flaucher kernel: gdb[8234]: segfault at 7ffe3fa79f50 ip 0000000000718b95 sp 00007ffe3fa79f40 error 6 in gdb[400000+574000]
|
|
</p>
|
|
<p>
|
|
Aug 10 04:51:39 flaucher kernel: traps: test-suite[8249] trap int3 ip:7ffff7deb241 sp:7fffffffe5c8 error:0
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439477348298" ID="ID_1127859836" MODIFIED="1557498707242" TEXT="heruntergedampft auf einen Aufruf">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1439491824537" ID="ID_822305366" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
function gebunden an ein lambda
|
|
</p>
|
|
<p>
|
|
wobei ein Argument-Typ als vom Template-Argument
|
|
</p>
|
|
<p>
|
|
der umschließenden Funktion aufgegriffen wird
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1439492258423" ID="ID_1184070545" MODIFIED="1557498707242" TEXT="Plan">
|
|
<node CREATED="1439492266470" ID="ID_343206049" MODIFIED="1557498707242" TEXT="reproduzieren auf einer sauberen VM">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1439492277444" ID="ID_351705498" LINK="http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=795445" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Bugreport für Debian/Jessie <font color="#e02f0a">#795445</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439492285635" ID="ID_1216081677" MODIFIED="1557498707242" TEXT="gdb-Version untersuchen">
|
|
<node CREATED="1439516472396" ID="ID_1130713450" MODIFIED="1557498707242" TEXT="backports">
|
|
<node CREATED="1439516512684" ID="ID_1963171277" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Git: debBild/<b>Gdb_DEB.git</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1439516477008" ID="ID_956982844" MODIFIED="1557498707242" TEXT="Ver 7.8.2">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1439516495534" ID="ID_228349393" MODIFIED="1557498707242" TEXT="Bau-Abhängigkeiten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bison dejagnu flex gobjc libncurses5-dev libreadline-dev liblzma-dev libbabeltrace-dev libbabeltrace-ctf-dev python3-dev
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node CREATED="1439519150614" ID="ID_690017930" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<i>dutzende</i> Tests scheitern
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1439519171155" ID="ID_1728409463" MODIFIED="1557498707242" TEXT="das scheint nicht ungewöhnlich zu sein">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
verräterrischer Code im debian/rules
|
|
</p>
|
|
<p>
|
|
check-stamp:
|
|
</p>
|
|
<p>
|
|
ifeq ($(run_tests),yes)
|
|
</p>
|
|
<p>
|
|
        $(MAKE) $(NJOBS) -C $(DEB_BUILDDIR)/gdb check \
|
|
</p>
|
|
<p>
|
|
          || echo "**Tests failed, of course.**"
|
|
</p>
|
|
<p>
|
|
endif
|
|
</p>
|
|
<p>
|
|
        touch $@
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<b>au weia</b> LEUTE!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#f7f2b7" CREATED="1439521655505" ID="ID_388085317" MODIFIED="1561237018921" TEXT="funktioniert, kein Segfault mehr">
|
|
<linktarget COLOR="#64c53d" DESTINATION="ID_388085317" ENDARROW="Default" ENDINCLINATION="-80;156;" ID="Arrow_ID_173819250" SOURCE="ID_569521888" STARTARROW="None" STARTINCLINATION="404;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439492295754" ID="ID_1511393529" MODIFIED="1557498707242" TEXT="ggfs. upstream reporten"/>
|
|
<node CREATED="1439492301698" ID="ID_717647683" MODIFIED="1557498707242" TEXT="workaround">
|
|
<node CREATED="1439492309920" ID="ID_1813059120" MODIFIED="1557498707242" TEXT="andere gdb-version">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1439492315080" ID="ID_334485884" MODIFIED="1557498707242" TEXT="clang verwenden">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561237001239" ID="ID_569521888" MODIFIED="1561237037464" TEXT="gelöst mit gdb >= 7.8.2">
|
|
<arrowlink COLOR="#64c53d" DESTINATION="ID_388085317" ENDARROW="Default" ENDINCLINATION="-80;156;" ID="Arrow_ID_173819250" STARTARROW="None" STARTINCLINATION="404;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439177191998" ID="ID_1918895194" MODIFIED="1557498707242" TEXT="Syslog nicht mehr STDOUT">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439655684119" ID="ID_852404111" MODIFIED="1557498707242" TEXT="Warnungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
speziell: unused-function bei dem Trick mit dem std::hash macht mir Sorgen.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
und tatsächlich: das <i>ist</i> daneben, GCC hat Recht!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1439644339480" ID="ID_954549190" MODIFIED="1557498707242" TEXT="Lumiera DEB">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aktualisieren und neu bauen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1439644368572" ID="ID_107825553" MODIFIED="1557498707242" TEXT="Doku: Referenz-System">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1439176875682" ID="ID_1546966992" MODIFIED="1582315392127" TEXT="Debian/Buster">
|
|
<edge COLOR="#956a6a" STYLE="linear"/>
|
|
<icon BUILTIN="pencil"/>
|
|
<node CREATED="1581813838219" ID="ID_292810279" MODIFIED="1581813843787" TEXT="Aufgaben">
|
|
<node COLOR="#338800" CREATED="1581813846914" ID="ID_1924268278" MODIFIED="1582315382771" TEXT="C++17">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439176890840" ID="ID_1573907176" MODIFIED="1581813253348" TEXT="Probleme"/>
|
|
<node CREATED="1439655684119" ID="ID_448576273" MODIFIED="1581813253348" TEXT="Warnungen">
|
|
<node COLOR="#338800" CREATED="1581813910737" FOLDED="true" ID="ID_760008259" MODIFIED="1581815088793" TEXT="invalid function signature">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1581813924247" ID="ID_1396033299" MODIFIED="1581813932477" TEXT="in Christians MUTEX-Macros"/>
|
|
<node CREATED="1581814268376" ID="ID_1146072064" MODIFIED="1581814285793" TEXT="lumiera_sectionlock_unlock_fn hat Rückgabetyp int"/>
|
|
<node CREATED="1581814286382" ID="ID_1070334895" MODIFIED="1581814362629" TEXT="überflüssig...">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1581814293205" ID="ID_1473686899" MODIFIED="1581814302847" TEXT="wird nur in den magischen MACROS genutzt"/>
|
|
<node CREATED="1581814303324" ID="ID_947550011" MODIFIED="1581814323655" TEXT="dort KANN man gar nichts mit einem Fehler-Wert machen"/>
|
|
<node CREATED="1581814324097" ID="ID_1238690607" MODIFIED="1581814359836" TEXT="alle real existierenden Implementierungen: LUMIERA_DIE (LOCK_RELEASE);">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581814366704" ID="ID_68752359" MODIFIED="1581814371078" TEXT="gefährlich...">
|
|
<node CREATED="1581814371794" ID="ID_1259356965" MODIFIED="1581814384324" TEXT="hatte grade eben in Cinelerra eine Tonne von Segfaults gefixt"/>
|
|
<node CREATED="1581814384745" ID="ID_1154039482" MODIFIED="1581814458257" TEXT="GCC-8 ist nicht mehr gutmütig bei fehlenden Return_Statements">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
früher war das so eine typische "nörgel"-Warnung, die man unter den Teppich kehren konnte: 'ey, der Compiler bekommt es ja trotzdem richtig hin.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582315830960" ID="ID_284872523" MODIFIED="1582315840434" TEXT="Testsuite GRÜN">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1439644339480" ID="ID_1582631934" MODIFIED="1581813253348" TEXT="Lumiera DEB">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
sinnvollen Zustand erreichen: zumindest das neue GUI sollte wieder starten
|
|
</li>
|
|
<li>
|
|
dann Paket aktualisieren und neu bauen
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1439644368572" ID="ID_688656048" MODIFIED="1581813253348" TEXT="Doku: Referenz-System">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439176875682" FOLDED="true" ID="ID_1482098521" MODIFIED="1581813429187" TEXT="Debian/Bullseye">
|
|
<edge COLOR="#cead77" STYLE="linear"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1439176890840" ID="ID_535116778" MODIFIED="1581813253348" TEXT="Probleme"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1439644368572" ID="ID_1667125104" MODIFIED="1581813253348" TEXT="Doku: Referenz-System">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446505444775" FOLDED="true" HGAP="106" ID="ID_721807850" MODIFIED="1561311686974" TEXT="Buildsystem" VSHIFT="-5">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1446505367113" ID="ID_335245102" LINK="http://issues.lumiera.org/ticket/971" MODIFIED="1557498707242">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
standard hardening-flags setzen <font color="#ba015b">#971</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1446509415481" ID="ID_180589749" MODIFIED="1557498707242" TEXT="Versionen hochsetzen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wähle Kompatibiltät genau so, daß Ubuntu-Trusty noch unterstützt wird.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1446509422423" ID="ID_1328716100" MODIFIED="1557498707242" TEXT="gtkmm-3.0 3.10">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446509430758" ID="ID_371171235" MODIFIED="1557498707242" TEXT="glibmm-2.4 2.39">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446509601271" ID="ID_1477664506" MODIFIED="1557498707242" TEXT="libglib2.0 2.40">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1446510347931" ID="ID_559552800" MODIFIED="1557498707242" TEXT="direkten Check hierfür"/>
|
|
<node CREATED="1446510354914" ID="ID_1787485177" MODIFIED="1557498707242" TEXT="check für gthread fraglich"/>
|
|
</node>
|
|
<node CREATED="1446509752707" ID="ID_1392554051" MODIFIED="1557498707242" TEXT="libgdl-3-dev 3.12">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446509983556" ID="ID_366391443" MODIFIED="1557498707242" TEXT="libcairomm-1.0-dev 1.10">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446510475202" ID="ID_514495017" MODIFIED="1557498707242" TEXT="librsvg2-dev 2.30">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446511275302" ID="ID_359693763" MODIFIED="1557498707242" TEXT="libgavl-dev 1.4">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446510776857" ID="ID_674774779" MODIFIED="1557498707242" TEXT="Kommentar: librt gehört zu libc 6">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1446511125266" ID="ID_1198662071" MODIFIED="1557498707242" TEXT="Kommentar zu xv, x11 und xext : TODO videodisplayer obsolet?">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544239177727" FOLDED="true" HGAP="90" ID="ID_1414932362" MODIFIED="1561827466250" TEXT="Probleme..." VSHIFT="3">
|
|
<icon BUILTIN="go"/>
|
|
<node COLOR="#338800" CREATED="1544239202589" ID="ID_1398808684" MODIFIED="1544310874478" TEXT="an neue Layer-Struktur anpassen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1544239214321" FOLDED="true" ID="ID_953169553" MODIFIED="1561827466253" TEXT="CSS wird in 'stage'-Ordner installiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544239226829" ID="ID_82474485" MODIFIED="1544239233820" TEXT="ist eigentlich logisch"/>
|
|
<node CREATED="1544239234333" ID="ID_1530961275" MODIFIED="1544239247659" TEXT="eine Folge meiner Inkonsequenz">
|
|
<node CREATED="1544239248527" ID="ID_1536715197" MODIFIED="1544239262200" TEXT="ich wollte den 'gui' Ordner in target beibehalten"/>
|
|
<node CREATED="1544239262932" ID="ID_1612950753" MODIFIED="1576282357924" TEXT="aber GuiResource installiert src -> target">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
env.GuiResource(f) for f in env.Glob('stage/*.css')
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544239314129" ID="ID_1316699242" MODIFIED="1544310685527" TEXT="Lösungen...">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544239328169" ID="ID_1734838035" MODIFIED="1544310744532" TEXT="CSS in data-Ordner umziehen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1544310696005" ID="ID_1736290153" MODIFIED="1576282357923" TEXT="bliebe längerfristig eine Option">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wenn ich doch mal noch komplexere Bäume transportieren muß
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544310717868" ID="ID_1020173356" MODIFIED="1576282357923" TEXT="gefällt mir aber nicht">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
ich mag code-nahe Resourcen lieber beim Code selber
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544288541443" ID="ID_729362244" MODIFIED="1544310825247" TEXT="root der GUI-Ressourcen einen level tiefer legen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1544288579625" ID="ID_1342094420" MODIFIED="1544288601884" TEXT="d.h., wir behandeln nun GUI-Resourcen explizit"/>
|
|
<node CREATED="1544288602331" ID="ID_293063721" MODIFIED="1544288615109" TEXT="bisher war das Konzept "Resource" Applikations-global">
|
|
<node CREATED="1544310441186" ID="ID_1121330542" MODIFIED="1544310446333" TEXT="naja.... nicht wirklich"/>
|
|
<node CREATED="1544310446895" ID="ID_1245766637" MODIFIED="1544310531289" TEXT="das war nur die Absicht gewesen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber bei der Implementierung hab' ich dann Pragmatismus walten lassen
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
 Stichwort: getDirname()
|
|
</li>
|
|
<li>
|
|
effektiv ist das nur eine Ebene tief gestaffelt
|
|
</li>
|
|
<li>
|
|
alles darunter wäre in ein Verzeichnis gekippt worden
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544310749304" ID="ID_1607480762" MODIFIED="1544310785609" TEXT="geht auch nicht ohne weiteres....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
weil dann die Builder-Funktion die Quelle nicht mehr findet :-P
|
|
</p>
|
|
<p>
|
|
Dann
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544310787003" ID="ID_775636634" MODIFIED="1544310821317" TEXT="läuft schließlich darauf hinaus, die Builder-Funktion selber anzupassen">
|
|
<arrowlink COLOR="#386599" DESTINATION="ID_910836334" ENDARROW="Default" ENDINCLINATION="156;0;" ID="Arrow_ID_1032149588" STARTARROW="None" STARTINCLINATION="89;0;"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544310537285" ID="ID_799797239" MODIFIED="1544310831740" TEXT="GuiResourcen aufsammeln und in ein Verzeichnis kippen">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1544310560595" ID="ID_910836334" MODIFIED="1544310816900" TEXT="tatsächlich wird die Funktion env.GuiResource() genau einmal verwendet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
nämlich im src/SConscript, wenn es um das GUI geht
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#386599" DESTINATION="ID_910836334" ENDARROW="Default" ENDINCLINATION="156;0;" ID="Arrow_ID_1032149588" SOURCE="ID_775636634" STARTARROW="None" STARTINCLINATION="89;0;"/>
|
|
</node>
|
|
<node CREATED="1544310594077" ID="ID_1194673968" MODIFIED="1544310628882">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und sie war ohnehin schon so geschrieben worden, daß das Endresultat <i>irgendwie paßt</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node CREATED="1544310632504" ID="ID_1500688292" MODIFIED="1544310638741" TEXT="Fazit">
|
|
<node CREATED="1544310639631" ID="ID_1925161772" MODIFIED="1544310651177" TEXT="den Tanz mit dem root-Verzeichnis einfach weglassen"/>
|
|
<node CREATED="1544310651574" ID="ID_666502203" MODIFIED="1544310655937" TEXT="kein getDirname() mehr"/>
|
|
<node CREATED="1544310656429" ID="ID_1773784100" MODIFIED="1544310667072" TEXT="und stattdessen das Ziel direkt in Setup.py auscoden"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544239360927" ID="ID_1906746912" MODIFIED="1544239423084" TEXT="deckt Folgeproblem im GUI auf">
|
|
<arrowlink COLOR="#7f244b" DESTINATION="ID_626803835" ENDARROW="Default" ENDINCLINATION="193;-461;" ID="Arrow_ID_65546348" STARTARROW="None" STARTINCLINATION="421;19;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1447566875500" HGAP="35" ID="ID_773580451" MODIFIED="1557498707242" TEXT="wünschenswert..." VSHIFT="16">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1447566892252" ID="ID_649638170" MODIFIED="1557498707242" TEXT="generische Compiler-Schalter zur Diagnose loggen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...damit man auch im Paketbau-Build-Output wenigstens einmal <i>alle</i>  generischen Platform-Schalter sieht
|
|
</p>
|
|
<p>
|
|
Ich meine also: zu Beginn vom Build sollte das Buildsystem einmal eine Infozeile ausgeben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1447566892253" ID="ID_64485556" MODIFIED="1557498707242" TEXT="clean soll .sconf_temp und *.pyc mit wegräumen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...denn die stören jeweils beim erzeugen eines Hotfix/Patch im Paketbau per dpkg --commit
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1447978374453" HGAP="140" ID="ID_156552320" MODIFIED="1582315374832" TEXT="Compiler" VSHIFT="-10">
|
|
<icon BUILTIN="go"/>
|
|
<node CREATED="1447978472591" ID="ID_281213456" MODIFIED="1581813532154" TEXT="GCC-4.9">
|
|
<icon BUILTIN="licq"/>
|
|
</node>
|
|
<node CREATED="1447978381986" FOLDED="true" ID="ID_378439500" MODIFIED="1581813532154" TEXT="GCC-5">
|
|
<icon BUILTIN="licq"/>
|
|
<node CREATED="1447983098958" ID="ID_291439119" MODIFIED="1557498707243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
deprecated: <b>auto_ptr</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1447990971420" ID="ID_1499023407" MODIFIED="1557498707243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Tests mit TypeIDs <font color="#ed0b08">scheitern</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1447983008594" ID="ID_8361302" MODIFIED="1561237521960" TEXT="Lösung für std::hash finden"/>
|
|
<node COLOR="#338800" CREATED="1561237626971" ID="ID_172542353" MODIFIED="1561237649112" TEXT="August 2018">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561237650841" ID="ID_749683072" MODIFIED="1561237661542" TEXT="Anpassungen und Umstellung"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561237662047" ID="ID_998640781" MODIFIED="1561237692524" TEXT="Achtung: std::string wird größer">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Grund ist die Umstellung auf inline-Storage
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1561237693445" ID="ID_795236381" MODIFIED="1561237730770" TEXT="noch offen: Umstellung auf lib::Symbol in EntryID">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wäre theoretisch jetzt möglich,
|
|
</p>
|
|
<p>
|
|
da wir nun eine vollwertige String-Tabelle haben
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561237793933" ID="ID_938708757" MODIFIED="1581813532155" TEXT="GCC-6">
|
|
<icon BUILTIN="licq"/>
|
|
<node CREATED="1561237816056" ID="ID_584388122" MODIFIED="1561237823947" TEXT="Debian/Stretch">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1561237804916" ID="ID_392420321" MODIFIED="1561237815456" TEXT="gegenwärtig (2019) der Referenz-Compiler"/>
|
|
</node>
|
|
<node CREATED="1561237739453" ID="ID_894802950" MODIFIED="1561237784571" TEXT="GCC-7">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561237754266" ID="ID_646410828" MODIFIED="1561237789149" TEXT="Herbst 2018">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
waren nur minimale Anpassungen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561237831168" ID="ID_1760455064" MODIFIED="1561311488940" TEXT="Juni 2019">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1561237841287" ID="ID_1588960225" MODIFIED="1561311497905" TEXT="Probleme mit libboost 1.65">
|
|
<arrowlink COLOR="#37aea5" DESTINATION="ID_584004962" ENDARROW="Default" ENDINCLINATION="295;-171;" ID="Arrow_ID_1368108105" STARTARROW="None" STARTINCLINATION="247;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581813455951" ID="ID_1821559366" MODIFIED="1582315344844" TEXT="GCC-8">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1581813466582" ID="ID_1727015963" MODIFIED="1583523550183" TEXT="Februar 2020">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1581740476035" FOLDED="true" ID="ID_1259527140" MODIFIED="1583523540875" TEXT="Build-Fixes (analog Paketbau)">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1581740511638" ID="ID_673829980" MODIFIED="1581812450753" TEXT="die FSecs-Problematik">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1581812473146" ID="ID_1228189647" MODIFIED="1581812478016" TEXT="betroffen...">
|
|
<node CREATED="1581740610730" ID="ID_696004750" MODIFIED="1581740610730" TEXT="src/lib/time/timevalue.hpp"/>
|
|
<node CREATED="1581740623344" ID="ID_1853788907" MODIFIED="1581740623344" TEXT="src/lib/time/time.cpp"/>
|
|
<node CREATED="1581740661389" ID="ID_1959026707" MODIFIED="1581740661389" TEXT="tests/core/proc/asset/meta/time-grid-basics-test.cpp"/>
|
|
</node>
|
|
<node CREATED="1581812452760" ID="ID_284310017" MODIFIED="1581812543320" TEXT="inzwischen längst schon sauberer gelöst">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das Problem wurde vom GCC beim Bauen des alten Lumiera-Paketes angemahnt; tatsächlich aber hatte ich das Problem inzwischen längst schon anderweitig bemerkt und an der Wurzel gelöst, anstatt nur Symptome zu behandeln
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1581740733368" FOLDED="true" ID="ID_1726260734" MODIFIED="1581906950545" TEXT="TICKET #939 : should better use 64bit base type for FSecs?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1581740750350" ID="ID_1497724243" MODIFIED="1581819702167" TEXT="macht sich als 32bit vs 64bit-Problematik bemerkbar">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
als "workaround" hatte ich boost::rational<long> genommen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1581819704923" ID="ID_1047068236" MODIFIED="1581819708983" TEXT="was ist die Gefahr?">
|
|
<node CREATED="1581819714050" ID="ID_314031332" MODIFIED="1581819747785" TEXT="wenn FSecs == rational<int64_t>"/>
|
|
<node CREATED="1581819818091" ID="ID_135964502" MODIFIED="1581819829735" TEXT="könnte dann...">
|
|
<node CREATED="1581819830610" ID="ID_1892644470" MODIFIED="1581819869673" TEXT="ein gavl_time_t als FSecs reinrutschen?"/>
|
|
<node CREATED="1581819875124" ID="ID_1881211496" MODIFIED="1581819926345" TEXT="ein FrameCnt (==int64_t) als FSecs reinrutschen"/>
|
|
</node>
|
|
<node CREATED="1581830913676" ID="ID_1851233163" MODIFIED="1581831276538" TEXT="möglicherweise">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
<node CREATED="1581830921543" ID="ID_1634734053" MODIFIED="1581830932821" TEXT="FixedFramesQuantiser-ctor">
|
|
<node CREATED="1581830948928" ID="ID_1558541350" MODIFIED="1581831146865" TEXT="Framerate">
|
|
<node CREATED="1581831157480" ID="ID_425744081" MODIFIED="1581831161915" TEXT="via uint fps">
|
|
<node CREATED="1581833787784" ID="ID_208241204" MODIFIED="1581833800782" TEXT="hat Vorfahrt bei einfachen Zahlen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581831174129" ID="ID_283797015" MODIFIED="1581831181172" TEXT="via rational<uint>"/>
|
|
</node>
|
|
<node CREATED="1581830970509" ID="ID_892094269" MODIFIED="1581831262411" TEXT="via Duration">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1581831241536" ID="ID_1150857436" MODIFIED="1581831259798" TEXT="keine Gefahr"/>
|
|
<node CREATED="1581831244519" ID="ID_270912881" MODIFIED="1581833828374" TEXT="ctor via FSecs ist explicit"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581831295432" ID="ID_897252634" MODIFIED="1581831298540" TEXT="Grid::timeOf">
|
|
<node CREATED="1581831305831" ID="ID_775298577" MODIFIED="1581831317561" TEXT="FrameCnt gridPoint"/>
|
|
<node CREATED="1581831336819" ID="ID_742904480" MODIFIED="1581831547730" TEXT="FSecs [, offset]">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1581831549990" ID="ID_1767803348" MODIFIED="1581831553618" TEXT="keine Gefahr"/>
|
|
<node CREATED="1581831554078" ID="ID_292991581" MODIFIED="1581831588989" TEXT="da stets der direkte Match auf FrameCnt bevorzugt wird"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581833987508" ID="ID_1945258109" MODIFIED="1581834001127" TEXT="die sonstiten TimeValues sind bereits "wasserdicht"">
|
|
<node CREATED="1581834003850" ID="ID_1726640094" MODIFIED="1581834011693" TEXT="alle gefährlichen ctor sind explicit"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581834016097" ID="ID_943401392" MODIFIED="1581834026595" TEXT="Lösungs-Alternativen">
|
|
<node COLOR="#338800" CREATED="1581834028399" ID="ID_1290001374" MODIFIED="1581905054869" TEXT="FSecs := rational<int64_t>">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1581834219506" ID="ID_1492786906" MODIFIED="1581834235727" TEXT="erlaubt Einstieg mit maximal großen Sekundenbeträgen"/>
|
|
<node CREATED="1581904944430" ID="ID_95309143" MODIFIED="1581905174089">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und wir brauchen die <b>definitiv</b> zum sinnvollen Rechenen mit Zeiten auf micro-Scala
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Der kritsche Fall ist nämlich, wenn wir mit FSecs anfangen, und dann irgendwo in der Rechnung mal Time::SCALE multiplizieren, um auf die µ-Skala zu wechseln. Am Ende der Rechnung würde dann typischerweise ein rational_cast stehen. Damit das funktioniert, muß vor allem der Zähler des Bruches die volle Zeitskala unterstützen. Daher sind <b>64bit zwingend</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#265a98" DESTINATION="ID_95309143" ENDARROW="Default" ENDINCLINATION="389;0;" ID="Arrow_ID_1170592297" SOURCE="ID_38565900" STARTARROW="None" STARTINCLINATION="670;0;"/>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581834047228" ID="ID_622470274" MODIFIED="1581905031525" TEXT="FSecs := rational<int>">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1581834077245" ID="ID_897585288" MODIFIED="1581834173627" TEXT="hätte den Charme, daß weder ein FrameCnt, noch eine gavl-Time direkt reinrutschen kann">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil 64bit -> 32bit eine <i>narrowing conversion</i> ist, die zumindest eine Warnung erzeugt
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1581834174595" ID="ID_1571757083" MODIFIED="1581902077277" TEXT="TODO: ist dieses Argument stichhaltig?">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1581902078156" ID="ID_1759780689" MODIFIED="1581902089742" TEXT="ja... durch Experiment geprüft"/>
|
|
<node CREATED="1581902090474" ID="ID_355415579" MODIFIED="1581902102205" TEXT="aber ohnehin ist lib::Time schon sehr gut abgedichtet"/>
|
|
</node>
|
|
<node CREATED="1581905033868" ID="ID_1903781960" MODIFIED="1581905047679" TEXT="aber die Genauigkeit reicht nicht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581834243675" ID="ID_1426215906" MODIFIED="1581902070280" TEXT="FSecs-ctor explicit machen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1581834266215" ID="ID_221160071" MODIFIED="1581834285216" TEXT="man würde damit ein "Schlupfloch" schließen"/>
|
|
<node CREATED="1581834285684" ID="ID_1178771813" MODIFIED="1581834312204" TEXT="im Moment kann man schreiben Time(12L) (und bekommt 12 Sekunden)"/>
|
|
<node CREATED="1581834377896" ID="ID_897382203" MODIFIED="1581834390340" TEXT="geplant: Integration mit std::chrono">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1581834393889" ID="ID_220525990" MODIFIED="1581834410119" TEXT="das würde wieder eine bequeme Notation bieten"/>
|
|
<node CREATED="1581834411251" ID="ID_509607126" MODIFIED="1581834424225" TEXT="wobei, "FSecs(12)" ist jetzt nicht sooo schlecht"/>
|
|
<node CREATED="1581834424753" ID="ID_1621101278" MODIFIED="1581834434707" TEXT="und außerdem mache ich es in der Praxis ohnehin so"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1581834553800" ID="ID_1858355977" MODIFIED="1581834582609" TEXT="erscheint mir als die sauberste Variante">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1581902038450" ID="ID_676891454" MODIFIED="1667336289185" TEXT="nicht einfach realisierbar">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#e0ceaa" COLOR="#690f14" CREATED="1667336290112" ID="ID_166419409" LINK="https://issues.lumiera.org/ticket/1055#comment:3" MODIFIED="1667336380910" TEXT="siehe Kommentar zu #1055">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1667336386235" ID="ID_1595778098" MODIFIED="1667336411267" TEXT="Vorsicht: soll nicht zur Denkfaulheit verleiten">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1667336412887" ID="ID_1127777473" MODIFIED="1667336438440" TEXT="std::chrono::duration vs Time als Zeit-Punkt"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581834456924" ID="ID_515357939" MODIFIED="1581834461008" TEXT="Typ-Fragen">
|
|
<node CREATED="1581834461832" ID="ID_1605358591" MODIFIED="1581834471551" TEXT="warum ist der FrameCnt ein signed integer?">
|
|
<node CREATED="1581883352929" ID="ID_1846298026" MODIFIED="1581883367592" TEXT="FrameCnt kann ein spezieller Timecode sein"/>
|
|
<node CREATED="1581883325779" ID="ID_573587391" MODIFIED="1581883342672" TEXT="weil es sich um eine Koordinate handelt"/>
|
|
<node CREATED="1581883343219" ID="ID_613888469" MODIFIED="1581883351652" TEXT="FrameCnt ist bisweilen negativ"/>
|
|
<node COLOR="#338800" CREATED="1581883360863" ID="ID_1550240767" MODIFIED="1581883366505" TEXT="also OK">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581834473819" ID="ID_38565900" MODIFIED="1581905067507" TEXT="brauchen / wollen wir 64bit für die FSecs?">
|
|
<arrowlink COLOR="#265a98" DESTINATION="ID_95309143" ENDARROW="Default" ENDINCLINATION="389;0;" ID="Arrow_ID_1170592297" STARTARROW="None" STARTINCLINATION="670;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1581813859601" FOLDED="true" ID="ID_728753164" MODIFIED="1582315336837" TEXT="auf C++17 heben">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1581991434932" ID="ID_104376570" MODIFIED="1582312758108" TEXT="Schalter setzen in Setup.py">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1581991444571" FOLDED="true" ID="ID_351533384" MODIFIED="1582312758109" TEXT="Problemcode vorerst auskommentiert">
|
|
<icon BUILTIN="licq"/>
|
|
<node CREATED="1581992755658" ID="ID_1595558796" MODIFIED="1581992775966" TEXT="util-coll.hpp">
|
|
<node CREATED="1581991489253" ID="ID_821303087" MODIFIED="1581992404462" TEXT=" and_all ">
|
|
<node CREATED="1581991517974" ID="ID_1722922510" MODIFIED="1581991517974" TEXT="can_STL_ForEach<Container>,"/>
|
|
<node CREATED="1581992406361" ID="ID_1457450258" MODIFIED="1581992409589" TEXT="von asset.cpp"/>
|
|
<node CREATED="1581992410249" ID="ID_845644128" MODIFIED="1581992429202" TEXT="von play-service.cpp : ProcessTable::isActive"/>
|
|
<node CREATED="1581992496443" ID="ID_1556779228" MODIFIED="1581992504496" TEXT="SubsystemRunner::triggerStartup"/>
|
|
<node CREATED="1581993273716" ID="ID_187313835" MODIFIED="1581993284470" TEXT="von util-foreach-test.cpp">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581995065708" ID="ID_167787591" MODIFIED="1581995069528" TEXT="has_any">
|
|
<node CREATED="1581995072059" ID="ID_266292535" MODIFIED="1581995075974" TEXT="von dock-area.cpp:153">
|
|
<node CREATED="1581995087331" ID="ID_1008790341" MODIFIED="1581995091844" TEXT="hier über std::list"/>
|
|
</node>
|
|
<node CREATED="1581995173317" ID="ID_1482525339" MODIFIED="1581995175625" TEXT="von panel-manager.cpp:146"/>
|
|
</node>
|
|
<node CREATED="1581992780940" ID="ID_846156960" MODIFIED="1581992784682" TEXT="last">
|
|
<node CREATED="1581992786719" ID="ID_868210635" MODIFIED="1581992786719" TEXT="enable_if< treat_as_LumieraIterator<IT>"/>
|
|
<node CREATED="1581992844006" ID="ID_1452486285" MODIFIED="1581992844915" TEXT="enable_if<util::{anonymous}::can_direct_access_Last<COLL>"/>
|
|
<node CREATED="1581992817306" ID="ID_1958248231" MODIFIED="1582226909217" TEXT="von dispatcher-interface-test.cpp">
|
|
<arrowlink COLOR="#1b487d" DESTINATION="ID_1278435250" ENDARROW="Default" ENDINCLINATION="531;0;" ID="Arrow_ID_1907491946" STARTARROW="Default" STARTINCLINATION="436;0;"/>
|
|
</node>
|
|
<node CREATED="1581994136969" ID="ID_1071697988" MODIFIED="1581994140342" TEXT="util-collection-test.cpp">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1581994205823" ID="ID_548485755" MODIFIED="1581994218847" TEXT="sehr interessant: der Iterator-Fall funktioniert nämlich">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581993060793" ID="ID_1110262639" MODIFIED="1581993091688" TEXT="TreeExplorer _DecoratorTraits : kann Collection-Fall nicht entscheiden">
|
|
<node CREATED="1581993101618" ID="ID_367690402" MODIFIED="1581993115453" TEXT="Verdarcht: wieder Lumiera Iter vs Collection enable-If"/>
|
|
<node CREATED="1581993133055" ID="ID_7676282" MODIFIED="1581993136234" TEXT="von iter-chain-search-test.cpp"/>
|
|
<node CREATED="1581993437094" ID="ID_553794215" MODIFIED="1581993437978" TEXT="verb-visitor-dispatch-test.cpp:203"/>
|
|
<node CREATED="1581993764266" ID="ID_1301200739" MODIFIED="1581993765334" TEXT="iter-tree-explorer-test.cpp:343"/>
|
|
</node>
|
|
<node CREATED="1581992139781" ID="ID_1486869166" MODIFIED="1581992148980" TEXT="util::join über einen transformIter">
|
|
<node CREATED="1581992186951" ID="ID_510132051" MODIFIED="1581992235886" TEXT="transformIter kan Ret-Type nicht abgreifen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
src/lib/itertools.hpp:805
|
|
</p>
|
|
<p>
|
|
error: no type named 'Ret' in 'struct lib::meta::_Fun<std::__cxx11::basic_string<char> (*)(const std::__cxx11::basic_string<char>&) noexcept, void>'
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1581992163401" ID="ID_1538196186" MODIFIED="1581993587078" TEXT="src/lib/variant.hpp:549:3: required from here"/>
|
|
<node CREATED="1581994935333" ID="ID_1128036242" MODIFIED="1581994936473" TEXT="test-nexus.cpp:50"/>
|
|
<node CREATED="1581993620189" ID="ID_868294584" MODIFIED="1581994635577" TEXT="ebenfalls via stringify()">
|
|
<node CREATED="1581993588898" ID="ID_1089387725" MODIFIED="1581994651213" TEXT="format-helper-test.cpp:142"/>
|
|
<node CREATED="1581994623271" ID="ID_628781534" MODIFIED="1581994658943" TEXT="tree-mutator-binding-test.cpp 420"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581994485434" ID="ID_942628679" MODIFIED="1581994495082" TEXT="MutationMessage">
|
|
<node CREATED="1581994497448" ID="ID_635292284" MODIFIED="1581994499252" TEXT="von mutation-message-test.cpp">
|
|
<node CREATED="1581994524698" ID="ID_582179423" MODIFIED="1581994535359" TEXT="kann nicht MutaionMessage-ctor auswählen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1581993910615" ID="ID_439067077" MODIFIED="1581993928904" TEXT="meta::_Fun Type-Deduction">
|
|
<node CREATED="1581993931924" ID="ID_1676073018" MODIFIED="1581993936207" TEXT="von item-wrapper-test.cpp:315">
|
|
<node CREATED="1581993971527" ID="ID_1616033054" MODIFIED="1581993977618" TEXT="ruft wrapper.hpp FunctionResult"/>
|
|
<node CREATED="1581994006526" ID="ID_1829879519" MODIFIED="1581994013677" TEXT="function-closure.hpp: _chain"/>
|
|
</node>
|
|
<node CREATED="1581994029929" ID="ID_20368460" MODIFIED="1581994030643" TEXT="no type named 'Args' in 'struct lib::meta::_Fun<int (*)() noexcept, void>'"/>
|
|
</node>
|
|
<node CREATED="1582226720811" ID="ID_1404034997" MODIFIED="1582226979278" TEXT="job.h : InvocationInstanceID ctor unclear">
|
|
<linktarget COLOR="#ca99b1" DESTINATION="ID_1404034997" ENDARROW="Default" ENDINCLINATION="-5;81;" ID="Arrow_ID_402256801" SOURCE="ID_520524824" STARTARROW="None" STARTINCLINATION="235;22;"/>
|
|
<node CREATED="1582226760132" ID="ID_1708527048" MODIFIED="1582226852847" TEXT="bis jetzt hat der Compiler einen "paßt scho"-ctor synthetisiert">
|
|
<icon BUILTIN="smiley-neutral"/>
|
|
</node>
|
|
<node CREATED="1582226854666" ID="ID_1829839467" MODIFIED="1582226871843" TEXT="sieht aber nach unvollständigem oder schlampigem Design aus">
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1581992817306" ID="ID_1278435250" MODIFIED="1582226909217" TEXT="ebenfalls von dispatcher-interface-test.cpp">
|
|
<linktarget COLOR="#1b487d" DESTINATION="ID_1278435250" ENDARROW="Default" ENDINCLINATION="531;0;" ID="Arrow_ID_1907491946" SOURCE="ID_1958248231" STARTARROW="Default" STARTINCLINATION="436;0;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1581995421239" ID="ID_1730281364" MODIFIED="1582312758109" TEXT="mutmaßliche Probleme">
|
|
<icon BUILTIN="info"/>
|
|
<node COLOR="#435e98" CREATED="1581995443649" FOLDED="true" ID="ID_986769823" MODIFIED="1582312758109" TEXT="STL collection duck detector greift nicht mehr">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582073183681" ID="ID_652495805" MODIFIED="1582073205034" TEXT="erklärt Defekt">
|
|
<node CREATED="1582073420161" ID="ID_1988954672" MODIFIED="1582073427721" TEXT="util-foreach-Prädikate"/>
|
|
<node CREATED="1581995510176" ID="ID_1166388129" MODIFIED="1581995518450" TEXT="util-coll-Prädikate"/>
|
|
<node CREATED="1581995535628" ID="ID_829639067" MODIFIED="1581995540536" TEXT="TreeExplorer"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582073220260" ID="ID_140955956" MODIFIED="1582233559353" TEXT="Untersuchung">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582073223795" ID="ID_596161629" MODIFIED="1582073232715" TEXT="DuckDetector_test PASS">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582073234062" ID="ID_1909467497" MODIFIED="1582073239279" TEXT="also kein elementares Problem"/>
|
|
</node>
|
|
<node CREATED="1582075935580" ID="ID_27838904" MODIFIED="1582075956597" TEXT="begin() / end() sind jetzt noexcept"/>
|
|
<node CREATED="1582075957329" ID="ID_1720366662" MODIFIED="1582075973818" TEXT="das hat wohl Einfluß auf die type deduction"/>
|
|
<node CREATED="1582233029258" ID="ID_1301588264" MODIFIED="1582233055488" TEXT="Duck-Detector (in try.cpp) nachgebaut...">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1582233058772" ID="ID_1586059095" MODIFIED="1582233088483">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die <b>überladene const</b>-Variante ist der Grund
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1582233338068" ID="ID_982873335" MODIFIED="1582233352296" TEXT="eine einzeln stehende Funktion würde implizit konvertiert"/>
|
|
<node CREATED="1582233362797" ID="ID_833938257" MODIFIED="1582233401713" TEXT="aber er kann nicht entscheiden func const">
|
|
<node CREATED="1582233402761" ID="ID_712697643" MODIFIED="1582233402761" TEXT="-> func noexcept"/>
|
|
<node CREATED="1582233405153" ID="ID_248777238" MODIFIED="1582233417751" TEXT="-> func const noexcept"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1582233448999" ID="ID_1418345816" MODIFIED="1582233462949" TEXT="Fazit">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1582233464208" ID="ID_1766502973" MODIFIED="1582233477724" TEXT="wenn wir beide Varianten "greifen" wollen...."/>
|
|
<node CREATED="1582233478442" ID="ID_173149831" MODIFIED="1582306757303" TEXT="dann brauchen wir zwei "Greifer"!!!">
|
|
<arrowlink COLOR="#0eaf68" DESTINATION="ID_374929365" ENDARROW="Default" ENDINCLINATION="143;-60;" ID="Arrow_ID_325541082" STARTARROW="None" STARTINCLINATION="279;23;"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1581995458449" FOLDED="true" ID="ID_524595490" MODIFIED="1582312758109" TEXT="meta::_Fun Type-Deduction greift nicht mehr">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582073209005" ID="ID_1128456119" MODIFIED="1582073212094" TEXT="erklärt Defekt">
|
|
<node CREATED="1581995542307" ID="ID_1935687224" MODIFIED="1581995545415" TEXT="transformIterator"/>
|
|
<node CREATED="1581995546475" ID="ID_1004262725" MODIFIED="1581995552782" TEXT="stringify"/>
|
|
<node CREATED="1581995553206" ID="ID_984495822" MODIFIED="1581995556030" TEXT="util::join"/>
|
|
</node>
|
|
<node CREATED="1582312412651" ID="ID_1422313569" MODIFIED="1582312440377" TEXT="ebenfalls durch Spezialisierung auf noexcept lösbar">
|
|
<arrowlink COLOR="#8dbd97" DESTINATION="ID_698919272" ENDARROW="Default" ENDINCLINATION="551;0;" ID="Arrow_ID_1462827757" STARTARROW="None" STARTINCLINATION="551;0;"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582226930039" ID="ID_520524824" MODIFIED="1582312758109" TEXT="Union-Initialisierung on-the-fly">
|
|
<arrowlink COLOR="#ca99b1" DESTINATION="ID_1404034997" ENDARROW="Default" ENDINCLINATION="-5;81;" ID="Arrow_ID_402256801" STARTARROW="None" STARTINCLINATION="235;22;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582233568711" ID="ID_1046617766" MODIFIED="1582312758109" TEXT="Lösungen">
|
|
<icon BUILTIN="idea"/>
|
|
<node COLOR="#338800" CREATED="1582233577705" ID="ID_1368671019" MODIFIED="1582312758109" TEXT="STL-Iterierbarkeit">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582233592571" ID="ID_409234723" MODIFIED="1582312758109">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Frage: wollen wir auf <i>noexcept</i> einschränken?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1582233691150" ID="ID_860044262" MODIFIED="1582312758109" TEXT="NEIN">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
<node CREATED="1582233699511" ID="ID_287790035" MODIFIED="1582312758109" TEXT="das ist nicht Teil des Konzepts »Iterierbarkeit«">
|
|
<node CREATED="1582233730337" ID="ID_1576759110" MODIFIED="1582312758109" TEXT="hier ganz klar "im weitesten Sinne" gemeint"/>
|
|
<node CREATED="1582233816125" ID="ID_1024965560" MODIFIED="1582312758109" TEXT="Beweis: <bits/range_access.h>">
|
|
<node CREATED="1582233844361" ID="ID_697050029" MODIFIED="1582312758109" TEXT="Funktion std::begin(X) ist ohne noexcept definiert"/>
|
|
<node CREATED="1582233871134" ID="ID_439487192" MODIFIED="1582312758109" TEXT="macht auch inhaltlich Sinn so"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582233905345" ID="ID_374929365" MODIFIED="1582312758109" TEXT="Lösungsansatz-1: beide Varianten explizit prüfen">
|
|
<linktarget COLOR="#0eaf68" DESTINATION="ID_374929365" ENDARROW="Default" ENDINCLINATION="143;-60;" ID="Arrow_ID_325541082" SOURCE="ID_173149831" STARTARROW="None" STARTINCLINATION="279;23;"/>
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1582237126809" ID="ID_885223940" MODIFIED="1582312758109" TEXT="das würde den Status-quo einfach reparieren"/>
|
|
<node CREATED="1582237135080" ID="ID_247923480" MODIFIED="1582312758109" TEXT="dieser ist aber selbst einigermaßen "pragmatisch" und verworren">
|
|
<node CREATED="1582237183692" ID="ID_898840580" MODIFIED="1582312758109" TEXT="siehe z.B. lib/meta/trait-special.hpp">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<ul>
|
|
<li>
|
|
als schneller Fix implementiert
|
|
</li>
|
|
<li>
|
|
und tatsächlich nur einmal, für einen Test verwendet
|
|
</li>
|
|
<li>
|
|
eigentlich wird damit das Problem "unter den Teppich gekehrt"
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582237153893" ID="ID_1734163342" MODIFIED="1582312758109" TEXT="...und ich weiß, daß das Thema für C++20 angegangen und aufgeräumt werden muß"/>
|
|
<node COLOR="#435e98" CREATED="1582305423630" ID="ID_406561498" MODIFIED="1582312758109" TEXT="ist die einzige zur Zeit sinnvoll umsetzbare Lösung">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
"sinnvoll" heißt
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
stabil
|
|
</li>
|
|
<li>
|
|
lesbar
|
|
</li>
|
|
</ul>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582233920415" ID="ID_1234146956" MODIFIED="1582312758109" TEXT="Lösungsansatz-2: umstellen auf RangeTS-Iterierbarkeit">
|
|
<icon BUILTIN="closed"/>
|
|
<node CREATED="1582236780720" ID="ID_617011073" MODIFIED="1582312758109" TEXT="welchen Zweck erfüllt dieser Trait?">
|
|
<node CREATED="1582236798072" ID="ID_626851812" MODIFIED="1582312758110" TEXT="geht es um »Iterierbarket«?"/>
|
|
<node CREATED="1582236809676" ID="ID_1014412331" MODIFIED="1582312758110" TEXT="oder geht es um STL-Container?"/>
|
|
</node>
|
|
<node CREATED="1582237912798" ID="ID_1995184792" MODIFIED="1582312758110" TEXT="alle bisherigen Verwendungen....">
|
|
<node CREATED="1582237974967" ID="ID_1205441472" MODIFIED="1582312758110" TEXT="...dienen dazu, Lumiera-Itarator und STL-Container einheitlich »iterierbar« zu adaptieren"/>
|
|
<node CREATED="1582237960985" ID="ID_1470506535" MODIFIED="1582312758110" TEXT="...es gibt gar nicht so viele Verwendungen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
warum...?
|
|
</p>
|
|
<p>
|
|
..vermutlich, weil ich ab einem gewissen Punkt damit angefangen habe, auch die Lumiera-Iteratoren als "foreach-iterierbar" zu dekorieren (indem sie freie begin(iter) und end(iter)-Funktionen bieten).
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582305384364" ID="ID_238579581" MODIFIED="1582312758110" TEXT="ist nicht das was wir hier wollen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1582237046588" ID="ID_400180049" MODIFIED="1582312758110" TEXT="Lösunsansatz-3: ein maßgeschneidertes Concept bauen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1582237081319" ID="ID_1673821136" MODIFIED="1582312758110" TEXT="bereits im Vorgriff auf C++20 implementiert"/>
|
|
<node CREATED="1582237094158" ID="ID_206423592" MODIFIED="1582312758110">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es sollte genau die Eigenschaften abdecken, die wir <b>tatsächlich brauchen</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1582305280750" ID="ID_1737226688" MODIFIED="1582312758110" TEXT="hab's versucht">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1582305294632" ID="ID_1508436965" LINK="https://stackoverflow.com/a/16316640/444796" MODIFIED="1582312758110" TEXT="in Anlehnung an (SO)"/>
|
|
<node CREATED="1582305317917" ID="ID_63672565" MODIFIED="1582312758110" TEXT="wird aber sehr komplex im Detail"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1582305327187" ID="ID_393824782" MODIFIED="1582312758110" TEXT="Abbruch">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1582305338154" ID="ID_529828571" MODIFIED="1582312758110" TEXT="Lösung ist nicht lesbar"/>
|
|
<node CREATED="1582305348153" ID="ID_1318841418" MODIFIED="1582312758110" TEXT="in 2 Jahren nutzen wir Concepts">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582312227006" ID="ID_1679109428" MODIFIED="1582312758110" TEXT="Funktions-Detektor">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1582312235632" ID="ID_1383769424" MODIFIED="1582312758110" TEXT="es ist ebenfalls noexcept">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1582312256096" ID="ID_698919272" MODIFIED="1582312758110" TEXT="läßt sich mit forwarding-specialisation wegstrippen">
|
|
<linktarget COLOR="#8dbd97" DESTINATION="ID_698919272" ENDARROW="Default" ENDINCLINATION="551;0;" ID="Arrow_ID_1462827757" SOURCE="ID_1422313569" STARTARROW="None" STARTINCLINATION="551;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1582312269622" ID="ID_1014206981" LINK="https://stackoverflow.com/a/55701361/444796" MODIFIED="1582312758110" TEXT="Gefahr der kombinatorischen Explosion">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mit const und volatile...
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1447978388930" ID="ID_78828927" MODIFIED="1582315355090" TEXT="Clang 3.5">
|
|
<icon BUILTIN="licq"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582315356166" ID="ID_568554401" MODIFIED="1582315369107" TEXT="Clang-7">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1446480582168" FOLDED="true" HGAP="46" ID="ID_554745278" MODIFIED="1581813780309" TEXT="Release" VSHIFT="-5">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node CREATED="1446480601381" ID="ID_1870415321" MODIFIED="1581813706345" TEXT="release prep: clean-up obsolete information">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Doku durchkämmen nach Müll
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<font NAME="SansSerif" SIZE="12"/>
|
|
<icon BUILTIN="full-1"/>
|
|
<node CREATED="1446482192807" ID="ID_852733328" MODIFIED="1576282357919" TEXT="Debian">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier nach offensichtlich obsoleter Info checken
|
|
</p>
|
|
<p>
|
|
<font color="#d40222">WICHTIG</font>: keine vorgreifende Infos publizieren!!!!!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1446482445325" ID="ID_1134936512" MODIFIED="1576282357918" TEXT="Build-Tutorial">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
die explizit angegebenen Paketnamen schon mal vorchecken
|
|
</p>
|
|
<p>
|
|
die Abschnitte zu den LIbraries prüfen / umschreiben
|
|
</p>
|
|
<p>
|
|
insgesamt sorgfältig durchlesen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<node CREATED="1446489425420" ID="ID_1155768637" MODIFIED="1518487921104" TEXT="building from source"/>
|
|
<node CREATED="1446489431443" ID="ID_1672115205" MODIFIED="1518487921104" TEXT="building the debian way"/>
|
|
<node CREATED="1446489436395" ID="ID_52990160" MODIFIED="1518487921104" TEXT="contributing"/>
|
|
</node>
|
|
<node CREATED="1446482485648" ID="ID_718218074" MODIFIED="1518487921104" TEXT="technical/build/Dependencies"/>
|
|
</node>
|
|
<node CREATED="1446480725508" ID="ID_789754974" MODIFIED="1576282357917" TEXT="release prep: bump version number">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
knappe Kennzeichnung des Releases in den Kommentar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-2"/>
|
|
<node CREATED="1446480787391" ID="ID_1824008353" MODIFIED="1518487921104" TEXT="admin/scons/Setup.py"/>
|
|
<node CREATED="1446480787392" ID="ID_1638555946" MODIFIED="1518487921104" TEXT="data/config/setup.ini"/>
|
|
<node CREATED="1446480787392" ID="ID_619067196" MODIFIED="1518487921104" TEXT="doc/devel/Doxyfile"/>
|
|
<node CREATED="1446480787392" ID="ID_193733835" MODIFIED="1518487921104" TEXT="doc/devel/Doxyfile.browse"/>
|
|
</node>
|
|
<node CREATED="1446481181543" ID="ID_1995398229" MODIFIED="1576282357917" TEXT="Rück-Merge vom Release-Zweig">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hier geht es darum, Konsistenz im Git herzustellen.
|
|
</p>
|
|
<p>
|
|
Wenn alles korrekt gemacht wurde, dürfte es hier keinen Rückfluß von Änderungen geben.
|
|
</p>
|
|
<p>
|
|
Bitte auch daran denken, zuerst den DEB-Zweig zu prüfen. Diesen aber nicht zurückmergen,
|
|
</p>
|
|
<p>
|
|
denn wir wollen keine DEB-Info im Master haben!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-3"/>
|
|
<node CREATED="1446481302159" ID="ID_1330024662" MODIFIED="1518487921104" TEXT="Release-Zweig"/>
|
|
<node CREATED="1446481305102" ID="ID_1191774545" MODIFIED="1518487921104" TEXT="lfd Fixes von den DEBs"/>
|
|
<node CREATED="1446481314669" ID="ID_477388235" MODIFIED="1518487921104" TEXT="Plattform-Abhängigkeiten checken"/>
|
|
</node>
|
|
<node CREATED="1446480963028" ID="ID_83763074" MODIFIED="1581813706345" TEXT="Release-commit: Pre-release 0.pre.04">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
einzeilige Kennzeichnung wiederholen
|
|
</p>
|
|
<p>
|
|
die unmittelbaren Release-Dokumente durchgehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-4"/>
|
|
<node CREATED="1446481123991" ID="ID_1319204482" MODIFIED="1518487921104" TEXT="README"/>
|
|
<node CREATED="1446481126974" ID="ID_537666758" MODIFIED="1518487921104" TEXT="AUTHORS">
|
|
<node CREATED="1446481146548" ID="ID_1310945179" MODIFIED="1518487921104" TEXT="GTK-UI">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1446481155762" ID="ID_290411770" MODIFIED="1518487921104" TEXT="setup.ini">
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446481129206" ID="ID_799927356" MODIFIED="1518487921104" TEXT="LICENSE"/>
|
|
</node>
|
|
<node CREATED="1446481516578" ID="ID_552450474" MODIFIED="1581813706345" TEXT="Release-Zweig: upgrade current release to 0.pre.04">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Merge-commit auf den Release-Zweig.
|
|
</p>
|
|
<p>
|
|
Sollte konfliktfrei sein
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-5"/>
|
|
</node>
|
|
<node CREATED="1446481591568" ID="ID_1120064498" MODIFIED="1518487921104" TEXT="Paketieren">
|
|
<icon BUILTIN="full-6"/>
|
|
<node CREATED="1446481606134" ID="ID_212330450" MODIFIED="1518487921104" TEXT="Merge release -> deb"/>
|
|
<node CREATED="1446481618196" ID="ID_1882691551" MODIFIED="1518487921104" TEXT="Paket-Beschreibung"/>
|
|
<node CREATED="1446481637738" ID="ID_1002196753" MODIFIED="1518487921104" TEXT="Manpages">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
<node CREATED="1446481646057" ID="ID_262549512" MODIFIED="1518487921104" TEXT="control"/>
|
|
<node CREATED="1446481655743" ID="ID_269337100" MODIFIED="1581813706344" TEXT="rules"/>
|
|
</node>
|
|
<node CREATED="1446481713984" ID="ID_1112453089" MODIFIED="1576282357915" TEXT="ausliefern">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...das heißt bauen und hochladen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="full-7"/>
|
|
<node CREATED="1447566826434" HGAP="0" ID="ID_808634666" MODIFIED="1518487921104" TEXT="Bugfix-Release 0.pre.03-2" VSHIFT="-1">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1447566826434" HGAP="4" ID="ID_1582615496" MODIFIED="1518487921104" TEXT="Bugfix-Release 0.pre.03-3" VSHIFT="-14">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1446482059174" ID="ID_1294670881" MODIFIED="1581813751238">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<b>Referenz</b>: Debian/Jessie (stable) : i386 and x86_64
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1447566711958" ID="ID_450859594" MODIFIED="1518487921105" TEXT="alte version war broken"/>
|
|
<node CREATED="1447566721616" ID="ID_520179523" MODIFIED="1518487921105" TEXT="32 / 64bit Probleme"/>
|
|
<node CREATED="1447566743461" ID="ID_1754275668" LINK="http://issues.lumiera.org/ticket/973" MODIFIED="1518487921105">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Probleme mit der Compile-Reihenfolge  <font color="#d41807">#973</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1447566806556" ID="ID_708047854" MODIFIED="1518487921105" TEXT="neues Bugfix-Release">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1446482059174" ID="ID_1693967692" MODIFIED="1581813738594" TEXT="Ubuntu/Trusty (14.LTS) : i386 and x86_64">
|
|
<icon BUILTIN="licq"/>
|
|
<node CREATED="1446509774664" ID="ID_458867123" MODIFIED="1518487921105" TEXT="Ausnahmen für libgdl-3-dev 3.8"/>
|
|
<node CREATED="1447567139480" ID="ID_183954019" MODIFIED="1518487921105" TEXT="-> diese Ausnahmen in Paketdefinition übernommen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1447971961407" ID="ID_1876285814" MODIFIED="1518487921105" TEXT="habe dann aber doch gdl 3.16 gebackported">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1447971982360" ID="ID_1118580069" MODIFIED="1518487921105" TEXT="Beobachtung: Paket läßt sich nicht installieren">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1447971995582" ID="ID_1170070076" MODIFIED="1518487921105" TEXT="Doku-Registrierung scheitert">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1447972005940" ID="ID_876035298" MODIFIED="1541088155781" TEXT="doc-base Definition">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...führt sowohl eine README, alsauch ein Verzeichnis /usr/share/doc/lumiera/html auf, das (noch) nicht existiert
|
|
</p>
|
|
<p>
|
|
unter Debian/Jessie wird das ignoriert
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1447972547396" ID="ID_1950291699" MODIFIED="1541088155790">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
stelle fest: Fehler auf Trusty,
|
|
</p>
|
|
<p>
|
|
nur Warnung auf Mint
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
das heißt, daß ich versuchen kann, das Problem erst mal "unter den Teppich zu kehren"
|
|
</p>
|
|
<p>
|
|
Die Wahrscheinlichkeit, daß <i>irgend jemand</i> Lumiera unter Ubuntu/Trusty <i>installieren </i>möchte, erscheint mir akademisch
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446482059174" ID="ID_1906801117" MODIFIED="1581813769708" TEXT="Ubuntu/Vivid (15.04) : i386">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1446482059175" ID="ID_1107419581" MODIFIED="1518487921105" TEXT="Ubuntu/Wily (15.10) : x86_64">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1447978249148" ID="ID_218315533" MODIFIED="1518487921105">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bauen mit gcc-5 <b><font color="#d90d06">scheitert</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1447978292199" ID="ID_1160042901" MODIFIED="1518487921105" TEXT="ein Problem mit std::hash - Spezialisierung">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1447983052852" ID="ID_1130315053" MODIFIED="1576282357913" TEXT="liegt nur an fehlendem #include <utility>">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in lib/hash-standard.hpp
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1447990722939" ID="ID_1163368707" MODIFIED="1518487921105">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
mit gcc-5 gebaute Tests <b><font color="#d40262">scheitern</font></b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1447990760017" ID="ID_413820913" MODIFIED="1541088155831">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
bauen mit gcc-4.9 <i>nicht möglich</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
es gibt Probleme beim Linken mit den Boost-Libraries, die auf Ubuntu/wily mit gcc-5 gebaut sind.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1447990802803" ID="ID_1667893677" MODIFIED="1518487921105" TEXT="ABBRUCH"/>
|
|
</node>
|
|
<node CREATED="1446482059175" ID="ID_904094860" MODIFIED="1581813769707" TEXT="Mint/Rafaela (17.2.LTS) : x86_64">
|
|
<icon BUILTIN="closed"/>
|
|
</node>
|
|
<node CREATED="1446482249336" ID="ID_1088469455" MODIFIED="1576282357912" TEXT="Web/Doku aktualisieren">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Wichtig: hier nur was wirklich gebaut ist und funktioniert!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1446589479832" ID="ID_1851762530" MODIFIED="1581813706344" TEXT="alte Repos wegwerfen">
|
|
<node CREATED="1446589487798" ID="ID_1080472422" MODIFIED="1581813706344" TEXT="Lumi-Depot: Wheezy"/>
|
|
<node CREATED="1446589495445" ID="ID_1083044545" MODIFIED="1581813706344" TEXT="VBox Wheezy"/>
|
|
<node CREATED="1446589502132" ID="ID_271504207" MODIFIED="1581813706344" TEXT="VBox Mint Quiana"/>
|
|
</node>
|
|
<node CREATED="1446481892624" ID="ID_1020531472" MODIFIED="1581813706342" TEXT="Ticket schließen">
|
|
<font BOLD="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1439842359711" ID="ID_1982964862" MODIFIED="1581813505207" TEXT="Paket">
|
|
<icon BUILTIN="stop"/>
|
|
<node COLOR="#6a1928" CREATED="1561237113163" ID="ID_1613245846" MODIFIED="1561237134536" TEXT="zu klären">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1439842379420" ID="ID_1336697213" MODIFIED="1557498707243" TEXT="gtk-Abhängigkeiten"/>
|
|
<node CREATED="1446486970358" ID="ID_1758732894" MODIFIED="1561237137893" TEXT="was ist mit libXV">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
eigentlich war die nur notwendig für das Video-Viewer Widget,
|
|
</p>
|
|
<p>
|
|
was nun leider tot ist. Wir haben noch keinen Ersatz. Deshalb lasse ich die Abhängigkeit
|
|
</p>
|
|
<p>
|
|
bestehen, aber irgendwann müssen wir das schon glattziehen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="help"/>
|
|
</node>
|
|
<node CREATED="1446505367113" ID="ID_1119934206" LINK="http://issues.lumiera.org/ticket/971" MODIFIED="1557498707243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
hardening-flags! <font color="#ba015b">#971</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1478387336953" ID="ID_1320541285" MODIFIED="1557498707243" TEXT="debian/copyright">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1478387345624" ID="ID_666713431" MODIFIED="1557498707243" TEXT="sollte alle Copyright-statements korrekt zusammenfassen"/>
|
|
<node CREATED="1478387362709" ID="ID_1001009846" MODIFIED="1557498707243" TEXT="siehe Debian-Policy"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561237144633" HGAP="-10" ID="ID_1418254608" MODIFIED="1561237468222" TEXT="Docker-build" VSHIFT="30">
|
|
<edge COLOR="#2b265a" STYLE="linear"/>
|
|
<icon BUILTIN="prepare"/>
|
|
<node CREATED="1561237304621" ID="ID_1883389197" MODIFIED="1561237307268" TEXT="Automatisierung">
|
|
<node COLOR="#338800" CREATED="1561237242818" ID="ID_1327662353" MODIFIED="1561237253977" TEXT="automatisiert Build-Umgebung herstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561237261247" ID="ID_1198806785" MODIFIED="1561237298214" TEXT="Docker-Container starten und Build-Umgebung herstellen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561237338252" ID="ID_1527757716" MODIFIED="1561237341096" TEXT="Container">
|
|
<node CREATED="1561237342391" ID="ID_1602439603" MODIFIED="1561237349547" TEXT="laufend">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1561237350859" ID="ID_1545894719" MODIFIED="1561237360470" TEXT="ubuntu:bionic">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561237389597" FOLDED="true" ID="ID_1282777808" MODIFIED="1561237482474" STYLE="fork" TEXT="Release">
|
|
<icon BUILTIN="stop"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1561237395516" ID="ID_629494336" MODIFIED="1561237478731" TEXT="nixda">
|
|
<icon BUILTIN="flag-pink"/>
|
|
</node>
|
|
<node CREATED="1561237408778" ID="ID_410283986" MODIFIED="1561237478731" TEXT="Plan">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1561237420008" ID="ID_1274423839" MODIFIED="1561237478731" TEXT="vorbereitete saubere Umgebungen"/>
|
|
<node CREATED="1561237428807" ID="ID_662721931" MODIFIED="1561237478731" TEXT="per automatischer Routine erstellen"/>
|
|
<node CREATED="1561237439894" ID="ID_16174802" MODIFIED="1561237478731" TEXT="diese jeweils zum Release per DockerHub veröffentlichen"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1446356359992" HGAP="9" ID="ID_1850896628" MODIFIED="1557498707243" POSITION="left" TEXT="QA" VSHIFT="69">
|
|
<icon BUILTIN="prepare"/>
|
|
<node CREATED="1447985496639" ID="ID_1191711297" MODIFIED="1561311638128" TEXT="untersuchen">
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1447985501798" ID="ID_732609615" MODIFIED="1557498707243" TEXT="std::hash-Spezialisierung">
|
|
<node CREATED="1447985531602" ID="ID_515281257" LINK="http://issues.lumiera.org/ticket/722" MODIFIED="1557498707243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Ticket <font color="#d40230">#722</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1447985552663" ID="ID_1932953869" MODIFIED="1557498707243" TEXT="Hack ist inzwischen obsolet">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
seit gcc-4.8 ist kein static_assert mehr in der STDlib
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1447985591922" ID="ID_800130211" MODIFIED="1557498707243" TEXT="Frage: wie kann ich ein SFINAE-Brücke bauen"/>
|
|
<node CREATED="1447985637132" ID="ID_1680970111" MODIFIED="1557498707243" TEXT="Problem: wir haben nur einen Typparameter"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812024592" ID="ID_1371102521" MODIFIED="1570812029189" TEXT="immerwieder...">
|
|
<icon BUILTIN="bell"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1570815474222" ID="ID_678448874" MODIFIED="1570815485479" TEXT="#1204 Alignment issues">
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1570817474883" FOLDED="true" ID="ID_1779912405" MODIFIED="1570817537392" TEXT="#1205 Advice data possibly misaligned">
|
|
<linktarget COLOR="#cd4467" DESTINATION="ID_1779912405" ENDARROW="Default" ENDINCLINATION="296;20;" ID="Arrow_ID_1125835000" SOURCE="ID_711013238" STARTARROW="None" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
<node CREATED="1570817544291" ID="ID_1212317534" MODIFIED="1570817544291" TEXT="try { return new char[siz]; }"/>
|
|
<node CREATED="1570817565257" ID="ID_872374381" MODIFIED="1570817571504" TEXT="auf x86 harmlos"/>
|
|
<node CREATED="1570817572097" ID="ID_942342414" MODIFIED="1570817577917" TEXT="aber nicht portabel"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812031118" FOLDED="true" ID="ID_1018321072" MODIFIED="1570812037369" TEXT="Alignment bei placement-new">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1570812038974" ID="ID_716754107" MODIFIED="1570812068335" TEXT="der Buffer muß passendes Alignment für das Target aufweisen">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1570812070369" ID="ID_490799733" MODIFIED="1570812089910" TEXT="der Compiler kann das (meist/immer) nicht verifizieren">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1570812097734" ID="ID_649573793" MODIFIED="1570812117119" TEXT="da man die Storage oft weit durchreicht, ist das eine potentielle Falle"/>
|
|
</node>
|
|
<node CREATED="1570812123998" FOLDED="true" ID="ID_1852853548" MODIFIED="1570812393065" TEXT="2019-10 Codebasis durchgeprüft">
|
|
<node CREATED="1570812138224" ID="ID_499341259" MODIFIED="1570812146355" TEXT="alle Placement-New-Aufrufe"/>
|
|
<node CREATED="1570812148917" ID="ID_1136640650" MODIFIED="1570812152826" TEXT="einzeln abgeklärt"/>
|
|
<node CREATED="1570812156154" ID="ID_1286349242" MODIFIED="1570812160201" TEXT="potentiell gefährlich">
|
|
<node CREATED="1570812168060" ID="ID_572329221" MODIFIED="1570812347609" TEXT="buffhandle.hpp">
|
|
<linktarget COLOR="#6997ce" DESTINATION="ID_572329221" ENDARROW="Default" ENDINCLINATION="-312;0;" ID="Arrow_ID_558667540" SOURCE="ID_587624101" STARTARROW="None" STARTINCLINATION="241;-25;"/>
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1570812177483" ID="ID_684960114" MODIFIED="1570812180566" TEXT="im Moment sauber">
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1570812266492" ID="ID_156871602" MODIFIED="1570812291142">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Aber Vorsicht: es <b>wird noch gar nicht verwendet</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812221861" ID="ID_1839888193" MODIFIED="1570812227638" TEXT="siehe: usages of BufferProvider::buildHandle">
|
|
<node CREATED="1570812246800" ID="ID_447651236" MODIFIED="1570812246800" TEXT="TrackingHeapBlockProvider::provideLockedBuffer(HashVal typeID)">
|
|
<node CREATED="1570812260534" ID="ID_101354449" MODIFIED="1570812260534" TEXT="diagn::Block& newBlock = blocks.createBlock()"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812625135" ID="ID_688046161" MODIFIED="1570815492913" TEXT="typed-allocation-manager.hpp">
|
|
<linktarget COLOR="#ec5b9a" DESTINATION="ID_688046161" ENDARROW="Default" ENDINCLINATION="-281;28;" ID="Arrow_ID_789772576" SOURCE="ID_126301727" STARTARROW="None" STARTINCLINATION="117;-5;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1570812637077" ID="ID_1674717962" MODIFIED="1570812642972" TEXT="nicht fertig implementiert"/>
|
|
<node CREATED="1570812643428" ID="ID_1631975143" MODIFIED="1576282357910" TEXT="die gegenwärtige dummy-Implementierung ist nicht korrekt">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
typed-allocation-manager.hpp 217
|
|
</p>
|
|
<p>
|
|
dumme Heap-Allokation eines char[]
|
|
</p>
|
|
<p>
|
|
!!!!!11!!
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812308345" FOLDED="true" ID="ID_595212266" MODIFIED="1582333970566" TEXT="Review">
|
|
<icon BUILTIN="bell"/>
|
|
<node CREATED="1570812319615" ID="ID_587624101" MODIFIED="1570812352560" TEXT="buffhandle.hpp">
|
|
<arrowlink COLOR="#6997ce" DESTINATION="ID_572329221" ENDARROW="Default" ENDINCLINATION="-312;0;" ID="Arrow_ID_558667540" STARTARROW="None" STARTINCLINATION="241;-25;"/>
|
|
<node CREATED="1570812358786" ID="ID_1531404447" MODIFIED="1570812369421" TEXT="2019-10">
|
|
<node CREATED="1570812369993" ID="ID_1647231897" MODIFIED="1570812373524" TEXT="noch nicht verwendet"/>
|
|
<node CREATED="1570812373920" ID="ID_1210803090" MODIFIED="1570812385603" TEXT="Testcode (TrackingHeapBlockProvider) sauber"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1570812625135" ID="ID_126301727" MODIFIED="1570815492913" TEXT="typed-allocation-manager.hpp">
|
|
<arrowlink COLOR="#ec5b9a" DESTINATION="ID_688046161" ENDARROW="Default" ENDINCLINATION="-281;28;" ID="Arrow_ID_789772576" STARTARROW="None" STARTINCLINATION="117;-5;"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1570812925966" ID="ID_1900314792" MODIFIED="1570812931345" TEXT="2019-10">
|
|
<node CREATED="1570812637077" ID="ID_971741566" MODIFIED="1570812642972" TEXT="nicht fertig implementiert"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1447567193361" FOLDED="true" ID="ID_661445245" MODIFIED="1561311629097" TEXT="premature optimization">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
<node CREATED="1447566743461" ID="ID_1971297499" LINK="http://issues.lumiera.org/ticket/973" MODIFIED="1557498707243">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Probleme mit der Compile-Reihenfolge  <font color="#d41807">#973</font>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1477665256799" FOLDED="true" ID="ID_685276209" MODIFIED="1557498707243" TEXT="Ärger">
|
|
<icon BUILTIN="smily_bad"/>
|
|
<node CREATED="1477665276421" ID="ID_714740974" MODIFIED="1557498707243" TEXT="dlclose #1034">
|
|
<node CREATED="1477665304137" ID="ID_65862146" MODIFIED="1557498707243" TEXT="Assertion, da Library nicht entladen werden kann">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1477665320934" ID="ID_1841226938" MODIFIED="1557498707243" TEXT="LD_DEBUG=all NOBUG_LOG=pluginloader_dbg:TRACE 2>&1 target/lumiera | c++filt >weia">
|
|
<node CREATED="1477665330317" ID="ID_1760958407" MODIFIED="1557498707243" TEXT="weitere Untersuchung notwendig....">
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1521963965164" FOLDED="true" ID="ID_1027875371" MODIFIED="1561238596029" TEXT="komplexe Probleme">
|
|
<icon BUILTIN="go"/>
|
|
<node COLOR="#435e98" CREATED="1522025948980" ID="ID_295336770" MODIFIED="1557498707243" TEXT="3/2018">
|
|
<node COLOR="#338800" CREATED="1521964015114" FOLDED="true" ID="ID_1116388701" MODIFIED="1561238584135" TEXT="CallQueue_test">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
TEST Dispatch functors into other threads: CallQueue_test .. FAILED
|
|
</p>
|
|
<p>
|
|
unexpected return value 134, expected 0
|
|
</p>
|
|
<p>
|
|
stderr was:
|
|
</p>
|
|
<p>
|
|
0000000459: INFO: suite.cpp:180: thread_1: invokeTestCase: ++------------------- invoking TEST: CallQueue_test
|
|
</p>
|
|
<p>
|
|
0000003117: CHECK: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: (globalProducerSum == globalConsumerSum)
|
|
</p>
|
|
<p>
|
|
0000003127: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: /Werk/devel/lumi/target/modules/libtest-basics.so(_ZN3lib4test14CallQueue_test19verify_ThreadSafetyEv+0x24a) [0x7fdfce328a20]
|
|
</p>
|
|
<p>
|
|
0000003128: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: /Werk/devel/lumi/target/modules/libtest-basics.so(_ZN3lib4test14CallQueue_test3runERSt6vectorISsSaISsEE+0x34) [0x7fdfce32764e]
|
|
</p>
|
|
<p>
|
|
0000003129: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: /Werk/devel/lumi/target/modules/liblumierasupport.so(+0x1d7cb0) [0x7fdfcb7dfcb0]
|
|
</p>
|
|
<p>
|
|
0000003130: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: /Werk/devel/lumi/target/modules/liblumierasupport.so(_ZN4test5Suite3runERSt6vectorISsSaISsEE+0x38f) [0x7fdfcb7e0249]
|
|
</p>
|
|
<p>
|
|
0000003131: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: ./test-suite() [0x40625e]
|
|
</p>
|
|
<p>
|
|
0000003132: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf5) [0x7fdfc9029b45]
|
|
</p>
|
|
<p>
|
|
0000003133: BACKTRACE: call-queue-test.cpp:251: thread_1: verify_ThreadSafety: ./test-suite() [0x4060a9]
|
|
</p>
|
|
<p>
|
|
END
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1522025982759" ID="ID_1830638050" MODIFIED="1522025987194" TEXT="reproduzierbar....">
|
|
<node CREATED="1522025990246" ID="ID_261366619" MODIFIED="1544310845450" TEXT="Auf mehreren Terminals x-mal starten">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
for I in `seq 1 50`; do target/test-suite CallQueue_test; done
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1522026027993" ID="ID_25191931" MODIFIED="1522026034036" TEXT="Anhaltspunkte">
|
|
<node CREATED="1522026034720" ID="ID_584589060" MODIFIED="1544310845469" TEXT="erstmals beobachtet unter starker System-Last">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
habe gleichzeitig erst die Testsuite gebaut mit -j 36 und dann laufen lassen.
|
|
</p>
|
|
<p>
|
|
Gleichzeitig aber auch noch das ./build-website-Skript
|
|
</p>
|
|
<p>
|
|
und eine Doxygen-Seite im Browser geladen
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1521963972811" ID="ID_1942164320" MODIFIED="1522029864550" TEXT="hab ich da was mit dem ThreadWrapper kaputt gemacht?">
|
|
<icon BUILTIN="stop-sign"/>
|
|
<node CREATED="1522026114725" ID="ID_288423678" MODIFIED="1522026122240" TEXT="hatte kurz vorher den ThreadWrapper modernisiert"/>
|
|
<node CREATED="1522026122756" ID="ID_1246030370" MODIFIED="1522026127927" TEXT="und gebe nun ein Lambda durch"/>
|
|
<node CREATED="1522026128467" ID="ID_387844871" MODIFIED="1522026139087" TEXT="verwende dabei aber perfect-forwarding-Tricks">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522029869047" ID="ID_221734956" MODIFIED="1522029880963" TEXT="Anwort: vermutlich NEIN">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522026152280" ID="ID_156370463" MODIFIED="1522030023168" TEXT="anderer Verdacht: Objekt-Initialisierung">
|
|
<icon BUILTIN="back"/>
|
|
<node CREATED="1522026166734" ID="ID_731765048" MODIFIED="1522030021122" TEXT="das bekannte Problem"/>
|
|
<node CREATED="1522026170781" ID="ID_1581699734" MODIFIED="1522030021122" TEXT="der Thread läuft schon"/>
|
|
<node CREATED="1522026178860" ID="ID_917574124" MODIFIED="1522030021122" TEXT="aber das abgeleitete Objekt ist noch nicht so weit"/>
|
|
<node CREATED="1522029908986" ID="ID_1350487644" MODIFIED="1522030029028" TEXT="Jupp. Dat warsz">
|
|
<icon BUILTIN="idea"/>
|
|
<node CREATED="1522029922592" ID="ID_301766693" MODIFIED="1522030021122" TEXT="Barriere eingebaut"/>
|
|
<node CREATED="1522029928983" ID="ID_761637509" MODIFIED="1544310845562" TEXT="ist auch sinnvoll vom Testdesgin her">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
weil sich die Threads gegenseitig ihre Counter inkrementieren.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1522029979544" ID="ID_1820534569" MODIFIED="1522030021122" TEXT="Streßtest wiederholt, sogar mit 500 Thrads"/>
|
|
<node COLOR="#338800" CREATED="1522029995205" ID="ID_556688250" MODIFIED="1522030021122" TEXT="jetzt reproduzierbar alles sauber">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522030032424" ID="ID_1791738866" MODIFIED="1522030091201" TEXT="Problem war fehlende Barriere nach Objekt-Initialisierung">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1522030047375" ID="ID_1979180035" MODIFIED="1544310845583" TEXT="alle anderen multithreaded-Tests durchgeprüft">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
alle anderen (mit Ausnahme von BusTerm_test)
|
|
</p>
|
|
<p>
|
|
verwenden globale Variable oder überhaupt keine Objektfelder
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664730709910" FOLDED="true" ID="ID_532850171" MODIFIED="1664731043947" TEXT="Performance">
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664730715885" ID="ID_1774914566" MODIFIED="1664731036535" TEXT="GUI">
|
|
<arrowlink COLOR="#6e6b89" DESTINATION="ID_580266574" ENDARROW="Default" ENDINCLINATION="-1072;126;" ID="Arrow_ID_1760515184" STARTARROW="None" STARTINCLINATION="-1832;638;"/>
|
|
<icon BUILTIN="hourglass"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1664728069849" ID="ID_499807590" MODIFIED="1664730778937" TEXT="#1240 evaluate performance of ElementBoxWidget">
|
|
<arrowlink COLOR="#652a49" DESTINATION="ID_1113493685" ENDARROW="Default" ENDINCLINATION="-1026;116;" ID="Arrow_ID_1663742451" STARTARROW="None" STARTINCLINATION="-985;55;"/>
|
|
<icon BUILTIN="bell"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664730718511" ID="ID_1773381955" MODIFIED="1664730727367" TEXT="Engine">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#d2beaf" COLOR="#5c4d6e" CREATED="1664730722868" ID="ID_1536097796" MODIFIED="1664730727368" TEXT="Session">
|
|
<icon BUILTIN="hourglass"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561238618311" ID="ID_1197206022" MODIFIED="1561311521089" TEXT="Plattform-Evolution">
|
|
<icon BUILTIN="go"/>
|
|
<node COLOR="#435e98" CREATED="1561238627847" ID="ID_776424925" MODIFIED="1561311477641" TEXT="Juni 2019">
|
|
<node COLOR="#338800" CREATED="1561238635358" FOLDED="true" ID="ID_584004962" MODIFIED="1561311515592" TEXT="Ubuntu/Bionic - libboost 1.65">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
angeregt durch Gabriel;
|
|
</p>
|
|
<p>
|
|
er wollte "versuchen, Lumiera zu bauen"
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<linktarget COLOR="#37aea5" DESTINATION="ID_584004962" ENDARROW="Default" ENDINCLINATION="295;-171;" ID="Arrow_ID_1368108105" SOURCE="ID_1588960225" STARTARROW="None" STARTINCLINATION="247;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561237854717" FOLDED="true" ID="ID_682831433" MODIFIED="1561237893434" TEXT="boost::rational">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561237861421" ID="ID_575082452" MODIFIED="1561237891854" TEXT="erlaubt keine implizite signed/unsigned-conversion mehr">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561237876778" ID="ID_1489512347" MODIFIED="1561237888193" TEXT="gefixt bzw. eignen Operator für 1/fps definiert"/>
|
|
</node>
|
|
<node COLOR="#990000" CREATED="1561237894664" ID="ID_1271023428" MODIFIED="1561303718736" TEXT="CommandEquality_test scheitert">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1561237929923" ID="ID_1722173317" MODIFIED="1561237932732" TEXT="command-equality-test.cpp:169: thread_1: verifyMutationEquality: (mut_u0 != umu) ">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1561237934707" ID="ID_103532516" MODIFIED="1561238024555" TEXT="waren bisher ungleich wegen empty vs undef">
|
|
<node CREATED="1561238043825" ID="ID_1552996851" MODIFIED="1561238050167" TEXT="umo -> empty operation function"/>
|
|
<node CREATED="1561238050854" ID="ID_1689917500" MODIFIED="1561238066157" TEXT="mut_u0 -> empty UNDO function"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561238068215" ID="ID_506567611" MODIFIED="1561293990008" TEXT="war das bisherige Verhalten korrekt?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1561293701116" ID="ID_755823260" MODIFIED="1561293974672">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
wann sind Funktoren <i>äquivalent</i> ??
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
<u>mathematisch gilt</u>:
|
|
</p>
|
|
<p>
|
|
sie sind gleich, wenn sie für alle gleichen Argumente das gleiche Resultat liefern.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
<i>sei die Dose offen...</i>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1561293746047" ID="ID_1685820592" MODIFIED="1561293763727" TEXT="ich hatte da einen Hack im Einsatz">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1561293766313" ID="ID_503430163" MODIFIED="1561293901354" TEXT="std::function hat das Thema letztlich abgebogen">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
in tr1::functional war ein equality-Operator spezifiziert
|
|
</p>
|
|
<p>
|
|
boost::function hat sich geweigert diesen zu implementieren,
|
|
</p>
|
|
<p>
|
|
weil es keine vernünftige und konsistente Implementierung gibt.
|
|
</p>
|
|
<p>
|
|
|
|
</p>
|
|
<p>
|
|
Für den C++11 - Standard hat man dann einen Kompromiß geschlossen,
|
|
</p>
|
|
<p>
|
|
demnach der Vergleich mit einem NULLPTR sinnvoll (und implementierbar) ist,
|
|
</p>
|
|
<p>
|
|
aber ansonsten alle <i>validen definierten</i> Funktionen untereinander verschieden sind.
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="smiley-oh"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1561293905972" ID="ID_1691379411" MODIFIED="1561294054085" TEXT="Fazit: std::function ist nur partiell geordnet">
|
|
<arrowlink COLOR="#3044e4" DESTINATION="ID_1015641085" ENDARROW="Default" ENDINCLINATION="51;-54;" ID="Arrow_ID_44253813" STARTARROW="None" STARTINCLINATION="-282;0;"/>
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561294009342" ID="ID_1015641085" MODIFIED="1561311468701" TEXT="#294 re-evaluate command equality comparisons">
|
|
<linktarget COLOR="#3044e4" DESTINATION="ID_1015641085" ENDARROW="Default" ENDINCLINATION="51;-54;" ID="Arrow_ID_44253813" SOURCE="ID_1691379411" STARTARROW="None" STARTINCLINATION="-282;0;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1561294074429" ID="ID_1155061172" MODIFIED="1561294082271" TEXT="sinnvoller use-case?">
|
|
<node CREATED="1561294111368" ID="ID_550692627" MODIFIED="1561294116011" TEXT="bisher nur isValid()">
|
|
<node CREATED="1561294121390" ID="ID_1554085271" MODIFIED="1561294146172" TEXT="»ist aktiviert und beruht auf dem "gleichen" backend«">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="12"/>
|
|
</node>
|
|
<node CREATED="1561294154669" ID="ID_1700157755" MODIFIED="1561294165145" TEXT="und das backend wurde bisher...">
|
|
<node CREATED="1561294165894" ID="ID_504595200" MODIFIED="1561294171982" TEXT="auf gleiche Storage-Location"/>
|
|
<node CREATED="1561294172366" ID="ID_1176454147" MODIFIED="1561294188932">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sonst auf <i>Äquivalenz</i> getestet
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561294190088" ID="ID_1198524028" MODIFIED="1561294221209">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
und genau das Letztere ist nicht <b>garantiert korrekt</b> implementierbar
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1561294330073" ID="ID_608542803" MODIFIED="1561294340821" TEXT="Commands haben Referenz-Symantik">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1561294342041" ID="ID_260507058" MODIFIED="1561294357179" TEXT="und der Äquivalenz-Begriff gehört ehr zur Wert-Semantik"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#ccb59b" COLOR="#6e2a38" CREATED="1561294361678" ID="ID_979058533" MODIFIED="1561294387317" TEXT="Äquivalenz von Commands erscheint verzichtbar">
|
|
<font ITALIC="true" NAME="SansSerif" SIZE="14"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1561294395962" ID="ID_100338820" MODIFIED="1561294403572" TEXT="in der Praxis arbeitet man mit Command-IDs."/>
|
|
<node CREATED="1561294404352" ID="ID_499417243" MODIFIED="1561294455506">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
Selbst verschiedene Closures haben selbst die noch eine eindeutige <b>Identität</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561294470021" FOLDED="true" ID="ID_1846241113" MODIFIED="1561311466135" TEXT="totmachen">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561295990811" ID="ID_224001495" MODIFIED="1561296000279" TEXT="Äquivalenz-Check abklemmen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1561296000882" ID="ID_1788095213" MODIFIED="1561303690659" TEXT="2 Tests scheitern">
|
|
<node COLOR="#338800" CREATED="1561296072919" ID="ID_1173741195" MODIFIED="1561302966818" TEXT="CommandRegistry_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561296078403" ID="ID_15228506" MODIFIED="1561303686355" TEXT="CommandUse1_test">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561305344531" ID="ID_1797228597" MODIFIED="1561308173677" TEXT="Funktion hash_value aufgeben">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#435e98" CREATED="1561305360584" ID="ID_503655811" MODIFIED="1561308153571" TEXT="TypeHandler für BufferMetadata">
|
|
<node CREATED="1561305394029" ID="ID_1225221352" MODIFIED="1561305409873" TEXT="definiert eine Art Buffer-Typ"/>
|
|
<node CREATED="1561305410256" ID="ID_1164668948" MODIFIED="1561305416889" TEXT="basiert bisher auf dem konkreten Handler"/>
|
|
<node CREATED="1561305428408" ID="ID_1356896886" MODIFIED="1561305452650" TEXT="kann man hier auch das Identitägs-Argument anwenden?">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
d.h. wir brauchen keine Äquivalenz?
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1561305463577" ID="ID_1519337489" MODIFIED="1561305477381" TEXT="folglich wäre jeder TypeHandler ein Unikat"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561308051917" ID="ID_914530129" MODIFIED="1561308171779" TEXT="pragmatische Lösung: Type-ID">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node COLOR="#338800" CREATED="1561308061204" ID="ID_1554244425" MODIFIED="1561308168325" TEXT="verwende die typeid(TY) der Funktoren">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1561308078902" ID="ID_430150773" MODIFIED="1561308091311" TEXT="kann in's Auge gehn">
|
|
<icon BUILTIN="clanbomber"/>
|
|
<node CREATED="1561308093797" ID="ID_553457078" MODIFIED="1561308135247" TEXT="wenn jemand eine std::function<void(void)> direkt speichert">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
</node>
|
|
<node CREATED="1561308115205" ID="ID_1743532708" MODIFIED="1561308132530" TEXT="Regel ist aber TypeHandler::create<TY>()">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561296009625" ID="ID_617134183" MODIFIED="1561311456970" TEXT="alle Vergleichs-Operatoren auf Command-Funktor-Ebene zurückbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561296029622" ID="ID_696325144" MODIFIED="1561311458435" TEXT="die rawComparison zurückbauen">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1561296041852" ID="ID_1450999034" MODIFIED="1561311460017" TEXT="Doku aktualisieren">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#990000" CREATED="1446356368070" HGAP="-38" ID="ID_768449868" MODIFIED="1582333957320" TEXT="Au Au" VSHIFT="196">
|
|
<edge COLOR="#c14b4b" STYLE="sharp_bezier"/>
|
|
<icon BUILTIN="broken-line"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544239377061" FOLDED="true" ID="ID_1224449803" MODIFIED="1582494287885" TEXT="GUI-Start not yet failsafe">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node COLOR="#435e98" CREATED="1544239394777" ID="ID_626803835" MODIFIED="1557498707243" TEXT="aufgedeckt durch fehlende UI-Resourcen">
|
|
<linktarget COLOR="#7f244b" DESTINATION="ID_626803835" ENDARROW="Default" ENDINCLINATION="193;-461;" ID="Arrow_ID_65546348" SOURCE="ID_1906746912" STARTARROW="None" STARTINCLINATION="421;19;"/>
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
<node CREATED="1544239428238" ID="ID_1011459246" MODIFIED="1557498707243" TEXT="wie konnte das passieren....?">
|
|
<icon BUILTIN="smily_bad"/>
|
|
</node>
|
|
<node CREATED="1544239443516" ID="ID_1433396809" MODIFIED="1557498707243" TEXT="ich hatte doch die ganze Sequenz geprüft?!"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1544239461493" ID="ID_138383314" MODIFIED="1557498707243" TEXT="catch-Block sitzt nicht richtig">
|
|
<arrowlink COLOR="#e02825" DESTINATION="ID_478753729" ENDARROW="Default" ENDINCLINATION="-3550;0;" ID="Arrow_ID_390741072" STARTARROW="None" STARTINCLINATION="-1804;756;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544240822252" ID="ID_110235945" MODIFIED="1582493900730" TEXT="#1192 Lumiera hangs on failed GUI start">
|
|
<arrowlink COLOR="#e5221e" DESTINATION="ID_1795051800" ENDARROW="Default" ENDINCLINATION="-1916;0;" ID="Arrow_ID_127697886" STARTARROW="None" STARTINCLINATION="-716;43;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1582493761032" ID="ID_1071108928" LINK="https://issues.lumiera.org/ticket/1177" MODIFIED="1582493774585" TEXT=" #1177 Subsytem-Runner design rework ">
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1544310988414" FOLDED="true" ID="ID_134908056" MODIFIED="1557498707243" TEXT="ProcDispatcher macht idle-Loop">
|
|
<arrowlink COLOR="#ce3649" DESTINATION="ID_71855569" ENDARROW="Default" ENDINCLINATION="105;0;" ID="Arrow_ID_1871191743" STARTARROW="None" STARTINCLINATION="181;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1544311004661" ID="ID_1064987345" MODIFIED="1544311012720" TEXT="Symptom: CPU-Last im Ruhezustand"/>
|
|
<node CREATED="1544311014140" ID="ID_392351205" MODIFIED="1544320819468" TEXT="Grund: fällt sofort wieder aus timed wait">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544311029042" ID="ID_15647077" MODIFIED="1544320803272" TEXT="Ursache: Sync.hpp -- Timeout-Struct nicht korrekt initialisiert">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544311051503" ID="ID_1872128038" MODIFIED="1544311082817" TEXT="bool-Operator vergleicht auf 0">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544311064725" ID="ID_1179966941" MODIFIED="1544311079804" TEXT="finde aber im Debugger irgendwelche Werte.">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1544320706921" ID="ID_50250235" MODIFIED="1544320717897" TEXT="genauer: Werte werden nicht aufgeräumt">
|
|
<node CREATED="1544320719053" ID="ID_1185228058" MODIFIED="1544320755043" TEXT="Konvention ist: sekunden == 0 ==> kein Timeout">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544320761671" ID="ID_1421942136" MODIFIED="1544320772577" TEXT="pthread findet timeout in der Vergangenheit"/>
|
|
<node CREATED="1544320773286" ID="ID_256879540" MODIFIED="1544320782737" TEXT="...und kehr damit sofort zurück aus dem wait">
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544320791339" ID="ID_536822312" MODIFIED="1544320800480" TEXT="Fix: else-Zweig, reset()">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#435e98" CREATED="1544328974221" FOLDED="true" ID="ID_71855569" MODIFIED="1557498707243" TEXT="ProcDispatcher bleibt hängen">
|
|
<linktarget COLOR="#ce3649" DESTINATION="ID_71855569" ENDARROW="Default" ENDINCLINATION="105;0;" ID="Arrow_ID_1871191743" SOURCE="ID_134908056" STARTARROW="None" STARTINCLINATION="181;0;"/>
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1544329099419" ID="ID_1105978437" MODIFIED="1544329164023" TEXT="SessionCommandFunction_test">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
sporadich, nicht bei jedem Lauf, aber reproduzierbar.
|
|
</p>
|
|
<p>
|
|
Bleibt hängen an der Stelle, wo der Test den Dispatcher vorübergehend deaktiviert,
|
|
</p>
|
|
<p>
|
|
und dann auf den Deaktiviert-Zustand <b>wartet</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544329167436" ID="ID_739717124" MODIFIED="1544329363509" TEXT="Problem mit der Zustands-Logik">
|
|
<icon BUILTIN="messagebox_warning"/>
|
|
<node CREATED="1544329192703" ID="ID_1013421079" MODIFIED="1544329202330" TEXT="deaktivert bedeutet requireAction() == false"/>
|
|
<node CREATED="1544329202903" ID="ID_1019916123" MODIFIED="1544329356857" TEXT="und dadurch warten wir ohne Timeout">
|
|
<icon BUILTIN="broken-line"/>
|
|
<node CREATED="1544329280619" ID="ID_1784122176" MODIFIED="1544329348875" TEXT="und durch den Bug in lib::Sync wurde das nicht wirksam">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...weil der Objekt-Monitor nicht mehr bedingungslos gewartet hat,
|
|
</p>
|
|
<p>
|
|
nachdem <i>einmal</i> ein wait mit Timeout verwendet worden war
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="ksmiletris"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544329216228" ID="ID_422426535" MODIFIED="1544329234043">
|
|
<richcontent TYPE="NODE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
aber <b>inChange</b> bleibt <b>true</b>
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
</node>
|
|
<node CREATED="1544329235934" ID="ID_605336452" MODIFIED="1544329273933" TEXT="...und darauf wartet die äußere Hülle">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544329367261" ID="ID_50498392" MODIFIED="1544386159034" TEXT="Lösungen" VGAP="15">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544329727165" FOLDED="true" ID="ID_1043095728" MODIFIED="1544386423962" TEXT="requireAction() == true auch wenn disabled">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1544329753698" ID="ID_1588685067" MODIFIED="1544329760502" TEXT="geht nicht.">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
<node CREATED="1544329764640" ID="ID_706638200" MODIFIED="1544329781788" TEXT="denn dann kommen wir nicht mehr in den wait-state">
|
|
<icon BUILTIN="info"/>
|
|
</node>
|
|
<node CREATED="1544329793943" ID="ID_1668546000" MODIFIED="1544329822612" TEXT="requireAction wird ja als Condition für den Wait verwendet">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544329372318" FOLDED="true" ID="ID_88425113" MODIFIED="1544386423070" TEXT="inChange nur setzen wenn requireAction() == true">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544329663574" ID="ID_565123980" MODIFIED="1544332799520" TEXT="Verdacht: kann dann trotzdem per Timeout aufwachen">
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
<node CREATED="1544329684707" ID="ID_651175391" MODIFIED="1544329708068" TEXT="und dann wäre inChange == false, obwohl wir arbeiten (Builder läuft)"/>
|
|
<node BACKGROUND_COLOR="#fdfdcf" COLOR="#ff0000" CREATED="1544332821150" ID="ID_484338481" MODIFIED="1544332874097" TEXT="fatale Konsequenzen....">
|
|
<richcontent TYPE="NOTE"><html>
|
|
<head>
|
|
|
|
</head>
|
|
<body>
|
|
<p>
|
|
...es könnte dann nämlich die Session geschlossen und freigegeben werden,
|
|
</p>
|
|
<p>
|
|
obwohl noch der Builder läuft
|
|
</p>
|
|
</body>
|
|
</html></richcontent>
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
<node CREATED="1544332907967" ID="ID_760793562" MODIFIED="1544332932033" TEXT="Analyse: kann das passieren?">
|
|
<icon BUILTIN="help"/>
|
|
<node CREATED="1544332934619" ID="ID_558823055" MODIFIED="1544333038537" TEXT="Fall: disabled-setzen während dem Timeout">
|
|
<node CREATED="1544333050044" ID="ID_318735401" MODIFIED="1544333066940" TEXT="Timeout eingetreten ==> requireAction war false"/>
|
|
<node CREATED="1544333069881" ID="ID_555896336" MODIFIED="1544333084882" TEXT="nach geänderter Logik wäre dann auch inChange == false"/>
|
|
<node CREATED="1544333087958" ID="ID_1209619554" MODIFIED="1544333108407" TEXT="Folglich wird fälschlicherweise nicht gewartet"/>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544333135104" ID="ID_549018822" MODIFIED="1544333155423" TEXT="Antwort: ja das kann passieren">
|
|
<icon BUILTIN="back"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544333313167" ID="ID_1694353778" MODIFIED="1544333323414" TEXT="damit ist diese Lösung hinfällig">
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544333328341" FOLDED="true" ID="ID_349762653" MODIFIED="1544386421940" TEXT="inChange unabhängig von requireAction() machen">
|
|
<icon BUILTIN="button_cancel"/>
|
|
<node CREATED="1544333344379" ID="ID_1647118494" MODIFIED="1544333369026" TEXT="eigene Methode, die aufgerufen wird, wenn wir aus dem wait() rauskommen"/>
|
|
<node CREATED="1544333456987" ID="ID_585691817" MODIFIED="1544333897248" TEXT="könnte gehen, erscheint mir aber gefährlich">
|
|
<icon BUILTIN="help"/>
|
|
<icon BUILTIN="yes"/>
|
|
<node CREATED="1544333510982" ID="ID_1431407168" MODIFIED="1544333516439" TEXT="was ist wenn....">
|
|
<node CREATED="1544333517379" ID="ID_689738064" MODIFIED="1544333533684" TEXT="disabled gesetzt wird, während wir im wait() sind?">
|
|
<node CREATED="1544333550151" ID="ID_100143787" MODIFIED="1544333556410" TEXT="dann ist inChange == false"/>
|
|
<node CREATED="1544333610495" ID="ID_942332687" MODIFIED="1544333626888" TEXT="aber deactivateCommandProecssing() -> notifyAll()"/>
|
|
<node CREATED="1544333630018" ID="ID_1936407440" MODIFIED="1544333636367" TEXT="noch während er das Lock hat"/>
|
|
<node CREATED="1544333723957" ID="ID_1134715607" MODIFIED="1544333742040" TEXT="sobald er das Lock aufgibt, wacht der Loop-Thread auf"/>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544333778756" ID="ID_705117923" MODIFIED="1544333804986" TEXT="gibt dann aber auch das Lock auf, bevor er inChange setzen kann">
|
|
<icon BUILTIN="broken-line"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1544333809035" ID="ID_1284134914" MODIFIED="1544333881455" TEXT="möglicher Race">
|
|
<linktarget COLOR="#a9b4c1" DESTINATION="ID_1284134914" ENDARROW="Default" ENDINCLINATION="-26;57;" ID="Arrow_ID_662106184" SOURCE="ID_151622227" STARTARROW="None" STARTINCLINATION="159;0;"/>
|
|
<icon BUILTIN="clanbomber"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544333819034" ID="ID_151622227" MODIFIED="1544333881455" TEXT="Lösung hinfällig, wegen potentiellem Race">
|
|
<arrowlink DESTINATION="ID_1284134914" ENDARROW="Default" ENDINCLINATION="-26;57;" ID="Arrow_ID_662106184" STARTARROW="None" STARTINCLINATION="159;0;"/>
|
|
<icon BUILTIN="stop-sign"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544333909701" ID="ID_328876957" MODIFIED="1544386156765" STYLE="fork" TEXT="inChange in requireAction() setzen, aber logisch präzise">
|
|
<icon BUILTIN="button_ok"/>
|
|
<node CREATED="1544333933346" ID="ID_593273191" MODIFIED="1544386155027" TEXT="d.h. nur wenn nicht warten und kein Timeout"/>
|
|
<node CREATED="1544381554267" ID="ID_193163875" MODIFIED="1544386155027" TEXT="Zustand nur einmal in die Flags übernhmen, zu Beginn"/>
|
|
<node CREATED="1544382733514" ID="ID_1386275063" MODIFIED="1544386155027" TEXT="Trick mit dem Countdown auf isDirty_ zurückbauen"/>
|
|
</node>
|
|
</node>
|
|
<node CREATED="1544386177470" ID="ID_1764197819" MODIFIED="1544386413663" TEXT="erst jetzt sehe ich das erwartete Builder-Verhalten">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node CREATED="1544386386938" ID="ID_1316391277" MODIFIED="1544386416510" TEXT="und der SessionCommandFunction_test bleibt nicht mehr hängen">
|
|
<icon BUILTIN="idea"/>
|
|
</node>
|
|
<node COLOR="#338800" CREATED="1544386406767" ID="ID_789739914" MODIFIED="1544386410583" TEXT="problem solved">
|
|
<icon BUILTIN="button_ok"/>
|
|
</node>
|
|
</node>
|
|
<node BACKGROUND_COLOR="#eee5c3" COLOR="#990000" CREATED="1570817474883" ID="ID_711013238" MODIFIED="1570817537392" TEXT="#1205 Advice data possibly misaligned">
|
|
<arrowlink COLOR="#cd4467" DESTINATION="ID_1779912405" ENDARROW="Default" ENDINCLINATION="296;20;" ID="Arrow_ID_1125835000" STARTARROW="None" STARTINCLINATION="462;0;"/>
|
|
<icon BUILTIN="flag-yellow"/>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</node>
|
|
</map>
|