@jupyterlab/debugger 4.0.0-alpha.2 → 4.0.0-alpha.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/lib/debugger.d.ts +4 -0
  2. package/lib/debugger.js +5 -1
  3. package/lib/debugger.js.map +1 -1
  4. package/lib/dialogs/evaluate.d.ts +5 -0
  5. package/lib/dialogs/evaluate.js +16 -6
  6. package/lib/dialogs/evaluate.js.map +1 -1
  7. package/lib/factory.d.ts +1 -1
  8. package/lib/factory.js +15 -9
  9. package/lib/factory.js.map +1 -1
  10. package/lib/handler.js +24 -9
  11. package/lib/handler.js.map +1 -1
  12. package/lib/handlers/console.js +9 -3
  13. package/lib/handlers/console.js.map +1 -1
  14. package/lib/handlers/editor.d.ts +33 -11
  15. package/lib/handlers/editor.js +177 -88
  16. package/lib/handlers/editor.js.map +1 -1
  17. package/lib/handlers/file.d.ts +1 -0
  18. package/lib/handlers/file.js +11 -2
  19. package/lib/handlers/file.js.map +1 -1
  20. package/lib/handlers/notebook.d.ts +0 -7
  21. package/lib/handlers/notebook.js +22 -18
  22. package/lib/handlers/notebook.js.map +1 -1
  23. package/lib/icons.d.ts +3 -0
  24. package/lib/icons.js +15 -0
  25. package/lib/icons.js.map +1 -1
  26. package/lib/model.d.ts +5 -0
  27. package/lib/model.js +4 -0
  28. package/lib/model.js.map +1 -1
  29. package/lib/panels/breakpoints/index.d.ts +18 -0
  30. package/lib/panels/breakpoints/index.js +10 -3
  31. package/lib/panels/breakpoints/index.js.map +1 -1
  32. package/lib/panels/breakpoints/pauseonexceptions.d.ts +53 -0
  33. package/lib/panels/breakpoints/pauseonexceptions.js +98 -0
  34. package/lib/panels/breakpoints/pauseonexceptions.js.map +1 -0
  35. package/lib/panels/callstack/index.d.ts +1 -1
  36. package/lib/panels/kernelSources/body.d.ts +45 -0
  37. package/lib/panels/kernelSources/body.js +76 -0
  38. package/lib/panels/kernelSources/body.js.map +1 -0
  39. package/lib/panels/kernelSources/filter.d.ts +11 -0
  40. package/lib/panels/kernelSources/filter.js +18 -0
  41. package/lib/panels/kernelSources/filter.js.map +1 -0
  42. package/lib/panels/kernelSources/index.d.ts +39 -0
  43. package/lib/panels/kernelSources/index.js +54 -0
  44. package/lib/panels/kernelSources/index.js.map +1 -0
  45. package/lib/panels/kernelSources/model.d.ts +73 -0
  46. package/lib/panels/kernelSources/model.js +120 -0
  47. package/lib/panels/kernelSources/model.js.map +1 -0
  48. package/lib/panels/sources/body.js +5 -3
  49. package/lib/panels/sources/body.js.map +1 -1
  50. package/lib/panels/variables/grid.d.ts +8 -2
  51. package/lib/panels/variables/grid.js +29 -364
  52. package/lib/panels/variables/grid.js.map +1 -1
  53. package/lib/panels/variables/gridpanel.d.ts +140 -0
  54. package/lib/panels/variables/gridpanel.js +363 -0
  55. package/lib/panels/variables/gridpanel.js.map +1 -0
  56. package/lib/panels/variables/index.d.ts +1 -9
  57. package/lib/panels/variables/index.js +1 -15
  58. package/lib/panels/variables/index.js.map +1 -1
  59. package/lib/panels/variables/mimerenderer.d.ts +15 -2
  60. package/lib/panels/variables/mimerenderer.js +56 -17
  61. package/lib/panels/variables/mimerenderer.js.map +1 -1
  62. package/lib/panels/variables/model.d.ts +3 -0
  63. package/lib/panels/variables/model.js +7 -0
  64. package/lib/panels/variables/model.js.map +1 -1
  65. package/lib/panels/variables/scope.js +4 -0
  66. package/lib/panels/variables/scope.js.map +1 -1
  67. package/lib/panels/variables/tree.d.ts +2 -5
  68. package/lib/panels/variables/tree.js +137 -47
  69. package/lib/panels/variables/tree.js.map +1 -1
  70. package/lib/service.d.ts +32 -2
  71. package/lib/service.js +122 -9
  72. package/lib/service.js.map +1 -1
  73. package/lib/session.d.ts +37 -1
  74. package/lib/session.js +89 -6
  75. package/lib/session.js.map +1 -1
  76. package/lib/sidebar.d.ts +7 -1
  77. package/lib/sidebar.js +10 -2
  78. package/lib/sidebar.js.map +1 -1
  79. package/lib/sources.d.ts +2 -2
  80. package/lib/sources.js +32 -17
  81. package/lib/sources.js.map +1 -1
  82. package/lib/tokens.d.ts +139 -24
  83. package/lib/tokens.js.map +1 -1
  84. package/package.json +39 -47
  85. package/src/config.ts +78 -0
  86. package/src/debugger.ts +154 -0
  87. package/src/dialogs/evaluate.ts +144 -0
  88. package/src/factory.ts +72 -0
  89. package/src/handler.ts +528 -0
  90. package/src/handlers/console.ts +118 -0
  91. package/src/handlers/editor.ts +469 -0
  92. package/src/handlers/file.ts +86 -0
  93. package/src/handlers/notebook.ts +128 -0
  94. package/src/hash.ts +69 -0
  95. package/src/icons.ts +64 -0
  96. package/src/index.ts +16 -0
  97. package/src/model.ts +155 -0
  98. package/src/panels/breakpoints/body.tsx +145 -0
  99. package/src/panels/breakpoints/index.ts +116 -0
  100. package/src/panels/breakpoints/model.ts +74 -0
  101. package/src/panels/breakpoints/pauseonexceptions.tsx +141 -0
  102. package/src/panels/callstack/body.tsx +96 -0
  103. package/src/panels/callstack/index.ts +152 -0
  104. package/src/panels/callstack/model.ts +86 -0
  105. package/src/panels/kernelSources/body.tsx +139 -0
  106. package/src/panels/kernelSources/filter.tsx +44 -0
  107. package/src/panels/kernelSources/index.tsx +106 -0
  108. package/src/panels/kernelSources/model.ts +160 -0
  109. package/src/panels/sources/body.ts +161 -0
  110. package/src/panels/sources/index.tsx +85 -0
  111. package/src/panels/sources/model.ts +94 -0
  112. package/src/panels/sources/sourcepath.tsx +28 -0
  113. package/src/panels/variables/grid.ts +144 -0
  114. package/src/panels/variables/gridpanel.ts +455 -0
  115. package/src/panels/variables/index.ts +199 -0
  116. package/src/panels/variables/mimerenderer.ts +125 -0
  117. package/src/panels/variables/model.ts +61 -0
  118. package/src/panels/variables/scope.tsx +132 -0
  119. package/src/panels/variables/tree.tsx +521 -0
  120. package/src/service.ts +1009 -0
  121. package/src/session.ts +342 -0
  122. package/src/sidebar.ts +194 -0
  123. package/src/sources.ts +327 -0
  124. package/src/svg.d.ts +9 -0
  125. package/src/tokens.ts +1071 -0
  126. package/style/base.css +2 -1
  127. package/style/breakpoints.css +21 -12
  128. package/style/icons/arrow-collapse.svg +1 -1
  129. package/style/icons/arrow-expand.svg +1 -1
  130. package/style/icons/exceptions.svg +10 -0
  131. package/style/icons/open-kernel-source.svg +6 -0
  132. package/style/icons/pause.svg +6 -0
  133. package/style/icons.css +9 -8
  134. package/style/index.css +1 -1
  135. package/style/index.js +1 -1
  136. package/style/kernelSources.css +45 -0
  137. package/style/sidebar.css +1 -1
  138. package/style/variables.css +82 -21
package/style/base.css CHANGED
@@ -6,6 +6,7 @@
6
6
  @import './callstack.css';
7
7
  @import './editor.css';
8
8
  @import './icons.css';
9
+ @import './kernelSources.css';
9
10
  @import './sidebar.css';
10
11
  @import './sources.css';
11
12
  @import './variables.css';
@@ -17,7 +18,7 @@
17
18
  }
18
19
 
19
20
  #jp-debugger .jp-switch-label {
20
- margin-right: 0px;
21
+ margin-right: 0;
21
22
  }
22
23
 
23
24
  .jp-DebuggerBugButton[aria-pressed='true'] path {
@@ -55,25 +55,34 @@
55
55
  margin-left: auto;
56
56
  }
57
57
 
58
- [data-jp-debugger='true'] .CodeMirror-gutter-wrapper::after {
58
+ [data-jp-debugger='true'] .cm-breakpoint-gutter .cm-gutterElement:empty::after {
59
59
  content: '●';
60
60
  color: var(--jp-error-color1);
61
61
  opacity: 0;
62
- position: absolute;
63
- left: 3px;
64
- top: -1px;
65
62
  }
66
63
 
67
- [data-jp-debugger='true'].jp-Editor .CodeMirror-gutter-wrapper:hover::after,
64
+ .cm-gutter {
65
+ cursor: default;
66
+ }
67
+
68
+ .cm-breakpoint-gutter .cm-gutterElement {
69
+ color: var(--jp-error-color1);
70
+ padding-left: 5px;
71
+ font-size: 20px;
72
+ position: relative;
73
+ top: -5px;
74
+ }
75
+
76
+ [data-jp-debugger='true'].jp-Editor
77
+ .cm-breakpoint-gutter
78
+ .cm-gutterElement:empty:hover::after,
68
79
  [data-jp-debugger='true']
69
80
  .jp-Notebook
70
81
  .jp-CodeCell.jp-mod-selected
71
- .CodeMirror-gutter-wrapper:hover::after,
72
- [data-jp-debugger='true'] .jp-Editor .CodeMirror-gutter-wrapper:hover::after {
73
- opacity: 0.5;
74
- }
75
-
76
- [data-jp-debugger='true'].jp-DebuggerEditors
77
- .CodeMirror-gutter-wrapper:hover::after {
82
+ .cm-breakpoint-gutter:empty:hover::after,
83
+ [data-jp-debugger='true']
84
+ .jp-Editor
85
+ .cm-breakpoint-gutter
86
+ .cm-gutterElement:empty:hover::after {
78
87
  opacity: 0.5;
79
88
  }
@@ -1 +1 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path fill="#646465" d="M6 4v8l4-4-4-4zm1 2.414l1.586 1.586-1.586 1.586v-3.172z"/></svg>
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path fill="#646465" d="M6 4v8l4-4-4-4zm1 2.414l1.586 1.586-1.586 1.586v-3.172z"/></svg>
@@ -1 +1 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path fill="#646465" d="M11 10.07h-5.656l5.656-5.656v5.656z"/></svg>
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path fill="#646465" d="M11 10.07h-5.656l5.656-5.656v5.656z"/></svg>
@@ -0,0 +1,10 @@
1
+ <svg height="24" width="24" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
2
+ <g class="jp-icon3" fill="#616161" transform="matrix(1.1999396,0,0,1.3858273,-2.3726971,-4.6347192)">
3
+ <path
4
+ d="M 12.023438,0.30859375 11.158203,1.8085937 -1.2382812,23.285156 l 26.5292972,-0.002 z m 0.002,3.99999995 9.800781,16.9746093 -19.6015626,0.002 z"
5
+ transform="matrix(0.72509832,0,0,0.7247701,3.2918397,3.480876)"
6
+ />
7
+ <path d="m 11.144475,9.117095 h 1.666751 v 7.215906 h -1.666751 z" />
8
+ <path d="m 11.144475,17.054592 h 1.666751 v 1.443181 h -1.666751 z" />
9
+ </g>
10
+ </svg>
@@ -0,0 +1,6 @@
1
+ <svg width="24" height="24" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
2
+ <g class="jp-icon3" fill="#616161">
3
+ <path d="M5 2H15L20 7V20C20 20.5304 19.7893 21.0391 19.4142 21.4142C19.0391 21.7893 18.5304 22 18 22H5C4.46957 22 3.96086 21.7893 3.58579 21.4142C3.21071 21.0391 3 20.5304 3 20V14H4V16L8 13L4 10V12H3V4C3 3.46957 3.21071 2.96086 3.58579 2.58579C3.96086 2.21071 4.46957 2 5 2ZM12 18H16V16H12V18ZM12 14H18V12H12V14ZM12 10H18V8H12V10ZM10 14C10.5523 14 11 13.5523 11 13C11 12.4477 10.5523 12 10 12C9.44771 12 9 12.4477 9 13C9 13.5523 9.44771 14 10 14Z"/>
4
+ <path d="M3 12V14H1V13V12H3Z"/>
5
+ </g>
6
+ </svg>
@@ -0,0 +1,6 @@
1
+ <svg height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg">
2
+ <g class="jp-icon3" fill="#616161">
3
+ <path d="m 7,6 h 4 V 18 H 7 Z" />
4
+ <path d="m 13,6 h 4 v 12 h -4 z" />
5
+ </g>
6
+ </svg>
package/style/icons.css CHANGED
@@ -12,16 +12,17 @@ button.jp-Button.jp-mod-minimal.jp-TreeView.jp-TableView {
12
12
  width: 35px;
13
13
  }
14
14
 
15
- button.jp-Button.jp-mod-minimal.jp-TreeView:hover {
16
- cursor: pointer;
17
- background-color: var(--jp-layout-color1);
15
+ .jp-ViewModeSelected .jp-Button,
16
+ .jp-PauseOnExceptions.lm-mod-toggled {
17
+ background-color: var(--jp-inverse-layout-color3);
18
18
  }
19
19
 
20
- button.jp-Button.jp-mod-minimal.jp-TableView:hover {
21
- cursor: pointer;
22
- background-color: var(--jp-layout-color1);
20
+ .jp-ViewModeSelected .jp-Button:hover,
21
+ .jp-PauseOnExceptions.lm-mod-toggled:hover {
22
+ background-color: var(--jp-inverse-layout-color4);
23
23
  }
24
24
 
25
- .jp-ViewModeSelected {
26
- background-color: var(--jp-layout-color1);
25
+ .jp-ViewModeSelected .jp-Button .jp-icon3[fill],
26
+ .jp-PauseOnExceptions.lm-mod-toggled .jp-icon3[fill] {
27
+ fill: var(--jp-layout-color1);
27
28
  }
package/style/index.css CHANGED
@@ -8,10 +8,10 @@
8
8
  @import url('~@jupyterlab/ui-components/style/index.css');
9
9
  @import url('~@jupyterlab/apputils/style/index.css');
10
10
  @import url('~@jupyterlab/codeeditor/style/index.css');
11
- @import url('~@jupyterlab/codemirror/style/index.css');
12
11
  @import url('~@jupyterlab/rendermime/style/index.css');
13
12
  @import url('~@jupyterlab/docregistry/style/index.css');
14
13
  @import url('~@jupyterlab/application/style/index.css');
14
+ @import url('~@jupyterlab/codemirror/style/index.css');
15
15
  @import url('~@jupyterlab/cells/style/index.css');
16
16
  @import url('~@jupyterlab/console/style/index.css');
17
17
  @import url('~@jupyterlab/fileeditor/style/index.css');
package/style/index.js CHANGED
@@ -8,10 +8,10 @@ import '@lumino/widgets/style/index.js';
8
8
  import '@jupyterlab/ui-components/style/index.js';
9
9
  import '@jupyterlab/apputils/style/index.js';
10
10
  import '@jupyterlab/codeeditor/style/index.js';
11
- import '@jupyterlab/codemirror/style/index.js';
12
11
  import '@jupyterlab/rendermime/style/index.js';
13
12
  import '@jupyterlab/docregistry/style/index.js';
14
13
  import '@jupyterlab/application/style/index.js';
14
+ import '@jupyterlab/codemirror/style/index.js';
15
15
  import '@jupyterlab/cells/style/index.js';
16
16
  import '@jupyterlab/console/style/index.js';
17
17
  import '@jupyterlab/fileeditor/style/index.js';
@@ -0,0 +1,45 @@
1
+ /*-----------------------------------------------------------------------------
2
+ | Copyright (c) Jupyter Development Team.
3
+ | Distributed under the terms of the Modified BSD License.
4
+ |----------------------------------------------------------------------------*/
5
+
6
+ .jp-DebuggerKernelSources {
7
+ min-height: 50px;
8
+ margin-top: 3px;
9
+ }
10
+
11
+ [data-jp-debugger='true'].jp-Editor .jp-mod-readOnly {
12
+ background: var(--jp-layout-color2);
13
+ height: 100%;
14
+ }
15
+
16
+ .jp-DebuggerKernelSources-body [data-jp-debugger='true'].jp-Editor {
17
+ height: 100%;
18
+ }
19
+
20
+ .jp-DebuggerKernelSources-body {
21
+ height: 100%;
22
+ overflow-y: auto;
23
+ }
24
+
25
+ .jp-DebuggerKernelSources-header > div > span {
26
+ overflow: hidden;
27
+ cursor: pointer;
28
+ text-overflow: ellipsis;
29
+ white-space: nowrap;
30
+ font-size: var(--jp-ui-font-size0);
31
+ color: var(--jp-ui-font-color1);
32
+ }
33
+
34
+ .jp-DebuggerKernelSource-filterBox {
35
+ padding: 0;
36
+ flex: 0 0 auto;
37
+ margin: 0;
38
+ position: sticky;
39
+ top: 0;
40
+ background-color: var(--jp-layout-color1);
41
+ }
42
+
43
+ .jp-DebuggerKernelSource-filterBox-hidden {
44
+ display: none;
45
+ }
package/style/sidebar.css CHANGED
@@ -7,6 +7,6 @@
7
7
  /* Set font-size to override default h2 sizing but keeping default --jp-ui-font-size0 */
8
8
  font-size: 100%;
9
9
  font-weight: 600;
10
- margin: 0px auto 0px 0px;
10
+ margin: 0 auto 0 0;
11
11
  padding: 4px 10px;
12
12
  }
@@ -2,7 +2,6 @@
2
2
  | Copyright (c) Jupyter Development Team.
3
3
  | Distributed under the terms of the Modified BSD License.
4
4
  |----------------------------------------------------------------------------*/
5
-
6
5
  .jp-DebuggerVariables {
7
6
  display: flex;
8
7
  flex-direction: column;
@@ -16,57 +15,96 @@
16
15
  flex: 1 1 auto;
17
16
  min-height: 24px;
18
17
  overflow: auto;
18
+
19
+ /* For absolute positioning of jp-DebuggerVariables-buttons. */
20
+ position: relative;
19
21
  }
20
22
 
21
- .jp-DebuggerVariables-body ul {
23
+ .jp-DebuggerVariables-branch {
22
24
  list-style: none;
23
25
  margin: 0;
24
26
  padding: 0;
25
27
  }
26
28
 
27
- .jp-DebuggerVariables-body > ul {
29
+ .jp-DebuggerVariables-body
30
+ .jp-DebuggerVariables-branch
31
+ .jp-DebuggerVariables-branch {
32
+ grid-area: nested;
33
+ }
34
+
35
+ .jp-DebuggerVariables-body > .jp-DebuggerVariables-branch {
28
36
  padding-top: 0.1em;
29
37
  }
30
38
 
31
- .jp-DebuggerVariables-body ul li {
32
- padding: 5px 0 0 0;
39
+ .jp-DebuggerVariables-branch li {
40
+ padding: 3px 0;
33
41
  cursor: pointer;
34
42
  color: var(--jp-content-font-color1);
35
- display: flex;
36
- align-items: center;
43
+ display: grid;
44
+ grid-template:
45
+ 'collapser name detail'
46
+ 'nested nested nested';
47
+ grid-template-columns: max-content max-content 1fr;
37
48
  }
38
49
 
39
- .jp-DebuggerVariables-body ul li:hover .jp-DebuggerVariables-renderVariable {
40
- display: block;
50
+ .jp-DebuggerVariables-branch li:not(:has(li:hover)):hover {
51
+ background: var(--jp-layout-color2);
41
52
  }
42
53
 
43
- .jp-DebuggerVariables-body .jp-DebuggerVariables-hspacer {
44
- flex: 1 1 auto;
54
+ .jp-DebuggerVariables-collapser {
55
+ width: 16px;
56
+ grid-area: collapser;
57
+ transform: rotate(-90deg);
58
+ transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
59
+ }
60
+
61
+ .jp-DebuggerVariables-collapser.jp-mod-expanded {
62
+ transform: rotate(0);
63
+ }
64
+
65
+ .jp-DebuggerVariables-buttons {
66
+ position: absolute;
67
+ top: 0;
68
+ right: 8px;
69
+ margin-top: 1px;
45
70
  }
46
71
 
47
- .jp-DebuggerVariables-body .jp-DebuggerVariables-renderVariable {
48
- flex: 0 0 auto;
72
+ .jp-DebuggerVariables-name {
73
+ color: var(--jp-mirror-editor-attribute-color);
74
+ grid-area: name;
75
+ }
76
+
77
+ .jp-DebuggerVariables-name::after {
78
+ content: ':';
79
+ margin-right: 5px;
80
+ }
81
+
82
+ .jp-DebuggerVariables-detail {
83
+ /* detail contains value for primitive types or name of the type otherwise */
84
+ color: var(--jp-mirror-editor-string-color);
85
+ }
86
+
87
+ .jp-DebuggerVariables-renderVariable {
49
88
  border: none;
50
89
  background: none;
51
90
  cursor: pointer;
52
- display: none;
53
- padding: 0px 8px;
91
+ transform-origin: center center;
92
+ transition: transform 0.2s cubic-bezier(0.4, 0, 1, 1);
54
93
  }
55
94
 
56
- .jp-DebuggerVariables-body .jp-DebuggerVariables-renderVariable:active {
57
- transform: scale(1.272) translateX(-4px);
58
- overflow: hidden;
95
+ .jp-DebuggerVariables-renderVariable:active {
96
+ transform: scale(1.35);
59
97
  }
60
98
 
61
- .jp-DebuggerVariables-body .jp-DebuggerVariables-renderVariable:hover {
99
+ .jp-DebuggerVariables-renderVariable:hover {
62
100
  background-color: var(--jp-layout-color2);
63
101
  }
64
102
 
65
- .jp-DebuggerVariables-body .jp-DebuggerVariables-renderVariable:disabled {
103
+ .jp-DebuggerVariables-renderVariable:disabled {
66
104
  cursor: default;
67
105
  }
68
106
 
69
- .jp-DebuggerVariables-body ul li > ul {
107
+ .jp-DebuggerVariables-branch li > .jp-DebuggerVariables-branch {
70
108
  margin-left: 12px;
71
109
  }
72
110
 
@@ -114,3 +152,26 @@
114
152
  .jp-DebuggerVariables-colorPalette .jp-mod-text {
115
153
  color: var(--jp-content-font-color0);
116
154
  }
155
+
156
+ .jp-VariableRendererPanel {
157
+ overflow: auto;
158
+ }
159
+
160
+ .jp-VariableRendererPanel-renderer {
161
+ overflow: auto;
162
+ height: 100%;
163
+ }
164
+
165
+ .jp-VariableRenderer-TrustButton[aria-pressed='true'] {
166
+ box-shadow: inset 0 var(--jp-border-width) 4px
167
+ rgba(
168
+ var(--jp-shadow-base-lightness),
169
+ var(--jp-shadow-base-lightness),
170
+ var(--jp-shadow-base-lightness),
171
+ 0.6
172
+ );
173
+ }
174
+
175
+ .jp-DebuggerRichVariable div[data-mime-type='text/plain'] > pre {
176
+ white-space: normal;
177
+ }