-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
99 lines (86 loc) · 3.27 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title>interrupt</title>
<link rel="stylesheet" href="css/reveal.css">
<link rel="stylesheet" href="css/theme/black.css">
<!-- Theme used for syntax highlighting of code -->
<link rel="stylesheet" href="lib/css/zenburn.css">
<!-- Printing and PDF exports -->
<script>
var link = document.createElement( 'link' );
link.rel = 'stylesheet';
link.type = 'text/css';
link.href = window.location.search.match( /print-pdf/gi ) ? 'css/print/pdf.css' : 'css/print/paper.css';
document.getElementsByTagName( 'head' )[0].appendChild( link );
</script>
</head>
<body>
<div class="reveal">
<div class="slides">
<section>
<h2>Interrupt Chat</h2>
<p>"Realtime" interruptible chatting in the terminal</p>
</section>
<section>
<h3>Idea</h3>
kind of like speech rather than im/zulip/email in that...
<ul>
<li class="fragment">what you say is observed by others as its produced</li>
<li class="fragment">people can interrupt one another</li>
<li class="fragment">what you say doesn't stay observable for long</li>
<li class="fragment">(so you have to listen and pay attention)</li>
</ul>
</section>
<section>
<h3>want</h3>
<ul>
<li class="fragment">Immediacy: see what you type right away</li>
<li class="fragment">Consistency: everyone should see the same thing</li>
<li class="fragment">Integrity: reports of what you typed don't alter</li>
</ul>
<p class="fragment">(some sort of "ici thoerem": can't have all of these)</p>
</section>
<section>
video...
<video data-autoplay class="stretch" src="https://raw.githubusercontent.com/bebebebebe/presentation-chat/gh-pages/assets/interrupt_clip.mov"></video>
</section>
<section>
How it works
<ul>
<li class="fragment">client terminal: raw mode without echo</li>
<li class="fragment">UDP sockets</li>
<li class="fragment">client sends each keypress with timestamp to server</li>
<li class="fragment">server checks timestamp, ignores old from client</li>
<li class="fragment">server updates state: recent chat, names, speaker</li>
<li class="fragment">server updates all clients with new state</li>
<li class="fragment">client checks timestamp, ignores old from server</li>
<li class="fragment"> client updates terminal with new state</li>
</ul>
</section>
<section>
<p>Live Demo...</p>
<p>Thanks!<p>
<p>project github: https://github.com/bebebebebe/Interrupt</p>
</section>
</div>
</div>
<script src="lib/js/head.min.js"></script>
<script src="js/reveal.js"></script>
<script>
// More info https://github.com/hakimel/reveal.js#configuration
Reveal.initialize({
history: true,
// More info https://github.com/hakimel/reveal.js#dependencies
dependencies: [
{ src: 'plugin/markdown/marked.js' },
{ src: 'plugin/markdown/markdown.js' },
{ src: 'plugin/notes/notes.js', async: true },
{ src: 'plugin/highlight/highlight.js', async: true, callback: function() { hljs.initHighlightingOnLoad(); } }
]
});
</script>
</body>
</html>