Documentation ¶
Overview ¶
Copyright © 2020 NAME HERE <EMAIL ADDRESS>
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.
Copyright © 2020 NAME HERE <EMAIL ADDRESS>
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.
Copyright © 2020 NAME HERE <EMAIL ADDRESS>
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.
Copyright © 2020 NAME HERE <EMAIL ADDRESS>
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.
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ConvertCmd = &cobra.Command{ Use: "convert", Short: "Convert an item from gibbed to digital_marine or vice versa", Args: cobra.MaximumNArgs(2), Run: func(cmd *cobra.Command, args []string) { if len(args) > 0 { if len(args) > 1 { literals = append(literals, args[0]+" "+args[1]) } else { literals = append(literals, args[0]) } } queue := make(chan string) done := sync.WaitGroup{} done.Add(1) go func() { for literal := range queue { c, err := convert(literal) if err != nil { cmd.PrintErr(err) return } cmd.Println(c) } done.Done() }() for _, literal := range literals { queue <- literal } for _, file := range files { var reader io.Reader var err error if file != "-" { reader, err = os.Open(file) if err != nil { cmd.PrintErr(err) return } } else { reader = os.Stdin } scanner := bufio.NewScanner(reader) for scanner.Scan() { queue <- scanner.Text() } if err := scanner.Err(); err != nil { cmd.PrintErr(err) return } if f, ok := reader.(*os.File); ok { err = f.Close() if err != nil { cmd.PrintErr(err) return } } } close(queue) done.Wait() }, }
deserializeCmd represents the deserialize command
var DecryptCommand = &cobra.Command{ Use: "decrypt", Short: "decrypt a file", Args: cobra.ExactArgs(1), Run: func(cmd *cobra.Command, args []string) { f, err := os.Open(args[0]) if err != nil { panic(err) } defer f.Close() var d []byte if fileType == "character" { _, d = character.Decrypt(f) } else if fileType == "profile" { _, d = profile.Decrypt(f) } else { log.Fatalln("invalid file type") } _, err = os.Stdout.Write(d) }, }
var DeserializeCmd = &cobra.Command{ Use: "deserialize", Short: "Deserialize a .sav file.", Long: `Deserialize a .sav file. Tries to best-guess the sav file format (profile or character) based on the files name. Override with --format <profile|character> `, Args: cobra.ExactArgs(1), PersistentPreRunE: func(cmd *cobra.Command, args []string) error { if format != "" { if format == "profile" { isProfile = true } else if format == "character" { isProfile = false } else { return errors.New("unknown format option") } } else { isProfile = shared.GuessIsProfileSav(args[0]) } return nil }, Run: func(cmd *cobra.Command, args []string) { f, err := os.Open(args[0]) if err != nil { panic(err) } if isProfile { s, p := profile.Deserialize(f) r := struct { Sav shared.SavFile Profile pb.Profile }{s, p} bs, err := yaml.Marshal(r) if err != nil { panic(err) } fmt.Print(string(bs)) } else { s, c := character.Deserialize(f) r := struct { Sav shared.SavFile Character pb.Character }{s, c} bs, err := yaml.Marshal(r) if err != nil { panic(err) } fmt.Print(string(bs)) } }, }
deserializeCmd represents the deserialize command
var ItemsCommand = &cobra.Command{ Use: "items", Args: cobra.ExactArgs(1), Run: func(cmd *cobra.Command, args []string) { f, err := os.Open(args[0]) if err != nil { cmd.PrintErrf("couldn't open character: %v\n", err) } s, c := character.Deserialize(f) err = f.Close() if err != nil { cmd.PrintErr(err) return } for _, file := range files { var reader io.Reader var err error if file != "-" { reader, err = os.Open(file) if err != nil { cmd.PrintErr(err) return } } else { reader = os.Stdin } scanner := bufio.NewScanner(reader) for scanner.Scan() { items = append(items, scanner.Text()) } if err := scanner.Err(); err != nil { cmd.PrintErr(err) return } if f, ok := reader.(*os.File); ok { err = f.Close() if err != nil { cmd.PrintErr(err) return } } } for i := range items { var anoints = make([]string, 0) if parts := strings.Split(items[i], " "); len(parts) > 1 { var anointments Anointments bs, err := base64.StdEncoding.DecodeString(parts[1]) if err != nil { cmd.PrintErr(err) return } err = json.Unmarshal(bs, &anointments) if anointments.CopyType != "anointment" { cmd.PrintErrln("not a valid anointment code") return } for _, i := range anointments.Components { anoints = append(anoints, item.DmKeyToInvKey(anointments.ComponentNames[i], assets.GetDB().GetData("InventoryGenericPartData").Assets)) } items[i] = parts[0] } if strings.HasPrefix(items[i], "bl3(") || strings.HasPrefix(items[i], "BL3(") { } else { bs, err := base64.StdEncoding.DecodeString(items[i]) if err != nil { cmd.PrintErr(err) return } var dmi item.DigitalMarineItem err = json.Unmarshal(bs, &dmi) if err == nil { gi := item.DmToGibbed(dmi) bs, err = item.Serialize(gi, 0) if err != nil { cmd.PrintErr(err) return } items[i] = hex.EncodeToString(bs) } } items[i] = strings.TrimPrefix(items[i], "bl3(") items[i] = strings.TrimPrefix(items[i], "BL3(") items[i] = strings.TrimSuffix(items[i], ")") bs, err := base64.StdEncoding.DecodeString(items[i]) if err != nil { cmd.PrintErr(err) return } bsc := make([]byte, len(bs)) copy(bsc, bs) current, err := item.Deserialize(bsc) if err != nil { cmd.PrintErr(err) return } current.Generics = append(current.Generics, anoints...) bs, err = item.Serialize(current, 0) if err != nil { cmd.PrintErr(err) return } c.InventoryItems = append(c.InventoryItems, &pb.OakInventoryItemSaveGameData{ ItemSerialNumber: bs, PickupOrderIndex: 200, Flags: 1, WeaponSkinPath: "", DevelopmentSaveData: nil, }) } f, err = os.Create(args[0]) if err != nil { cmd.PrintErrf("couldn't create character: %v\n", err) } character.Serialize(f, s, c) err = f.Close() if err != nil { cmd.PrintErr(err) return } }, }
Functions ¶
func Execute ¶
func Execute()
Execute adds all child commands to the root command and sets flags appropriately. This is called by main.main(). It only needs to happen once to the rootCmd.