aboutsummaryrefslogtreecommitdiff
path: root/zen/cmds/print.cpp
blob: f66f433f18f3140bdcde92c1b050cef0ba96a7a5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
// Copyright Epic Games, Inc. All Rights Reserved.

#include "print.h"

#include <zencore/compactbinarypackage.h>
#include <zencore/compactbinaryvalidation.h>
#include <zencore/filesystem.h>
#include <zencore/logging.h>
#include <zencore/string.h>

using namespace std::literals;

namespace zen {

PrintCommand::PrintCommand()
{
	m_Options.add_options()("h,help", "Print help");
	m_Options.add_option("", "s", "source", "Object payload file", cxxopts::value(m_Filename), "<file name>");
}

PrintCommand::~PrintCommand() = default;

int
PrintCommand::Run(const ZenCliOptions& GlobalOptions, int argc, char** argv)
{
	ZEN_UNUSED(GlobalOptions, argc, argv);

	m_Options.parse_positional({"source"});

	auto result = m_Options.parse(argc, argv);

	if (result.count("help"))
	{
		std::cout << m_Options.help({"", "Group"}) << std::endl;

		return 0;
	}

	// Validate arguments

	if (m_Filename.empty())
		throw std::runtime_error("No file specified");

	zen::FileContents Fc = zen::ReadFile(m_Filename);

	if (Fc.ErrorCode)
	{
		zen::ConsoleLog().error("Failed to open file '{}': {}", m_Filename, Fc.ErrorCode.message());

		return 1;
	}

	IoBuffer Data = Fc.Flatten();

	if (CbValidateError Result = ValidateCompactBinary(Data, CbValidateMode::All); Result != CbValidateError::None)
	{
		zen::ConsoleLog().error("Data in file '{}' does not appear to be compact binary (validation error {:#x})",
								m_Filename,
								uint32_t(Result));

		return 1;
	}

	zen::CbObject Object{SharedBuffer(Data)};

	zen::StringBuilder<1024> ObjStr;
	zen::CompactBinaryToJson(Object, ObjStr);
	zen::ConsoleLog().info("{}", ObjStr);

	return 0;
}

//////////////////////////////////////////////////////////////////////////

PrintPackageCommand::PrintPackageCommand()
{
	m_Options.add_options()("h,help", "Print help");
	m_Options.add_option("", "s", "source", "Package payload file", cxxopts::value(m_Filename), "<file name>");
}

PrintPackageCommand::~PrintPackageCommand()
{
}

int
PrintPackageCommand::Run(const ZenCliOptions& GlobalOptions, int argc, char** argv)
{
	ZEN_UNUSED(GlobalOptions, argc, argv);

	m_Options.parse_positional({"source"});

	auto result = m_Options.parse(argc, argv);

	if (result.count("help"))
	{
		std::cout << m_Options.help({"", "Group"}) << std::endl;

		return 0;
	}

	// Validate arguments

	if (m_Filename.empty())
		throw std::runtime_error("No file specified");

	zen::FileContents Fc   = zen::ReadFile(m_Filename);
	IoBuffer		  Data = Fc.Flatten();
	zen::CbPackage	  Package;

	bool Ok = Package.TryLoad(Data) || zen::legacy::TryLoadCbPackage(Package, Data, &UniqueBuffer::Alloc);

	if (Ok)
	{
		zen::StringBuilder<1024> ObjStr;
		zen::CompactBinaryToJson(Package.GetObject(), ObjStr);
		zen::ConsoleLog().info("{}", ObjStr);
	}
	else
	{
		zen::ConsoleLog().error("error: malformed package?");
	}

	return 0;
}

}  // namespace zen