Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
c812d6a9
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c812d6a9
编写于
8月 21, 2019
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
support directories in indexed db fsp
上级
2dcfacba
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
93 addition
and
23 deletion
+93
-23
src/vs/workbench/services/log/browser/indexedDBLogProvider.ts
...vs/workbench/services/log/browser/indexedDBLogProvider.ts
+93
-23
未找到文件。
src/vs/workbench/services/log/browser/indexedDBLogProvider.ts
浏览文件 @
c812d6a9
...
...
@@ -9,6 +9,7 @@ import { Disposable, IDisposable } from 'vs/base/common/lifecycle';
import
{
Event
,
Emitter
}
from
'
vs/base/common/event
'
;
import
{
VSBuffer
}
from
'
vs/base/common/buffer
'
;
import
{
FileSystemError
}
from
'
vs/workbench/api/common/extHostTypes
'
;
import
{
isEqualOrParent
,
joinPath
}
from
'
vs/base/common/resources
'
;
const
LOGS_OBJECT_STORE
=
'
logs
'
;
export
const
INDEXEDDB_LOG_SCHEME
=
'
vscode-logs-indexedbd
'
;
...
...
@@ -41,7 +42,7 @@ export class IndexedDBLogProvider extends Disposable implements IFileSystemProvi
c
(
db
);
}
};
request
.
onupgradeneeded
=
(
e
)
=>
{
request
.
onupgradeneeded
=
()
=>
{
const
db
=
request
.
result
;
if
(
!
db
.
objectStoreNames
.
contains
(
LOGS_OBJECT_STORE
))
{
db
.
createObjectStore
(
LOGS_OBJECT_STORE
);
...
...
@@ -55,20 +56,7 @@ export class IndexedDBLogProvider extends Disposable implements IFileSystemProvi
return
Disposable
.
None
;
}
mkdir
(
resource
:
URI
):
Promise
<
void
>
{
return
Promise
.
reject
(
new
Error
(
'
Not Supported
'
));
}
rename
(
from
:
URI
,
to
:
URI
,
opts
:
FileOverwriteOptions
):
Promise
<
void
>
{
return
Promise
.
reject
(
new
Error
(
'
Not Supported
'
));
}
readdir
(
resource
:
URI
):
Promise
<
[
string
,
FileType
][]
>
{
return
Promise
.
reject
(
new
Error
(
'
Not Supported
'
));
}
delete
(
resource
:
URI
,
opts
:
FileDeleteOptions
):
Promise
<
void
>
{
return
Promise
.
reject
(
new
Error
(
'
Not Supported
'
));
async
mkdir
(
resource
:
URI
):
Promise
<
void
>
{
}
async
stat
(
resource
:
URI
):
Promise
<
IStat
>
{
...
...
@@ -81,33 +69,67 @@ export class IndexedDBLogProvider extends Disposable implements IFileSystemProvi
size
:
content
.
byteLength
};
}
catch
(
e
)
{
}
const
files
=
await
this
.
readdir
(
resource
);
if
(
files
.
length
)
{
return
{
type
:
FileType
.
File
,
type
:
FileType
.
Directory
,
ctime
:
0
,
mtime
:
0
,
size
:
0
};
}
return
Promise
.
reject
(
new
FileSystemError
(
resource
,
FileSystemProviderErrorCode
.
FileNotFound
));
}
async
readFile
(
resource
:
URI
):
Promise
<
Uint8Array
>
{
async
readdir
(
resource
:
URI
):
Promise
<
[
string
,
FileType
][]
>
{
const
hasKey
=
await
this
.
hasKey
(
resource
.
path
);
if
(
hasKey
)
{
return
Promise
.
reject
(
new
FileSystemError
(
resource
,
FileSystemProviderErrorCode
.
FileNotADirectory
));
}
return
new
Promise
(
async
(
c
,
e
)
=>
{
const
db
=
await
this
.
database
;
const
transaction
=
db
.
transaction
([
LOGS_OBJECT_STORE
]);
const
objectStore
=
transaction
.
objectStore
(
LOGS_OBJECT_STORE
);
const
request
=
objectStore
.
get
(
resource
.
path
);
const
request
=
objectStore
.
get
AllKeys
(
);
request
.
onerror
=
()
=>
e
(
request
.
error
);
request
.
onsuccess
=
()
=>
{
if
(
request
.
result
)
{
c
(
VSBuffer
.
fromString
(
request
.
result
).
buffer
);
}
else
{
e
(
new
FileSystemError
(
resource
,
FileSystemProviderErrorCode
.
FileNotFound
));
const
files
:
[
string
,
FileType
][]
=
[];
const
resourceSegments
=
resource
.
path
.
split
(
'
/
'
);
for
(
const
key
of
<
string
[]
>
request
.
result
)
{
if
(
isEqualOrParent
(
URI
.
file
(
key
).
with
({
scheme
:
INDEXEDDB_LOG_SCHEME
}),
resource
,
false
))
{
const
keySegments
=
key
.
split
(
'
/
'
);
files
.
push
([
keySegments
[
resourceSegments
.
length
],
resourceSegments
.
length
+
1
===
keySegments
.
length
?
FileType
.
File
:
FileType
.
Directory
]);
}
}
c
(
files
);
};
});
}
writeFile
(
resource
:
URI
,
content
:
Uint8Array
,
opts
:
FileWriteOptions
):
Promise
<
void
>
{
async
readFile
(
resource
:
URI
):
Promise
<
Uint8Array
>
{
const
hasKey
=
await
this
.
hasKey
(
resource
.
path
);
if
(
!
hasKey
)
{
return
Promise
.
reject
(
new
FileSystemError
(
resource
,
FileSystemProviderErrorCode
.
FileNotFound
));
}
return
new
Promise
(
async
(
c
,
e
)
=>
{
const
db
=
await
this
.
database
;
const
transaction
=
db
.
transaction
([
LOGS_OBJECT_STORE
]);
const
objectStore
=
transaction
.
objectStore
(
LOGS_OBJECT_STORE
);
const
request
=
objectStore
.
get
(
resource
.
path
);
request
.
onerror
=
()
=>
e
(
request
.
error
);
request
.
onsuccess
=
()
=>
c
(
VSBuffer
.
fromString
(
request
.
result
||
''
).
buffer
);
});
}
async
writeFile
(
resource
:
URI
,
content
:
Uint8Array
,
opts
:
FileWriteOptions
):
Promise
<
void
>
{
const
hasKey
=
await
this
.
hasKey
(
resource
.
path
);
if
(
!
hasKey
)
{
const
files
=
await
this
.
readdir
(
resource
);
if
(
files
.
length
)
{
return
Promise
.
reject
(
new
FileSystemError
(
resource
,
FileSystemProviderErrorCode
.
FileIsADirectory
));
}
}
return
new
Promise
(
async
(
c
,
e
)
=>
{
const
db
=
await
this
.
database
;
const
transaction
=
db
.
transaction
([
LOGS_OBJECT_STORE
],
'
readwrite
'
);
...
...
@@ -122,4 +144,52 @@ export class IndexedDBLogProvider extends Disposable implements IFileSystemProvi
});
}
async
delete
(
resource
:
URI
,
opts
:
FileDeleteOptions
):
Promise
<
void
>
{
const
hasKey
=
await
this
.
hasKey
(
resource
.
path
);
if
(
hasKey
)
{
await
this
.
deleteKey
(
resource
.
path
);
return
;
}
if
(
opts
.
recursive
)
{
const
files
=
await
this
.
readdir
(
resource
);
await
Promise
.
all
(
files
.
map
(([
key
])
=>
this
.
delete
(
joinPath
(
resource
,
key
),
opts
)));
}
}
rename
(
from
:
URI
,
to
:
URI
,
opts
:
FileOverwriteOptions
):
Promise
<
void
>
{
return
Promise
.
reject
(
new
Error
(
'
Not Supported
'
));
}
private
hasKey
(
key
:
string
):
Promise
<
boolean
>
{
return
new
Promise
<
boolean
>
(
async
(
c
,
e
)
=>
{
const
db
=
await
this
.
database
;
const
transaction
=
db
.
transaction
([
LOGS_OBJECT_STORE
]);
const
objectStore
=
transaction
.
objectStore
(
LOGS_OBJECT_STORE
);
const
request
=
objectStore
.
getKey
(
key
);
request
.
onerror
=
()
=>
e
(
request
.
error
);
request
.
onsuccess
=
()
=>
{
c
(
!!
request
.
result
);
};
});
}
private
deleteKey
(
key
:
string
):
Promise
<
void
>
{
return
new
Promise
(
async
(
c
,
e
)
=>
{
const
db
=
await
this
.
database
;
const
transaction
=
db
.
transaction
([
LOGS_OBJECT_STORE
],
'
readwrite
'
);
const
objectStore
=
transaction
.
objectStore
(
LOGS_OBJECT_STORE
);
const
request
=
objectStore
.
delete
(
key
);
request
.
onerror
=
()
=>
e
(
request
.
error
);
request
.
onsuccess
=
()
=>
{
this
.
versions
.
delete
(
key
);
this
.
_onDidChangeFile
.
fire
([{
resource
:
this
.
toResource
(
key
),
type
:
FileChangeType
.
DELETED
}]);
c
();
};
});
}
private
toResource
(
key
:
string
):
URI
{
return
URI
.
file
(
key
).
with
({
scheme
:
INDEXEDDB_LOG_SCHEME
});
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录