Skip to content

Commit c11e2b8

Browse files
committed
move Exports method to export.go files
Signed-off-by: Jie Zhang <[email protected]>
1 parent 6ca8355 commit c11e2b8

File tree

2 files changed

+57
-33
lines changed

2 files changed

+57
-33
lines changed

export.go

+57
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,57 @@
1+
/*
2+
Copyright The containerd Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package containerd
18+
19+
import (
20+
"context"
21+
"io"
22+
23+
"github.com/containerd/containerd/images"
24+
ocispec "github.com/opencontainers/image-spec/specs-go/v1"
25+
)
26+
27+
type exportOpts struct {
28+
}
29+
30+
// ExportOpt allows the caller to specify export-specific options
31+
type ExportOpt func(c *exportOpts) error
32+
33+
func resolveExportOpt(opts ...ExportOpt) (exportOpts, error) {
34+
var eopts exportOpts
35+
for _, o := range opts {
36+
if err := o(&eopts); err != nil {
37+
return eopts, err
38+
}
39+
}
40+
return eopts, nil
41+
}
42+
43+
// Export exports an image to a Tar stream.
44+
// OCI format is used by default.
45+
// It is up to caller to put "org.opencontainers.image.ref.name" annotation to desc.
46+
// TODO(AkihiroSuda): support exporting multiple descriptors at once to a single archive stream.
47+
func (c *Client) Export(ctx context.Context, exporter images.Exporter, desc ocispec.Descriptor, opts ...ExportOpt) (io.ReadCloser, error) {
48+
_, err := resolveExportOpt(opts...) // unused now
49+
if err != nil {
50+
return nil, err
51+
}
52+
pr, pw := io.Pipe()
53+
go func() {
54+
pw.CloseWithError(exporter.Export(ctx, c.ContentStore(), desc, pw))
55+
}()
56+
return pr, nil
57+
}

import.go

-33
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,6 @@ import (
2222

2323
"github.com/containerd/containerd/errdefs"
2424
"github.com/containerd/containerd/images"
25-
ocispec "github.com/opencontainers/image-spec/specs-go/v1"
2625
)
2726

2827
type importOpts struct {
@@ -84,35 +83,3 @@ func (c *Client) Import(ctx context.Context, importer images.Importer, reader io
8483
}
8584
return images, nil
8685
}
87-
88-
type exportOpts struct {
89-
}
90-
91-
// ExportOpt allows the caller to specify export-specific options
92-
type ExportOpt func(c *exportOpts) error
93-
94-
func resolveExportOpt(opts ...ExportOpt) (exportOpts, error) {
95-
var eopts exportOpts
96-
for _, o := range opts {
97-
if err := o(&eopts); err != nil {
98-
return eopts, err
99-
}
100-
}
101-
return eopts, nil
102-
}
103-
104-
// Export exports an image to a Tar stream.
105-
// OCI format is used by default.
106-
// It is up to caller to put "org.opencontainers.image.ref.name" annotation to desc.
107-
// TODO(AkihiroSuda): support exporting multiple descriptors at once to a single archive stream.
108-
func (c *Client) Export(ctx context.Context, exporter images.Exporter, desc ocispec.Descriptor, opts ...ExportOpt) (io.ReadCloser, error) {
109-
_, err := resolveExportOpt(opts...) // unused now
110-
if err != nil {
111-
return nil, err
112-
}
113-
pr, pw := io.Pipe()
114-
go func() {
115-
pw.CloseWithError(exporter.Export(ctx, c.ContentStore(), desc, pw))
116-
}()
117-
return pr, nil
118-
}

0 commit comments

Comments
 (0)