Spaces:
Runtime error
Runtime error
infill mask and more infill examples
Browse files- static/index.html +92 -32
static/index.html
CHANGED
|
@@ -101,16 +101,22 @@ label {
|
|
| 101 |
width: 100%;
|
| 102 |
height: 400px;
|
| 103 |
}
|
|
|
|
|
|
|
|
|
|
| 104 |
</style>
|
| 105 |
<body>
|
| 106 |
<div class="header">
|
| 107 |
<h1>InCoder</h1>
|
| 108 |
</div
|
| 109 |
<div id="about">
|
| 110 |
-
<p>"Extend" will insert text at the end. "Infill" will replace all
|
| 111 |
<p id="examples">
|
| 112 |
<span style="font-weight: bold">Examples:</span>
|
| 113 |
<span><a href='javascript:select_example("python");'>Python</a></span>
|
|
|
|
|
|
|
|
|
|
| 114 |
<span><a href='javascript:select_example("javascript");'>JavaScript</a></span>
|
| 115 |
<span><a href='javascript:select_example("jupyter");'>Jupyter</a></span>
|
| 116 |
<span><a href='javascript:select_example("stackoverflow");'>StackOverflow</a></span>
|
|
@@ -179,7 +185,10 @@ Syntax:
|
|
| 179 |
<div class="submit-holder">
|
| 180 |
<!-- <input type="submit" value="Extend" id="extend-form-button"/> -->
|
| 181 |
<input type="button" value="Extend" id="extend-form-button"/>
|
|
|
|
|
|
|
| 182 |
<input type="button" value="Infill" id="infill-form-button"/>
|
|
|
|
| 183 |
<!--
|
| 184 |
<div>
|
| 185 |
<label for="extra_sentinel_checkbox">Infill: Extra sentinel</label>
|
|
@@ -208,24 +217,71 @@ Syntax:
|
|
| 208 |
</div>
|
| 209 |
</div>
|
| 210 |
|
| 211 |
-
<h3>Debug info</h3>
|
| 212 |
<p>
|
| 213 |
<script type="text/javascript">
|
| 214 |
// these constants are only used for providing user expectations.
|
| 215 |
var OVERHEAD = 3;
|
| 216 |
var PER_TOKEN = 0.12;
|
|
|
|
| 217 |
|
| 218 |
var Range = require("ace/range").Range;
|
| 219 |
|
| 220 |
// examples for the user
|
| 221 |
var EXAMPLES = {
|
| 222 |
"python": {
|
| 223 |
-
"prompt": "<| file ext=.py |>\
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 224 |
"length": 128,
|
| 225 |
"mode": "python"
|
| 226 |
},
|
| 227 |
"javascript": {
|
| 228 |
-
"prompt": "<| file ext=.js |>\n",
|
| 229 |
"length": 128,
|
| 230 |
"mode": "javascript"
|
| 231 |
},
|
|
@@ -259,7 +315,23 @@ var EXAMPLES = {
|
|
| 259 |
var editor = ace.edit("editor");
|
| 260 |
|
| 261 |
function set_editor_mode(mode) {
|
| 262 |
-
editor.session
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 263 |
}
|
| 264 |
|
| 265 |
/*
|
|
@@ -364,41 +436,27 @@ function convert_string_index_to_location(string_index, lines) {
|
|
| 364 |
}
|
| 365 |
|
| 366 |
function get_infill_parts() {
|
| 367 |
-
// todo: update this to handle multi-select
|
| 368 |
var lines = editor.getSession().doc.$lines;
|
| 369 |
var lines_flat = join_lines(lines);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 370 |
if (editor.selection.ranges.length > 1) {
|
| 371 |
-
var spans = [];
|
| 372 |
for (var i = 0; i < editor.selection.ranges.length; i++) {
|
| 373 |
-
|
| 374 |
-
|
| 375 |
-
var left = Math.min(start, end);
|
| 376 |
-
var right = Math.max(start, end);
|
| 377 |
-
spans.push({left: left, right: right});
|
| 378 |
}
|
| 379 |
-
spans.sort(function (a, b) { return a.left - b.left; });
|
| 380 |
-
var parts = [];
|
| 381 |
-
var last_right = 0;
|
| 382 |
-
for (var i = 0; i < spans.length; i++) {
|
| 383 |
-
var span = spans[i];
|
| 384 |
-
parts.push(lines_flat.substring(last_right, span.left));
|
| 385 |
-
last_right = span.right;
|
| 386 |
-
}
|
| 387 |
-
parts.push(lines_flat.substring(last_right));
|
| 388 |
-
return parts;
|
| 389 |
} else {
|
| 390 |
-
|
| 391 |
-
console.log(cursor);
|
| 392 |
-
var anchor = convert_location_to_string_index(editor.getSelection().anchor, lines);
|
| 393 |
-
var lead = convert_location_to_string_index(editor.getSelection().lead, lines);
|
| 394 |
-
var before = Math.min(anchor, lead);
|
| 395 |
-
var after = Math.max(anchor, lead);
|
| 396 |
-
var prefix = lines_flat.substring(0, before);
|
| 397 |
-
var suffix = lines_flat.substring(after);
|
| 398 |
-
return [prefix, suffix]
|
| 399 |
}
|
| 400 |
}
|
| 401 |
|
|
|
|
| 402 |
function make_generate_listener(url) {
|
| 403 |
return async function(event) {
|
| 404 |
var length = $("#length_slider").val();
|
|
@@ -480,13 +538,15 @@ function make_generate_listener(url) {
|
|
| 480 |
|
| 481 |
// actual logic
|
| 482 |
$(document).ready(function() {
|
|
|
|
| 483 |
$("#extend-form-button").click(make_generate_listener("generate"));
|
| 484 |
$("#infill-form-button").click(make_generate_listener("infill"));
|
| 485 |
$("#mode").change(function (e) {
|
| 486 |
var mode = $("#mode").val();
|
| 487 |
set_editor_mode(mode);
|
| 488 |
});
|
| 489 |
-
|
|
|
|
| 490 |
});
|
| 491 |
</script>
|
| 492 |
</body>
|
|
|
|
| 101 |
width: 100%;
|
| 102 |
height: 400px;
|
| 103 |
}
|
| 104 |
+
.ace_infill {
|
| 105 |
+
color: red;
|
| 106 |
+
}
|
| 107 |
</style>
|
| 108 |
<body>
|
| 109 |
<div class="header">
|
| 110 |
<h1>InCoder</h1>
|
| 111 |
</div
|
| 112 |
<div id="about">
|
| 113 |
+
<p>Refresh "Extend" will insert text at the end. "Infill" will replace all <infill> masks. (click add <infill> mask to add infill mask at the cursors or selections ) </p>
|
| 114 |
<p id="examples">
|
| 115 |
<span style="font-weight: bold">Examples:</span>
|
| 116 |
<span><a href='javascript:select_example("python");'>Python</a></span>
|
| 117 |
+
<span><a href='javascript:select_example("python-infill2");'>Python-infill</a></span>
|
| 118 |
+
<span><a href='javascript:select_example("type-pred");'>Type-prediction</a></span>
|
| 119 |
+
<span><a href='javascript:select_example("docstring");'>Doc-string</a></span>
|
| 120 |
<span><a href='javascript:select_example("javascript");'>JavaScript</a></span>
|
| 121 |
<span><a href='javascript:select_example("jupyter");'>Jupyter</a></span>
|
| 122 |
<span><a href='javascript:select_example("stackoverflow");'>StackOverflow</a></span>
|
|
|
|
| 185 |
<div class="submit-holder">
|
| 186 |
<!-- <input type="submit" value="Extend" id="extend-form-button"/> -->
|
| 187 |
<input type="button" value="Extend" id="extend-form-button"/>
|
| 188 |
+
<span style='margin-left:1em'>
|
| 189 |
+
<input type="button" value="Add <infill> mask" id="insert-mask-button" title="add the infill marker at cursor or selection"/>
|
| 190 |
<input type="button" value="Infill" id="infill-form-button"/>
|
| 191 |
+
</span>
|
| 192 |
<!--
|
| 193 |
<div>
|
| 194 |
<label for="extra_sentinel_checkbox">Infill: Extra sentinel</label>
|
|
|
|
| 217 |
</div>
|
| 218 |
</div>
|
| 219 |
|
| 220 |
+
<h3 id="debug-info">Debug info</h3>
|
| 221 |
<p>
|
| 222 |
<script type="text/javascript">
|
| 223 |
// these constants are only used for providing user expectations.
|
| 224 |
var OVERHEAD = 3;
|
| 225 |
var PER_TOKEN = 0.12;
|
| 226 |
+
var SPLIT_TOKEN = "<infill>"
|
| 227 |
|
| 228 |
var Range = require("ace/range").Range;
|
| 229 |
|
| 230 |
// examples for the user
|
| 231 |
var EXAMPLES = {
|
| 232 |
"python": {
|
| 233 |
+
"prompt": "<| file ext=.py |>\nclass Person:\n" + SPLIT_TOKEN + "\np = Person('Eren', 18, 'Male')",
|
| 234 |
+
"length": 128,
|
| 235 |
+
"mode": "python"
|
| 236 |
+
},
|
| 237 |
+
"python-infill2": {
|
| 238 |
+
"prompt":
|
| 239 |
+
`from collections import Counter
|
| 240 |
+
def <infill>(file_name):
|
| 241 |
+
"""Count the number of occurrences of each word in the file."""
|
| 242 |
+
<infill>
|
| 243 |
+
`,
|
| 244 |
+
"length": 128,
|
| 245 |
+
"mode": "python"
|
| 246 |
+
},
|
| 247 |
+
|
| 248 |
+
"type-pred": {
|
| 249 |
+
"prompt":
|
| 250 |
+
`def count_words(filename: str) -> <infill>:
|
| 251 |
+
"""Count the number of occurrences of each word in the file."""
|
| 252 |
+
with open(filename, 'r') as f:
|
| 253 |
+
word_counts = {}
|
| 254 |
+
for line in f:
|
| 255 |
+
for word in line.split():
|
| 256 |
+
if word in word_counts:
|
| 257 |
+
word_counts[word] = 1
|
| 258 |
+
else:
|
| 259 |
+
word_counts[word] = 1
|
| 260 |
+
return word_counts
|
| 261 |
+
`,
|
| 262 |
+
"length": 64,
|
| 263 |
+
"mode": "python"
|
| 264 |
+
},
|
| 265 |
+
"docstring": {
|
| 266 |
+
"prompt":
|
| 267 |
+
`def count_words(filename: str) -> Dict[str, int]:
|
| 268 |
+
"""<infill>
|
| 269 |
+
"""
|
| 270 |
+
with open(filename, 'r') as f:
|
| 271 |
+
word_counts = {}
|
| 272 |
+
for line in f:
|
| 273 |
+
for word in line.split():
|
| 274 |
+
if word in word_counts:
|
| 275 |
+
word_counts[word] = 1
|
| 276 |
+
else:
|
| 277 |
+
word_counts[word] = 1
|
| 278 |
+
return word_counts
|
| 279 |
+
`,
|
| 280 |
"length": 128,
|
| 281 |
"mode": "python"
|
| 282 |
},
|
| 283 |
"javascript": {
|
| 284 |
+
"prompt": "<| file ext=.js |>\n // is something really happening here",
|
| 285 |
"length": 128,
|
| 286 |
"mode": "javascript"
|
| 287 |
},
|
|
|
|
| 315 |
var editor = ace.edit("editor");
|
| 316 |
|
| 317 |
function set_editor_mode(mode) {
|
| 318 |
+
session = editor.session
|
| 319 |
+
session.setMode("ace/mode/" + mode, function() {
|
| 320 |
+
var rules = session.$mode.$highlightRules.getRules();
|
| 321 |
+
for (var stateName in rules) {
|
| 322 |
+
if (Object.prototype.hasOwnProperty.call(rules, stateName)) {
|
| 323 |
+
rules[stateName].unshift({
|
| 324 |
+
token: 'infill',
|
| 325 |
+
regex: SPLIT_TOKEN
|
| 326 |
+
});
|
| 327 |
+
}
|
| 328 |
+
}
|
| 329 |
+
// force recreation of tokenizer
|
| 330 |
+
session.$mode.$tokenizer = null;
|
| 331 |
+
session.bgTokenizer.setTokenizer(session.$mode.getTokenizer());
|
| 332 |
+
// force re-highlight whole document
|
| 333 |
+
session.bgTokenizer.start(0);
|
| 334 |
+
});
|
| 335 |
}
|
| 336 |
|
| 337 |
/*
|
|
|
|
| 436 |
}
|
| 437 |
|
| 438 |
function get_infill_parts() {
|
|
|
|
| 439 |
var lines = editor.getSession().doc.$lines;
|
| 440 |
var lines_flat = join_lines(lines);
|
| 441 |
+
parts = lines_flat.split(SPLIT_TOKEN)
|
| 442 |
+
if (parts.length == 1) {
|
| 443 |
+
window.alert('There are no infill masks, add some <infill> masks before requesting an infill')
|
| 444 |
+
}
|
| 445 |
+
return parts
|
| 446 |
+
}
|
| 447 |
+
|
| 448 |
+
function insert_mask() {
|
| 449 |
if (editor.selection.ranges.length > 1) {
|
|
|
|
| 450 |
for (var i = 0; i < editor.selection.ranges.length; i++) {
|
| 451 |
+
console.log('range is', editor.selection.ranges[i])
|
| 452 |
+
editor.session.replace(editor.selection.ranges[i], SPLIT_TOKEN)
|
|
|
|
|
|
|
|
|
|
| 453 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 454 |
} else {
|
| 455 |
+
editor.session.replace(editor.selection.getRange(), SPLIT_TOKEN)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 456 |
}
|
| 457 |
}
|
| 458 |
|
| 459 |
+
|
| 460 |
function make_generate_listener(url) {
|
| 461 |
return async function(event) {
|
| 462 |
var length = $("#length_slider").val();
|
|
|
|
| 538 |
|
| 539 |
// actual logic
|
| 540 |
$(document).ready(function() {
|
| 541 |
+
$("#insert-mask-button").click(insert_mask);
|
| 542 |
$("#extend-form-button").click(make_generate_listener("generate"));
|
| 543 |
$("#infill-form-button").click(make_generate_listener("infill"));
|
| 544 |
$("#mode").change(function (e) {
|
| 545 |
var mode = $("#mode").val();
|
| 546 |
set_editor_mode(mode);
|
| 547 |
});
|
| 548 |
+
select_example("python")
|
| 549 |
+
// set_editor_mode("python");
|
| 550 |
});
|
| 551 |
</script>
|
| 552 |
</body>
|