diff options
| author | Marcelo Arteiro <arteiro@google.com> | 2023-01-06 17:48:22 +0000 |
|---|---|---|
| committer | Marcelo Arteiro <arteiro@google.com> | 2023-01-25 16:48:18 +0000 |
| commit | f27a8e140de48492f5512717b234fa056fd996ef (patch) | |
| tree | 6fdd8ddbfd5a930670d15dd2afd99f82e2f3d8a0 /packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts | |
| parent | b56558ee8d849ff5d27da5ff65dac36b91634fa7 (diff) | |
Scripts for token migration
Instructions:
1. Install packages with `npm i`
2. Update migration list resources/migrationList.csv
3. Check run scripts in package.json
4. To run with script use `npm run main`
5. To run with debg tokens `npm run main -- debug`
6. To reset all repos `npm run resetRepo`
Test: Manual
Bug: 241778903
Change-Id: I0f828f1d75fdbd39ef8dfe2ca25ac02aaff4bfca
Diffstat (limited to 'packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts')
| -rw-r--r-- | packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts b/packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts new file mode 100644 index 000000000000..359e3ab6568b --- /dev/null +++ b/packages/SystemUI/scripts/token_alignment/helpers/FileIO.ts @@ -0,0 +1,112 @@ +// Copyright 2022 Google LLC + +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at + +// http://www.apache.org/licenses/LICENSE-2.0 + +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License.import { exec } from 'child_process'; + +import { exec } from 'child_process'; +import { parse } from 'csv-parse'; +import { promises as fs } from 'fs'; +import jsdom from 'jsdom'; + +const DOMParser = new jsdom.JSDOM('').window.DOMParser as typeof window.DOMParser; + +type TFileList = string[]; + +export type TCSVRecord = Array<string | boolean | number>; + +class _FileIO { + public parser = new DOMParser(); + public saved: string[] = []; + + public loadXML = async (path: string): Promise<XMLDocument> => { + try { + const src = await this.loadFileAsText(path); + return this.parser.parseFromString(src, 'text/xml') as XMLDocument; + } catch (error) { + console.log(`Failed to parse XML file '${path}'.`, error); + process.exit(); + } + }; + + public loadFileAsText = async (path: string): Promise<string> => { + try { + return await fs.readFile(path, { encoding: 'utf8' }); + } catch (error) { + console.log(`Failed to read file '${path}'.`, error); + process.exit(); + } + }; + + public saveFile = async (data: string, path: string) => { + try { + await fs.writeFile(path, data, { encoding: 'utf8' }); + this.saved.push(path); + } catch (error) { + console.log(error); + console.log(`Failed to write file '${path}'.`); + process.exit(); + } + }; + + public loadFileList = async (path: string): Promise<TFileList> => { + const src = await this.loadFileAsText(path); + + try { + return JSON.parse(src) as TFileList; + } catch (error) { + console.log(error); + console.log(`Failed to parse JSON file '${path}'.`); + process.exit(); + } + }; + + public loadCSV = (path: string): Promise<Array<TCSVRecord>> => { + return new Promise((resolve, reject) => { + this.loadFileAsText(path).then((src) => { + parse( + src, + { + delimiter: ' ', + }, + (err, records) => { + if (err) { + reject(err); + return; + } + + resolve(records); + } + ); + }); + }); + }; + + formatSaved = () => { + const cmd = `idea format ${this.saved.join(' ')}`; + + exec(cmd, (error, out, stderr) => { + if (error) { + console.log(error.message); + return; + } + + if (stderr) { + console.log(stderr); + return; + } + + console.log(out); + }); + }; +} + +export const FileIO = new _FileIO(); |
