mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2024-06-25 22:53:22 +00:00
![SquidDev](/assets/img/avatar_default.png)
OK, so let's get this out of the way, there's some actual changes mixed in here too. I'm really sorry: - Turtles can now not be renamed with unnamed item tags (previously it would clear the name, this seemed a little unideal). - commands.getBlock(s)Data will also include NBT. Now, onto the horror story which is these inspection changes: - Make a lot of methods static - Typo fixes - Make utility classes final + private constructor - Lots of reformatting (ifs -> ternary, invert control flow, etc...) - ??? - Profit! I'm so going to regret this - can pretty much guarantee this is going to break something.
81 lines
1.9 KiB
Java
81 lines
1.9 KiB
Java
/*
|
|
* This file is part of ComputerCraft - http://www.computercraft.info
|
|
* Copyright Daniel Ratcliffe, 2011-2019. Do not distribute without permission.
|
|
* Send enquiries to dratcliffe@gmail.com
|
|
*/
|
|
|
|
package dan200.computercraft.core.filesystem;
|
|
|
|
import dan200.computercraft.api.filesystem.IMount;
|
|
|
|
import javax.annotation.Nonnull;
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.nio.channels.ReadableByteChannel;
|
|
import java.util.List;
|
|
|
|
public class SubMount implements IMount
|
|
{
|
|
private IMount m_parent;
|
|
private String m_subPath;
|
|
|
|
public SubMount( IMount parent, String subPath )
|
|
{
|
|
m_parent = parent;
|
|
m_subPath = subPath;
|
|
}
|
|
|
|
// IMount implementation
|
|
|
|
@Override
|
|
public boolean exists( @Nonnull String path ) throws IOException
|
|
{
|
|
return m_parent.exists( getFullPath( path ) );
|
|
}
|
|
|
|
@Override
|
|
public boolean isDirectory( @Nonnull String path ) throws IOException
|
|
{
|
|
return m_parent.isDirectory( getFullPath( path ) );
|
|
}
|
|
|
|
@Override
|
|
public void list( @Nonnull String path, @Nonnull List<String> contents ) throws IOException
|
|
{
|
|
m_parent.list( getFullPath( path ), contents );
|
|
}
|
|
|
|
@Override
|
|
public long getSize( @Nonnull String path ) throws IOException
|
|
{
|
|
return m_parent.getSize( getFullPath( path ) );
|
|
}
|
|
|
|
@Nonnull
|
|
@Override
|
|
@Deprecated
|
|
public InputStream openForRead( @Nonnull String path ) throws IOException
|
|
{
|
|
return m_parent.openForRead( getFullPath( path ) );
|
|
}
|
|
|
|
@Nonnull
|
|
@Override
|
|
public ReadableByteChannel openChannelForRead( @Nonnull String path ) throws IOException
|
|
{
|
|
return m_parent.openChannelForRead( getFullPath( path ) );
|
|
}
|
|
|
|
private String getFullPath( String path )
|
|
{
|
|
if( path.isEmpty() )
|
|
{
|
|
return m_subPath;
|
|
}
|
|
else
|
|
{
|
|
return m_subPath + "/" + path;
|
|
}
|
|
}
|
|
}
|