All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.jonatino.netvars.NetVars Maven / Gradle / Ivy

The newest version!
/*
 *    Copyright 2016 Jonathan Beaudoin
 *
 *    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.
 */

package com.github.jonatino.netvars;

import com.github.jonatino.OffsetManager;
import com.github.jonatino.misc.PatternScanner;
import com.github.jonatino.misc.Strings;
import com.github.jonatino.netvars.impl.ClientClass;
import com.github.jonatino.netvars.impl.RecvProp;
import com.github.jonatino.netvars.impl.RecvTable;

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.List;


/**
 * Created by Jonathan on 11/16/2015.
 */
public final class NetVars {

	private static final ArrayDeque netVars = new ArrayDeque<>(16_500);

	private static final ClientClass clientClass = new ClientClass();
	private static final RecvTable table = new RecvTable();
	private static final RecvProp prop = new RecvProp();

	public static void load() {
		int firstclass = PatternScanner.getAddressForPattern(OffsetManager.clientModule(), 0, 0, 0, "DT_TEWorldDecal");
		firstclass = PatternScanner.getAddressForPattern(OffsetManager.clientModule(), 0x2B, 0, PatternScanner.READ, firstclass);

		for (clientClass.setBase(firstclass); clientClass.readable(); clientClass.setBase(clientClass.next())) {
			table.setBase(clientClass.table());
			String tableName = table.tableName();
			if (tableName.length() > 0 && table.propCount() > 0) {
				scanTable(table, 0, tableName);
			}
		}
	}

	public static void dump() {
		List text = new ArrayList<>();
		netVars.forEach(n -> text.add(n.toString()));
		try {
			Files.write(Paths.get("NetVars.txt"), text);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	private static void scanTable(RecvTable table, int offset, String className) {
		for (int i = 0; i < table.propCount(); i++) {
			prop.setBase(table.propForId(i));
			prop.setOffset(offset);

			String propName = prop.name();
			int propOffset = prop.offset();

			if (Character.isDigit(propName.charAt(0))) {
				continue;
			}

			if (propOffset != 0x0) {
				netVars.add(new NetVar(className, propName, propOffset));
			}

			int child = prop.table();
			if (child == 0) {
				continue;
			}
			scanTable(new RecvTable().setBase(child), propOffset, className);
		}
	}

	public static int byName(String className, String varname) {
		for (NetVar var : netVars) {
			if (var.className.equals(className) && var.varName.equals(varname)) {
				return var.offset;
			}
		}
		throw new RuntimeException("NetVar [" + className + ", " + varname + "] not found!");
	}

	private static class NetVar {

		private final String className;
		private final String varName;
		private final int offset;

		private NetVar(String className, String varName, int offset) {
			this.className = className;
			this.varName = varName;
			this.offset = offset;
		}

		@Override
		public String toString() {
			return className + " " + varName + " = " + Strings.hex(offset);
		}

	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy