extract: Use wrapped source
This commit is contained in:
parent
55a4142ca4
commit
d82e8b42b2
1 changed files with 45 additions and 18 deletions
|
@ -4,7 +4,9 @@ import chalk from 'chalk'
|
|||
import { parseFileList } from '../blobs/file-list'
|
||||
import { copyBlobs } from '../blobs/copy'
|
||||
import { createVendorDirs, generateBuild, writeBuildFiles } from '../blobs/build'
|
||||
import { readFile } from '../util/fs'
|
||||
import { readFile, withTempDir } from '../util/fs'
|
||||
import { withSpinner } from '../util/cli'
|
||||
import { wrapSystemSrc } from '../frontend/source'
|
||||
|
||||
export default class Extract extends Command {
|
||||
static description = 'extract proprietary files'
|
||||
|
@ -14,19 +16,43 @@ export default class Extract extends Command {
|
|||
vendor: flags.string({ char: 'v', description: 'device vendor/OEM name', required: true }),
|
||||
device: flags.string({ char: 'd', description: 'device codename', required: true }),
|
||||
skipCopy: flags.boolean({ char: 'k', description: 'skip file copying and only generate build files' }),
|
||||
|
||||
// Wrapped source
|
||||
stockSrc: flags.string({
|
||||
char: 's',
|
||||
description:
|
||||
'path to (extracted) factory images, (mounted) images, (extracted) OTA package, OTA payload, or directory containing any such files (optionally under device and/or build ID directory)',
|
||||
required: true,
|
||||
}),
|
||||
buildId: flags.string({
|
||||
char: 'b',
|
||||
description: 'build ID of the stock images (optional, only used for locating factory images)',
|
||||
}),
|
||||
useTemp: flags.boolean({
|
||||
char: 't',
|
||||
description: 'use a temporary directory for all extraction (prevents reusing extracted files across runs)',
|
||||
default: false,
|
||||
}),
|
||||
}
|
||||
|
||||
static args = [
|
||||
{ name: 'source', description: 'path to mounted factory images', required: true },
|
||||
{ name: 'listPath', description: 'path to LineageOS-compatible proprietary-files.txt list', required: true },
|
||||
]
|
||||
|
||||
async run() {
|
||||
let {
|
||||
args: { source, listPath },
|
||||
flags: { vendor, device, skipCopy },
|
||||
args: { listPath },
|
||||
flags: { vendor, device, skipCopy, stockSrc, buildId, useTemp },
|
||||
} = this.parse(Extract)
|
||||
|
||||
await withTempDir(async tmp => {
|
||||
// Prepare stock system source
|
||||
let wrapBuildId = buildId == undefined ? null : buildId
|
||||
let wrapped = await withSpinner('Extracting stock system source', spinner =>
|
||||
wrapSystemSrc(stockSrc, device, wrapBuildId, useTemp, tmp, spinner),
|
||||
)
|
||||
stockSrc = wrapped.src!
|
||||
|
||||
// Parse list
|
||||
this.log(chalk.bold(chalk.greenBright('Parsing list')))
|
||||
let list = await readFile(listPath)
|
||||
|
@ -37,12 +63,13 @@ export default class Extract extends Command {
|
|||
|
||||
// Copy blobs
|
||||
if (!skipCopy) {
|
||||
await copyBlobs(entries, source, dirs.proprietary)
|
||||
await copyBlobs(entries, stockSrc, dirs.proprietary)
|
||||
}
|
||||
|
||||
// Generate build files
|
||||
this.log(chalk.bold(chalk.greenBright('Generating build files')))
|
||||
let build = await generateBuild(entries, device, vendor, source, dirs)
|
||||
let build = await generateBuild(entries, device, vendor, stockSrc, dirs)
|
||||
await writeBuildFiles(build, dirs)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue